summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--activitypub.c55
-rw-r--r--data.c2
-rw-r--r--http.c1
-rw-r--r--main.c1
-rw-r--r--snac.c1
-rw-r--r--xs_mime.h52
6 files changed, 110 insertions, 2 deletions
diff --git a/activitypub.c b/activitypub.c
index 8924f1c..7cb0f37 100644
--- a/activitypub.c
+++ b/activitypub.c
@@ -5,6 +5,7 @@
#include "xs_encdec.h"
#include "xs_json.h"
#include "xs_curl.h"
+#include "xs_mime.h"
#include "snac.h"
@@ -195,6 +196,59 @@ d_char *msg_update(snac *snac, char *object)
}
+d_char *msg_actor(snac *snac)
+/* create a Person message for this actor */
+{
+ xs *ctxt = xs_list_new();
+ xs *icon = xs_dict_new();
+ xs *keys = xs_dict_new();
+ xs *avtr = NULL;
+ xs *kid = NULL;
+ d_char *msg = msg_base(snac, "Person", snac->actor, NULL, NULL);
+ char *p;
+ int n;
+
+ /* change the @context (is this really necessary?) */
+ ctxt = xs_list_append(ctxt, "https:/" "/www.w3.org/ns/activitystreams");
+ ctxt = xs_list_append(ctxt, "https:/" "/w3id.org/security/v1");
+ msg = xs_dict_set(msg, "@context", ctxt);
+
+ msg = xs_dict_set(msg, "url", snac->actor);
+ msg = xs_dict_set(msg, "name", xs_dict_get(snac->config, "name"));
+ msg = xs_dict_set(msg, "preferredUsername", snac->uid);
+ msg = xs_dict_set(msg, "published", xs_dict_get(snac->config, "published"));
+ msg = xs_dict_set(msg, "summary", xs_dict_get(snac->config, "bio"));
+
+ char *folders[] = { "inbox", "outbox", "followers", "following", NULL };
+
+ for (n = 0; folders[n]; n++) {
+ xs *f = xs_fmt("%s/%s", snac->actor, folders[n]);
+ msg = xs_dict_set(msg, folders[n], f);
+ }
+
+ p = xs_dict_get(snac->config, "avatar");
+
+ if (*p == '\0')
+ avtr = xs_fmt("%s/susie.png", srv_baseurl);
+ else
+ avtr = xs_dup(p);
+
+ icon = xs_dict_append(icon, "type", "Image");
+ icon = xs_dict_append(icon, "mediaType", xs_mime_by_ext(avtr));
+ icon = xs_dict_append(icon, "url", avtr);
+ msg = xs_dict_set(msg, "icon", icon);
+
+ kid = xs_fmt("%s#main-key", snac->actor);
+
+ keys = xs_dict_append(keys, "id", kid);
+ keys = xs_dict_append(keys, "owner", snac->actor);
+ keys = xs_dict_append(keys, "publicKeyPem", xs_dict_get(snac->key, "public"));
+ msg = xs_dict_set(msg, "publicKey", keys);
+
+ return msg;
+}
+
+
/** queues **/
void process_message(snac *snac, char *msg, char *req)
@@ -356,6 +410,7 @@ int activitypub_get_handler(d_char *req, char *q_path,
if (p_path == NULL) {
/* if there was no component after the user, it's an actor request */
+ msg = msg_actor(&snac);
}
else
if (strcmp(p_path, "outbox") == 0) {
diff --git a/data.c b/data.c
index 3167d28..06119c7 100644
--- a/data.c
+++ b/data.c
@@ -601,8 +601,6 @@ void timeline_admire(snac *snac, char *id, char *admirer, int like)
msg = xs_dict_set(msg, "_snac", meta);
- xs *j1 = xs_json_dumps_pp(msg, 4);
-
unlink(ofn);
_timeline_write(snac, id, msg, xs_dict_get(meta, "parent"));
diff --git a/http.c b/http.c
index 79ad239..abc3466 100644
--- a/http.c
+++ b/http.c
@@ -86,6 +86,7 @@ d_char *http_signed_request(snac *snac, char *method, char *url,
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, "host", xs_dict_get(srv_config, "host"));
hdrs = xs_dict_append(hdrs, "user-agent", "snac/2.x");
response = xs_http_request(method, url, hdrs,
diff --git a/main.c b/main.c
index d7d408f..acd9ef2 100644
--- a/main.c
+++ b/main.c
@@ -50,6 +50,7 @@ char *get_argv(int *argi, int argc, char *argv[])
#define GET_ARGV() get_argv(&argi, argc, argv)
+
int main(int argc, char *argv[])
{
char *cmd;
diff --git a/snac.c b/snac.c
index ccf54f8..9532c3b 100644
--- a/snac.c
+++ b/snac.c
@@ -11,6 +11,7 @@
#include "xs_openssl.h"
#include "xs_socket.h"
#include "xs_httpd.h"
+#include "xs_mime.h"
#include "snac.h"
diff --git a/xs_mime.h b/xs_mime.h
new file mode 100644
index 0000000..699ab39
--- /dev/null
+++ b/xs_mime.h
@@ -0,0 +1,52 @@
+/* copyright (c) 2022 grunfink - MIT license */
+
+#ifndef _XS_MIME
+
+#define _XS_MIME
+
+char *xs_mime_by_ext(char *file);
+
+#ifdef XS_IMPLEMENTATION
+
+/* intentionally brain-dead simple */
+struct _mime_info {
+ char *type;
+ char *ext;
+} mime_info[] = {
+ { "application/json", ".json" },
+ { "image/gif", ".gif" },
+ { "image/jpeg", ".jpeg" },
+ { "image/jpeg", ".jpg" },
+ { "image/png", ".png" },
+ { "image/webp", ".webp" },
+ { "text/css", ".css" },
+ { "text/html", ".html" },
+ { "text/plain", ".txt" },
+ { "text/xml", ".xml" },
+ { NULL, NULL }
+};
+
+
+char *xs_mime_by_ext(char *file)
+/* returns the MIME type by file extension */
+{
+ struct _mime_info *mi = mime_info;
+ char *p = NULL;
+
+ while (p == NULL && mi->type != NULL) {
+ if (xs_endswith(file, mi->ext))
+ p = mi->type;
+
+ mi++;
+ }
+
+ if (p == NULL)
+ p = "application/octet-stream";
+
+ return p;
+}
+
+
+#endif /* XS_IMPLEMENTATION */
+
+#endif /* XS_MIME */