Selaa lähdekoodia

Be more strict in not retrying on permanent errors.

default 1 vuosi sitten
vanhempi
commit
203dd88389
3 muutettua tiedostoa jossa 10 lisäystä ja 5 poistoa
  1. 2 2
      activitypub.c
  2. 7 2
      xs_curl.h
  3. 1 1
      xs_version.h

+ 2 - 2
activitypub.c

@@ -1430,8 +1430,8 @@ int process_input_message(snac *snac, xs_dict *msg, xs_dict *req)
     /* bring the actor */
     a_status = actor_request(snac, actor, &actor_o);
 
-    /* if the actor does not explicitly exist, discard */
-    if (a_status == 404 || a_status == 410) {
+    /* do not retry permanent failures */
+    if (a_status == 404 || a_status == 410 || a_status < 0) {
         snac_debug(snac, 1,
             xs_fmt("dropping message due to actor error %s %d", actor, a_status));
 

+ 7 - 2
xs_curl.h

@@ -169,8 +169,13 @@ xs_dict *xs_http_request(const char *method, const char *url,
     curl_slist_free_all(list);
 
     if (status != NULL) {
-        if (lstatus == 0)
-            lstatus = -cc;
+        if (lstatus == 0) {
+            /* set the timeout error to a fake HTTP status, or propagate as is */
+            if (cc == CURLE_OPERATION_TIMEDOUT)
+                lstatus = 599;
+            else
+                lstatus = -cc;
+        }
 
         *status = (int) lstatus;
     }

+ 1 - 1
xs_version.h

@@ -1 +1 @@
-/* ac9fa6f1941aa3e701bbb1da50b4d5a07090eddb */
+/* 246a8bc9941850f68bf9034662a8a96bcd33926d */