summaryrefslogtreecommitdiff
path: root/mastoapi.c
diff options
context:
space:
mode:
authordefault <nobody@localhost>2024-02-15 10:46:16 +0100
committerdefault <nobody@localhost>2024-02-15 10:46:16 +0100
commit2afcb4b6ecafeb852abb2d0bb48d170b469a5a36 (patch)
treeeb702c2bebdef8977349384ad3da4c5d60221af1 /mastoapi.c
parentb4208bfec93a1d7974bb5f56f6a3d122e7e2ca3b (diff)
mastoapi: fill the verified_at fields in mastoapi_account() for local users.
Diffstat (limited to 'mastoapi.c')
-rw-r--r--mastoapi.c28
1 files changed, 26 insertions, 2 deletions
diff --git a/mastoapi.c b/mastoapi.c
index e2c1ad6..4b7122c 100644
--- a/mastoapi.c
+++ b/mastoapi.c
@@ -622,6 +622,22 @@ xs_dict *mastoapi_account(const xs_dict *actor)
p = xs_dict_get(actor, "attachment");
xs_dict *v;
+ /* dict of validated links */
+ xs_dict *val_links = NULL;
+
+ if (xs_startswith(id, srv_baseurl)) {
+ /* if it's a local user, open it and pick its validated links */
+ snac user;
+
+ if (user_open(&user, prefu)) {
+ val_links = xs_dict_get(user.config, "validated_links");
+ user_free(&user);
+ }
+ }
+
+ if (xs_is_null(val_links))
+ val_links = xs_stock_dict;
+
while (xs_list_iter(&p, &v)) {
char *type = xs_dict_get(v, "type");
char *name = xs_dict_get(v, "name");
@@ -629,11 +645,18 @@ xs_dict *mastoapi_account(const xs_dict *actor)
if (!xs_is_null(type) && !xs_is_null(name) &&
!xs_is_null(value) && strcmp(type, "PropertyValue") == 0) {
+ char *val_date = NULL;
+
+ if (xs_startswith(value, "https:/" "/"))
+ val_date = xs_dict_get(val_links, value);
+
xs *d = xs_dict_new();
d = xs_dict_append(d, "name", name);
d = xs_dict_append(d, "value", value);
- d = xs_dict_append(d, "verified_at", xs_stock_null);
+ d = xs_dict_append(d, "verified_at",
+ xs_type(val_date) == XSTYPE_STRING && *val_date ?
+ val_date : xs_stock_null);
fields = xs_list_append(fields, d);
}
@@ -1149,7 +1172,8 @@ int mastoapi_get_handler(const xs_dict *req, const char *q_path,
d = xs_dict_append(d, "name", k);
d = xs_dict_append(d, "value", v);
d = xs_dict_append(d, "verified_at",
- xs_type(val_date) == XSTYPE_STRING ? val_date : xs_stock_null);
+ xs_type(val_date) == XSTYPE_STRING && *val_date ?
+ val_date : xs_stock_null);
fields = xs_list_append(fields, d);
}