summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--snac.c73
-rw-r--r--snac.h10
-rw-r--r--xs.h4
-rw-r--r--xs_json.h2
4 files changed, 86 insertions, 3 deletions
diff --git a/snac.c b/snac.c
index c28c607..1957271 100644
--- a/snac.c
+++ b/snac.c
@@ -1,3 +1,4 @@
1/* snac - A simple, minimalistic ActivityPub instance */
1/* copyright (c) 2022 grunfink - MIT license */ 2/* copyright (c) 2022 grunfink - MIT license */
2 3
3#define XS_IMPLEMENTATION 4#define XS_IMPLEMENTATION
@@ -13,8 +14,80 @@
13 14
14#include "snac.h" 15#include "snac.h"
15 16
17d_char *srv_basedir = NULL;
18d_char *srv_config = NULL;
19d_char *srv_baseurl = NULL;
20
21int dbglevel = 0;
22
23
24void srv_log(d_char *str)
25/* logs a message */
26{
27 char tm[16] = "00:00:00";
28 xs *msg = str;
29
30 fprintf(stderr, "%s %s\n", tm, msg);
31}
32
33
34int srv_open(char *basedir)
35/* opens a server */
36{
37 int ret = 0;
38 xs *cfg_file = NULL;
39 FILE *f;
40
41 srv_basedir = xs_str_new(basedir);
42
43 cfg_file = xs_fmt("%s/server.json", basedir);
44
45 if ((f = fopen(cfg_file, "r")) == NULL)
46 srv_log(xs_fmt("cannot open %s", cfg_file));
47 else {
48 xs *cfg_data;
49
50 /* read full config file */
51 cfg_data = xs_readall(f);
52
53 /* parse */
54 srv_config = xs_json_loads(cfg_data);
55
56 if (srv_config == NULL)
57 srv_log(xs_fmt("cannot parse %s", cfg_file));
58 else {
59 char *host;
60 char *prefix;
61 char *dbglvl;
62
63 host = xs_dict_get(srv_config, "host");
64 prefix = xs_dict_get(srv_config, "prefix");
65 dbglvl = xs_dict_get(srv_config, "dbglevel");
66
67 if (host == NULL || prefix == NULL)
68 srv_log(xs_str_new("cannot get server data"));
69 else {
70 srv_baseurl = xs_fmt("https://%s%s", host, prefix);
71
72 dbglevel = (int) xs_number_get(dbglvl);
73
74 if ((dbglvl = getenv("DEBUG")) != NULL) {
75 dbglevel = atoi(dbglvl);
76 srv_log(xs_fmt("DEBUG level set to %d from environment", dbglevel));
77 }
78
79 ret = 1;
80 }
81 }
82 }
83
84 return ret;
85}
86
16 87
17int main(int argc, char *argv[]) 88int main(int argc, char *argv[])
18{ 89{
90 srv_open("/home/angel/lib/snac/comam.es");
91
19 return 0; 92 return 0;
20} 93}
diff --git a/snac.h b/snac.h
index 2038c9d..609be40 100644
--- a/snac.h
+++ b/snac.h
@@ -1,2 +1,12 @@
1/* snac - A simple, minimalistic ActivityPub instance */
1/* copyright (c) 2022 grunfink - MIT license */ 2/* copyright (c) 2022 grunfink - MIT license */
2 3
4extern d_char *srv_basedir;
5extern d_char *srv_config;
6extern d_char *srv_baseurl;
7
8extern int dbglevel;
9
10void srv_log(d_char *str);
11int srv_open(char *basedir);
12
diff --git a/xs.h b/xs.h
index 40df89f..9195bc0 100644
--- a/xs.h
+++ b/xs.h
@@ -75,7 +75,7 @@ d_char *xs_dict_del(d_char *dict, const char *key);
75d_char *xs_dict_set(d_char *dict, const char *key, const char *data); 75d_char *xs_dict_set(d_char *dict, const char *key, const char *data);
76d_char *xs_val_new(xstype t); 76d_char *xs_val_new(xstype t);
77d_char *xs_number_new(float f); 77d_char *xs_number_new(float f);
78float xs_get_number(char *v); 78float xs_number_get(char *v);
79 79
80extern int _xs_debug; 80extern int _xs_debug;
81 81
@@ -697,7 +697,7 @@ d_char *xs_number_new(float f)
697} 697}
698 698
699 699
700float xs_get_number(char *v) 700float xs_number_get(char *v)
701/* gets the number as a float */ 701/* gets the number as a float */
702{ 702{
703 float f = 0.0; 703 float f = 0.0;
diff --git a/xs_json.h b/xs_json.h
index 4bf73d5..f6eaa2f 100644
--- a/xs_json.h
+++ b/xs_json.h
@@ -93,7 +93,7 @@ d_char *_xs_json_dumps(d_char *s, char *data, int level, int indent)
93 case XSTYPE_NUMBER: 93 case XSTYPE_NUMBER:
94 { 94 {
95 char tmp[32]; 95 char tmp[32];
96 snprintf(tmp, sizeof(tmp), "%g", xs_get_number(data)); 96 snprintf(tmp, sizeof(tmp), "%g", xs_number_get(data));
97 s = xs_str_cat(s, tmp); 97 s = xs_str_cat(s, tmp);
98 } 98 }
99 break; 99 break;