snac2

Fork of https://codeberg.org/grunfink/snac2
git clone https://git.inz.fi/snac2
Log | Files | Refs | README | LICENSE

commit 52f27123bbd6cf8101a86618c6aa04f52a07543a
parent 45c5c71f9e8f0ae9155be947b7548ed211e1fa4b
Author: default <nobody@localhost>
Date:   Mon, 18 Dec 2023 11:37:02 +0100

Fixed follow / unfollow mess for shared inboxes.

Diffstat:
Mactivitypub.c | 10++++++++--
1 file changed, 8 insertions(+), 2 deletions(-)

diff --git a/activitypub.c b/activitypub.c @@ -468,9 +468,9 @@ int is_msg_for_me(snac *snac, const xs_dict *c_msg) return following_check(snac, actor); } - /* if it's an Undo + Follow, it must be from someone we follow */ + /* if it's an Undo + Follow, it must be from someone that follows us */ if (xs_match(type, "Undo")) { - return following_check(snac, actor); + return follower_check(snac, actor); } /* if it's an Accept + Follow, it must be for a Follow we created */ @@ -478,6 +478,12 @@ int is_msg_for_me(snac *snac, const xs_dict *c_msg) return following_check(snac, actor); } + /* if it's a Follow, it must be explicitly for us */ + if (xs_match(type, "Follow")) { + char *object = xs_dict_get(c_msg, "object"); + return !xs_is_null(object) && strcmp(snac->actor, object) == 0; + } + /* if it's not a Create or Update, allow as is */ if (!xs_match(type, "Create|Update")) { return 1;