Browse Source

actor_request() accepts again an optional snac argument.

default 1 year ago
parent
commit
af912dba0b
5 changed files with 13 additions and 13 deletions
  1. 7 7
      activitypub.c
  2. 1 1
      http.c
  3. 3 3
      main.c
  4. 1 1
      mastoapi.c
  5. 1 1
      snac.h

+ 7 - 7
activitypub.c

@@ -115,7 +115,7 @@ int activitypub_request(snac *user, const char *url, xs_dict **data)
 }
 
 
-int actor_request(const char *actor, xs_dict **data)
+int actor_request(snac *user, const char *actor, xs_dict **data)
 /* request an actor */
 {
     int status;
@@ -129,7 +129,7 @@ int actor_request(const char *actor, xs_dict **data)
 
     if (status != 200) {
         /* actor data non-existent or stale: get from the net */
-        status = activitypub_request(NULL, actor, &payload);
+        status = activitypub_request(user, actor, &payload);
 
         if (valid_status(status)) {
             /* renew data */
@@ -207,7 +207,7 @@ int timeline_request(snac *snac, char **id, xs_str **wrk, int level)
 
                     /* request (and drop) the actor for this entry */
                     if (!xs_is_null(actor))
-                        actor_request(actor, NULL);
+                        actor_request(snac, actor, NULL);
 
                     /* does it have an ancestor? */
                     char *in_reply_to = xs_dict_get(object, "inReplyTo");
@@ -331,7 +331,7 @@ xs_str *get_actor_inbox(const char *actor)
     xs *data = NULL;
     char *v = NULL;
 
-    if (valid_status(actor_request(actor, &data))) {
+    if (valid_status(actor_request(NULL, actor, &data))) {
         /* try first endpoints/sharedInbox */
         if ((v = xs_dict_get(data, "endpoints")))
             v = xs_dict_get(v, "sharedInbox");
@@ -1127,7 +1127,7 @@ xs_dict *msg_follow(snac *snac, const char *q)
     }
 
     /* request the actor */
-    status = actor_request(actor, &actor_o);
+    status = actor_request(snac, actor, &actor_o);
 
     if (valid_status(status)) {
         /* check if the actor is an alias */
@@ -1560,7 +1560,7 @@ int process_input_message(snac *snac, xs_dict *msg, xs_dict *req)
     }
 
     /* bring the actor */
-    a_status = actor_request(actor, &actor_o);
+    a_status = actor_request(snac, actor, &actor_o);
 
     /* do not retry permanent failures */
     if (a_status == 404 || a_status == 410 || a_status < 0) {
@@ -1748,7 +1748,7 @@ int process_input_message(snac *snac, xs_dict *msg, xs_dict *req)
                     /* bring the actor */
                     xs *who_o = NULL;
 
-                    if (valid_status(actor_request(who, &who_o))) {
+                    if (valid_status(actor_request(snac, who, &who_o))) {
                         timeline_admire(snac, object, actor, 0);
                         snac_log(snac, xs_fmt("new 'Announce' %s %s", actor, object));
                         do_notify = 1;

+ 1 - 1
http.c

@@ -173,7 +173,7 @@ int check_signature(xs_dict *req, xs_str **err)
 
     xs *actor = NULL;
 
-    if (!valid_status(actor_request(keyId, &actor))) {
+    if (!valid_status(actor_request(NULL, keyId, &actor))) {
         *err = xs_fmt("unknown actor %s", keyId);
         return 0;
     }

+ 3 - 3
main.c

@@ -184,7 +184,7 @@ int main(int argc, char *argv[])
         xs *actor = NULL;
         int status;
 
-        status = actor_request(user, &actor);
+        status = actor_request(NULL, user, &actor);
 
         printf("status: %d\n", status);
         if (valid_status(status)) {
@@ -341,7 +341,7 @@ int main(int argc, char *argv[])
     if (strcmp(cmd, "ping") == 0) { /** **/
         xs *actor_o = NULL;
 
-        if (valid_status(actor_request(url, &actor_o))) {
+        if (valid_status(actor_request(&snac, url, &actor_o))) {
             xs *msg = msg_ping(&snac, url);
 
             enqueue_output_by_actor(&snac, msg, url, 0);
@@ -416,7 +416,7 @@ int main(int argc, char *argv[])
         int status;
         xs *data = NULL;
 
-        status = actor_request(url, &data);
+        status = actor_request(&snac, url, &data);
 
         printf("status: %d\n", status);
 

+ 1 - 1
mastoapi.c

@@ -1944,7 +1944,7 @@ int mastoapi_get_handler(const xs_dict *req, const char *q_path,
                     if (valid_status(webfinger_request(q, &actor, &user))) {
                         xs *actor_o = NULL;
 
-                        if (valid_status(actor_request(actor, &actor_o))) {
+                        if (valid_status(actor_request(&snac1, actor, &actor_o))) {
                             xs *acct = mastoapi_account(actor_o);
 
                             acl = xs_list_append(acl, acct);

+ 1 - 1
snac.h

@@ -243,7 +243,7 @@ xs_dict *msg_question(snac *user, const char *content, xs_list *attach,
                       const xs_list *opts, int multiple, int end_secs);
 
 int activitypub_request(snac *snac, const char *url, xs_dict **data);
-int actor_request(const char *actor, xs_dict **data);
+int actor_request(snac *user, const char *actor, xs_dict **data);
 void timeline_request_replies(snac *user, const char *id);
 int send_to_inbox_raw(const char *keyid, const char *seckey,
                   const xs_str *inbox, const xs_dict *msg,