summaryrefslogtreecommitdiff
path: root/webfinger.c
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 /webfinger.c
parentbdc166111df38377e0fdcffe386715d1c33c7ef2 (diff)
webfinger_request() returns the status.
Diffstat (limited to 'webfinger.c')
-rw-r--r--webfinger.c17
1 files changed, 9 insertions, 8 deletions
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;
}