diff --git a/activitypub.c b/activitypub.c index dc9ec95..194511e 100644 --- a/activitypub.c +++ b/activitypub.c @@ -1570,7 +1570,7 @@ int process_input_message(snac *snac, xs_dict *msg, xs_dict *req) snac_log(snac, xs_fmt("dropped 'Announce' from limited actor %s", actor)); else if (valid_status(object_get(object, &a_msg))) { - char *who = xs_dict_get(a_msg, "attributedTo"); + const char *who = xs_dict_get(a_msg, "attributedTo"); if (who && !is_muted(snac, who)) { /* bring the actor */ diff --git a/main.c b/main.c index 62f5041..bea6628 100644 --- a/main.c +++ b/main.c @@ -35,6 +35,8 @@ int usage(void) printf("unpin {basedir} {uid} {msg_url} Unpins a message\n"); printf("block {basedir} {instance_url} Blocks a full instance\n"); printf("unblock {basedir} {instance_url} Unblocks a full instance\n"); + printf("limit {basedir} {uid} {actor} Limits an actor (drops their announces)\n"); + printf("unlimit {basedir} {uid} {actor} Unlimits an actor\n"); /* printf("question {basedir} {uid} 'opts' Generates a poll (;-separated opts)\n");*/ @@ -272,6 +274,34 @@ int main(int argc, char *argv[]) return 0; } + if (strcmp(cmd, "limit") == 0) { /** **/ + int ret; + + if (!following_check(&snac, url)) + snac_log(&snac, xs_fmt("actor %s is not being followed", url)); + else + if ((ret = limit(&snac, url)) == 0) + snac_log(&snac, xs_fmt("actor %s is now limited", url)); + else + snac_log(&snac, xs_fmt("error limiting actor %s (%d)", url, ret)); + + return 0; + } + + if (strcmp(cmd, "unlimit") == 0) { /** **/ + int ret; + + if (!following_check(&snac, url)) + snac_log(&snac, xs_fmt("actor %s is not being followed", url)); + else + if ((ret = unlimit(&snac, url)) == 0) + snac_log(&snac, xs_fmt("actor %s is no longer limited", url)); + else + snac_log(&snac, xs_fmt("error unlimiting actor %s (%d)", url, ret)); + + return 0; + } + if (strcmp(cmd, "ping") == 0) { /** **/ xs *actor_o = NULL;