summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authordefault <nobody@localhost>2023-08-06 19:04:30 +0200
committerdefault <nobody@localhost>2023-08-06 19:04:30 +0200
commit106791ff6ba11c256b42a69c1ff052da3e8413fe (patch)
tree7e06feb4704ac0bdd65640729e923a67621d9aaf
parent28adb6c850cb13195e7324f36c0b04c0256ee328 (diff)
Added command-line interface for limit/unlimit users.
-rw-r--r--activitypub.c2
-rw-r--r--main.c30
2 files changed, 31 insertions, 1 deletions
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;