From 2e982c79e1385b568d407f6e45f2b062761dec12 Mon Sep 17 00:00:00 2001 From: grunfink Date: Sun, 27 Jul 2025 04:08:37 +0200 Subject: mastoapi: Fixed metadata in verify_credentials. --- mastoapi.c | 27 +++++++++++++++++++++++++-- 1 file changed, 25 insertions(+), 2 deletions(-) (limited to 'mastoapi.c') diff --git a/mastoapi.c b/mastoapi.c index 7fb995a..798edec 100644 --- a/mastoapi.c +++ b/mastoapi.c @@ -1271,8 +1271,31 @@ void credentials_get(char **body, char **ctype, int *status, snac snac) acct = xs_dict_append(acct, "header", header); acct = xs_dict_append(acct, "header_static", header); - const xs_dict *metadata = xs_dict_get(snac.config, "metadata"); - if (xs_type(metadata) == XSTYPE_DICT) { + xs *metadata = NULL; + const xs_dict *md = xs_dict_get(snac.config, "metadata"); + + if (xs_is_dict(md)) + metadata = xs_dup(md); + else + if (xs_is_string(md)) { + metadata = xs_dict_new(); + xs *l = xs_split(md, "\n"); + const char *ll; + + xs_list_foreach(l, ll) { + xs *kv = xs_split_n(ll, "=", 1); + const char *k = xs_list_get(kv, 0); + const char *v = xs_list_get(kv, 1); + + if (k && v) { + xs *kk = xs_strip_i(xs_dup(k)); + xs *vv = xs_strip_i(xs_dup(v)); + metadata = xs_dict_set(metadata, kk, vv); + } + } + } + + if (xs_is_dict(metadata)) { xs *fields = xs_list_new(); const xs_str *k; const xs_str *v; -- cgit v1.2.3