summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authordefault <nobody@localhost>2022-09-23 17:36:40 +0200
committerdefault <nobody@localhost>2022-09-23 17:36:40 +0200
commit40193b132007156bd5c44b576df1305ab2492771 (patch)
tree8b2f57268b86fee8b9e4c317821d78b318e07906
parentbdc166111df38377e0fdcffe386715d1c33c7ef2 (diff)
webfinger_request() returns the status.
-rw-r--r--main.c2
-rw-r--r--snac.h2
-rw-r--r--webfinger.c17
3 files changed, 11 insertions, 10 deletions
diff --git a/main.c b/main.c
index d7c1640..101c549 100644
--- a/main.c
+++ b/main.c
@@ -57,7 +57,7 @@ int main(int argc, char *argv[])
xs *uid = NULL;
int status;
- webfinger_request(user, &status, &actor, &uid);
+ status = webfinger_request(user, &actor, &uid);
printf("status: %d\n", status);
if (actor != NULL)
diff --git a/snac.h b/snac.h
index ffd88dc..b181e61 100644
--- a/snac.h
+++ b/snac.h
@@ -76,7 +76,7 @@ d_char *http_signed_request(snac *snac, char *method, char *url,
void httpd(void);
-void webfinger_request(char *qs, int *status, char **actor, char **user);
+int webfinger_request(char *qs, char **actor, char **user);
void webfinger_get_handler(d_char *req, char *q_path, int *status,
char **body, int *b_size, char **ctype);
diff --git a/webfinger.c b/webfinger.c
index 519fb67..3fc1eab 100644
--- a/webfinger.c
+++ b/webfinger.c
@@ -8,9 +8,10 @@
#include "snac.h"
-void webfinger_request(char *qs, int *status, char **actor, char **user)
+int webfinger_request(char *qs, char **actor, char **user)
/* queries the webfinger for qs and fills the required fields */
{
+ int status;
xs *payload = NULL;
int p_size = 0;
xs *headers = xs_dict_new();
@@ -42,10 +43,8 @@ void webfinger_request(char *qs, int *status, char **actor, char **user)
}
}
- if (host == NULL || resource == NULL) {
- *status = 400;
- return;
- }
+ if (host == NULL || resource == NULL)
+ return 400;
headers = xs_dict_append(headers, "accept", "application/json");
@@ -60,15 +59,15 @@ void webfinger_request(char *qs, int *status, char **actor, char **user)
req = xs_dict_append(req, "q_vars", q_vars);
webfinger_get_handler(req, "/.well-known/webfinger",
- status, &payload, &p_size, &ctype);
+ &status, &payload, &p_size, &ctype);
}
else {
xs *url = xs_fmt("https:/" "/%s/.well-known/webfinger?resource=%s", host, resource);
- xs_http_request("GET", url, headers, NULL, 0, status, &payload, &p_size);
+ xs_http_request("GET", url, headers, NULL, 0, &status, &payload, &p_size);
}
- if (valid_status(*status)) {
+ if (valid_status(status)) {
xs *obj = xs_json_loads(payload);
if (user != NULL) {
@@ -94,6 +93,8 @@ void webfinger_request(char *qs, int *status, char **actor, char **user)
}
}
}
+
+ return status;
}