summaryrefslogtreecommitdiff
path: root/mastoapi.c
diff options
context:
space:
mode:
authordefault <nobody@localhost>2023-04-12 20:20:46 +0200
committerdefault <nobody@localhost>2023-04-12 20:20:46 +0200
commite146c2afa8f29ce18313f6792f845f3613576699 (patch)
tree3da381f1b5ec246e7fa8cdd089125e11f3e1f843 /mastoapi.c
parent5366bd18530b483e8643a2ae4b63df648b9fb7f4 (diff)
Also return (some) information for non-local users.
Diffstat (limited to 'mastoapi.c')
-rw-r--r--mastoapi.c76
1 files changed, 47 insertions, 29 deletions
diff --git a/mastoapi.c b/mastoapi.c
index 82db8c2..c947096 100644
--- a/mastoapi.c
+++ b/mastoapi.c
@@ -412,7 +412,7 @@ xs_str *mastoapi_id(const xs_dict *msg)
#define MID_TO_MD5(id) (id + 10)
-xs_dict *mastoapi_account(snac *snac, const xs_dict *actor)
+xs_dict *mastoapi_account(const xs_dict *actor)
/* converts an ActivityPub actor to a Mastodon account */
{
xs_dict *acct = xs_dict_new();
@@ -459,7 +459,7 @@ xs_dict *mastoapi_status(snac *snac, const xs_dict *msg)
if (actor == NULL)
return NULL;
- xs *acct = mastoapi_account(snac, actor);
+ xs *acct = mastoapi_account(actor);
/** shave the yak converting an ActivityPub Note to a Mastodon status **/
@@ -682,38 +682,58 @@ int mastoapi_get_handler(const xs_dict *req, const char *q_path,
xs *l = xs_split(cmd, "/");
const char *uid = xs_list_get(l, 2);
const char *opt = xs_list_get(l, 3);
- snac snac2;
- if (uid != NULL && user_open(&snac2, uid)) {
- xs *out = NULL;
-
- if (opt == NULL) {
- /* account information */
- xs *actor = msg_actor(&snac2);
- out = mastoapi_account(&snac2, actor);
- }
- else
- if (strcmp(opt, "statuses") == 0) {
- /* the public list of posts of a user */
- xs *timeline = timeline_simple_list(&snac2, "public", 0, 256);
- xs_list *p = timeline;
- xs_str *v;
+ if (uid != NULL) {
+ snac snac2;
+ xs *out = NULL;
+ xs *actor = NULL;
+
+ /* is it a local user? */
+ if (user_open(&snac2, uid)) {
+ if (opt == NULL) {
+ /* account information */
+ actor = msg_actor(&snac2);
+ out = mastoapi_account(actor);
+ }
+ else
+ if (strcmp(opt, "statuses") == 0) {
+ /* the public list of posts of a user */
+ xs *timeline = timeline_simple_list(&snac2, "public", 0, 256);
+ xs_list *p = timeline;
+ xs_str *v;
- out = xs_list_new();
+ out = xs_list_new();
- while (xs_list_iter(&p, &v)) {
- xs *msg = NULL;
+ while (xs_list_iter(&p, &v)) {
+ xs *msg = NULL;
- if (valid_status(timeline_get_by_md5(&snac2, v, &msg))) {
- /* add only posts by the author */
- if (strcmp(xs_dict_get(msg, "type"), "Note") == 0 &&
- xs_startswith(xs_dict_get(msg, "id"), snac2.actor)) {
- xs *st = mastoapi_status(&snac2, msg);
+ if (valid_status(timeline_get_by_md5(&snac2, v, &msg))) {
+ /* add only posts by the author */
+ if (strcmp(xs_dict_get(msg, "type"), "Note") == 0 &&
+ xs_startswith(xs_dict_get(msg, "id"), snac2.actor)) {
+ xs *st = mastoapi_status(&snac2, msg);
- out = xs_list_append(out, st);
+ out = xs_list_append(out, st);
+ }
}
}
}
+
+ user_free(&snac2);
+ }
+ else {
+ /* try the uid as the md5 of a possibly loaded actor */
+ if (logged_in && valid_status(object_get_by_md5(uid, &actor))) {
+ if (opt == NULL) {
+ /* account information */
+ out = mastoapi_account(actor);
+ }
+ else
+ if (strcmp(opt, "statuses") == 0) {
+ /* we don't serve statuses of others; return the empty list */
+ out = xs_list_new();
+ }
+ }
}
if (out != NULL) {
@@ -721,8 +741,6 @@ int mastoapi_get_handler(const xs_dict *req, const char *q_path,
*ctype = "application/json";
status = 200;
}
-
- user_free(&snac2);
}
}
else
@@ -993,7 +1011,7 @@ int mastoapi_get_handler(const xs_dict *req, const char *q_path,
xs *actor2 = NULL;
if (valid_status(object_get_by_md5(v, &actor2))) {
- xs *acct2 = mastoapi_account(&snac1, actor2);
+ xs *acct2 = mastoapi_account(actor2);
out = xs_list_append(out, acct2);
}