summaryrefslogtreecommitdiff
path: root/data.c
diff options
context:
space:
mode:
authordefault <nobody@localhost>2023-02-12 09:17:38 +0100
committerdefault <nobody@localhost>2023-02-12 09:17:38 +0100
commit0f4db7cf26b25f4841fab33620b3f791c08844ab (patch)
treecca0493b7c9f0dd4d5d6f2b9cc93f4a2c7a57f60 /data.c
parentdca071b14dd2b173ddb04d09a1a50b785e639136 (diff)
New file ~user/user_o.json, for the admin to override user settings.
Diffstat (limited to 'data.c')
-rw-r--r--data.c16
1 files changed, 16 insertions, 0 deletions
diff --git a/data.c b/data.c
index 383cd38..c56b6a0 100644
--- a/data.c
+++ b/data.c
@@ -130,6 +130,7 @@ void user_free(snac *snac)
xs_free(snac->uid);
xs_free(snac->basedir);
xs_free(snac->config);
+ xs_free(snac->config_o);
xs_free(snac->key);
xs_free(snac->actor);
xs_free(snac->md5);
@@ -172,7 +173,22 @@ int user_open(snac *snac, const char *uid)
if ((snac->key = xs_json_loads(key_data)) != NULL) {
snac->actor = xs_fmt("%s/%s", srv_baseurl, uid);
snac->md5 = xs_md5_hex(snac->actor, strlen(snac->actor));
+
+ /* everything is ok right now */
ret = 1;
+
+ /* does it have a configuration override? */
+ xs *cfg_file_o = xs_fmt("%s/user_o.json", snac->basedir);
+ if ((f = fopen(cfg_file_o, "r")) != NULL) {
+ xs *j = xs_readall(f);
+ fclose(f);
+
+ if ((snac->config_o = xs_json_loads(j)) == NULL)
+ srv_log(xs_fmt("cannot parse '%s'", cfg_file_o));
+ }
+
+ if (snac->config_o == NULL)
+ snac->config_o = xs_dict_new();
}
else
srv_log(xs_fmt("cannot parse '%s'", key_file));