1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586 |
- #include "xs.h"
- #include "xs_io.h"
- #include "xs_encdec.h"
- #include "xs_openssl.h"
- #include "xs_curl.h"
- #include "snac.h"
- d_char *http_signed_request(snac *snac, char *method, char *url,
- d_char *headers,
- d_char *body, int b_size,
- int *status, d_char **payload, int *p_size)
- {
- xs *l1;
- xs *date;
- xs *digest;
- xs *s64;
- xs *signature;
- xs *hdrs;
- char *host;
- char *target;
- char *seckey;
- char *k, *v;
- date = xs_utc_time("%a, %d %b %Y %H:%M:%S GMT");
- {
- xs *s = xs_replace(url, "https:/" "/", "");
- l1 = xs_split_n(s, "/", 1);
- }
-
- host = xs_list_get(l1, 0);
- if (xs_list_len(l1) == 2)
- target = xs_list_get(l1, 1);
- else
- target = "";
-
- if (body != NULL)
- digest = xs_sha256_base64(body, b_size);
- else
- digest = xs_sha256_base64("", 0);
- seckey = xs_dict_get(snac->key, "secret");
- {
-
- xs *s = xs_fmt("(request-target): %s /%s\n"
- "host: %s\n"
- "digest: SHA-256=%s\n"
- "date: %s",
- strcmp(method, "POST") == 0 ? "post" : "get",
- target, host, digest, date);
- s64 = xs_rsa_sign(seckey, s, strlen(s));
- }
-
- signature = xs_fmt("keyId=\"%s#main-key\","
- "algorithm=\"rsa-sha256\","
- "headers=\"(request-target) host digest date\","
- "signature=\"%s\"",
- snac->actor, s64);
-
- hdrs = xs_dict_new();
- while (xs_dict_iter(&headers, &k, &v))
- hdrs = xs_dict_append(hdrs, k, v);
-
- hdrs = xs_dict_append(hdrs, "content-type", "application/activity+json");
- hdrs = xs_dict_append(hdrs, "accept", "application/activity+json");
- hdrs = xs_dict_append(hdrs, "date", date);
- hdrs = xs_dict_append(hdrs, "signature", signature);
- hdrs = xs_dict_append(hdrs, "digest", digest);
- hdrs = xs_dict_append(hdrs, "user-agent", "snac/2.x");
- return xs_http_request(method, url, hdrs,
- body, b_size, status, payload, p_size);
- }
|