summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--activitypub.c27
-rw-r--r--main.c14
-rw-r--r--snac.h1
3 files changed, 42 insertions, 0 deletions
diff --git a/activitypub.c b/activitypub.c
index c88b0ce..afbe7af 100644
--- a/activitypub.c
+++ b/activitypub.c
@@ -1168,6 +1168,33 @@ xs_dict *msg_admiration(snac *snac, char *object, char *type)
}
+xs_dict *msg_repulsion(snac *user, char *id, char *type)
+/* creates an Undo + admiration message */
+{
+ xs *a_msg = NULL;
+ xs_dict *msg = NULL;
+
+ if (valid_status(object_get(id, &a_msg))) {
+ /* create a clone of the original admiration message */
+ xs *object = msg_admiration(user, id, type);
+
+ /* delete the published date */
+ object = xs_dict_del(object, "published");
+
+ /* create an undo message for this object */
+ msg = msg_undo(user, object);
+
+ /* copy the 'to' field */
+ msg = xs_dict_set(msg, "to", xs_dict_get(object, "to"));
+
+ /* now we despise this */
+ object_unadmire(id, user->actor, *type == 'L' ? 1 : 0);
+ }
+
+ return msg;
+}
+
+
xs_dict *msg_actor(snac *snac)
/* create a Person message for this actor */
{
diff --git a/main.c b/main.c
index 1026b19..cd1a47b 100644
--- a/main.c
+++ b/main.c
@@ -295,6 +295,20 @@ int main(int argc, char *argv[])
return 0;
}
+ if (strcmp(cmd, "unboost") == 0) { /** **/
+ xs *msg = msg_repulsion(&snac, url, "Announce");
+
+ if (msg != NULL) {
+ enqueue_message(&snac, msg);
+
+ if (dbglevel) {
+ xs_json_dump(msg, 4, stdout);
+ }
+ }
+
+ return 0;
+ }
+
if (strcmp(cmd, "follow") == 0) { /** **/
xs *msg = msg_follow(&snac, url);
diff --git a/snac.h b/snac.h
index 0de9d5c..cac09a9 100644
--- a/snac.h
+++ b/snac.h
@@ -264,6 +264,7 @@ char *get_atto(const xs_dict *msg);
xs_list *get_attachments(const xs_dict *msg);
xs_dict *msg_admiration(snac *snac, char *object, char *type);
+xs_dict *msg_repulsion(snac *user, char *id, char *type);
xs_dict *msg_create(snac *snac, const xs_dict *object);
xs_dict *msg_follow(snac *snac, const char *actor);