diff options
author | default <nobody@localhost> | 2023-08-06 19:04:30 +0200 |
---|---|---|
committer | default <nobody@localhost> | 2023-08-06 19:04:30 +0200 |
commit | 106791ff6ba11c256b42a69c1ff052da3e8413fe (patch) | |
tree | 7e06feb4704ac0bdd65640729e923a67621d9aaf /main.c | |
parent | 28adb6c850cb13195e7324f36c0b04c0256ee328 (diff) |
Added command-line interface for limit/unlimit users.
Diffstat (limited to 'main.c')
-rw-r--r-- | main.c | 30 |
1 files changed, 30 insertions, 0 deletions
@@ -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; |