diff options
| -rw-r--r-- | activitypub.c | 19 | ||||
| -rw-r--r-- | data.c | 6 | ||||
| -rw-r--r-- | snac.h | 2 |
3 files changed, 18 insertions, 9 deletions
diff --git a/activitypub.c b/activitypub.c index e389915..d8f748e 100644 --- a/activitypub.c +++ b/activitypub.c | |||
| @@ -1955,9 +1955,12 @@ int process_input_message(snac *snac, xs_dict *msg, xs_dict *req) | |||
| 1955 | if (xs_type(object) == XSTYPE_DICT) | 1955 | if (xs_type(object) == XSTYPE_DICT) |
| 1956 | object = xs_dict_get(object, "id"); | 1956 | object = xs_dict_get(object, "id"); |
| 1957 | 1957 | ||
| 1958 | timeline_admire(snac, object, actor, 1); | 1958 | if (timeline_admire(snac, object, actor, 1) == 201) { |
| 1959 | snac_log(snac, xs_fmt("new 'Like' %s %s", actor, object)); | 1959 | snac_log(snac, xs_fmt("new 'Like' %s %s", actor, object)); |
| 1960 | do_notify = 1; | 1960 | do_notify = 1; |
| 1961 | } | ||
| 1962 | else | ||
| 1963 | snac_log(snac, xs_fmt("repeated 'Like' from %s to %s", actor, object)); | ||
| 1961 | } | 1964 | } |
| 1962 | else | 1965 | else |
| 1963 | if (strcmp(type, "Announce") == 0) { /** **/ | 1966 | if (strcmp(type, "Announce") == 0) { /** **/ |
| @@ -1983,9 +1986,13 @@ int process_input_message(snac *snac, xs_dict *msg, xs_dict *req) | |||
| 1983 | xs *who_o = NULL; | 1986 | xs *who_o = NULL; |
| 1984 | 1987 | ||
| 1985 | if (valid_status(actor_request(snac, who, &who_o))) { | 1988 | if (valid_status(actor_request(snac, who, &who_o))) { |
| 1986 | timeline_admire(snac, object, actor, 0); | 1989 | if (timeline_admire(snac, object, actor, 0) == 201) { |
| 1987 | snac_log(snac, xs_fmt("new 'Announce' %s %s", actor, object)); | 1990 | snac_log(snac, xs_fmt("new 'Announce' %s %s", actor, object)); |
| 1988 | do_notify = 1; | 1991 | do_notify = 1; |
| 1992 | } | ||
| 1993 | else | ||
| 1994 | snac_log(snac, xs_fmt("repeated 'Announce' from %s to %s", | ||
| 1995 | actor, object)); | ||
| 1989 | } | 1996 | } |
| 1990 | else | 1997 | else |
| 1991 | snac_debug(snac, 1, xs_fmt("dropped 'Announce' on actor request error %s", who)); | 1998 | snac_debug(snac, 1, xs_fmt("dropped 'Announce' on actor request error %s", who)); |
| @@ -1107,7 +1107,7 @@ int timeline_add(snac *snac, const char *id, const xs_dict *o_msg) | |||
| 1107 | } | 1107 | } |
| 1108 | 1108 | ||
| 1109 | 1109 | ||
| 1110 | void timeline_admire(snac *snac, const char *id, const char *admirer, int like) | 1110 | int timeline_admire(snac *snac, const char *id, const char *admirer, int like) |
| 1111 | /* updates a timeline entry with a new admiration */ | 1111 | /* updates a timeline entry with a new admiration */ |
| 1112 | { | 1112 | { |
| 1113 | /* if we are admiring this, add to both timelines */ | 1113 | /* if we are admiring this, add to both timelines */ |
| @@ -1116,10 +1116,12 @@ void timeline_admire(snac *snac, const char *id, const char *admirer, int like) | |||
| 1116 | object_user_cache_add(snac, id, "private"); | 1116 | object_user_cache_add(snac, id, "private"); |
| 1117 | } | 1117 | } |
| 1118 | 1118 | ||
| 1119 | object_admire(id, admirer, like); | 1119 | int ret = object_admire(id, admirer, like); |
| 1120 | 1120 | ||
| 1121 | snac_debug(snac, 1, xs_fmt("timeline_admire (%s) %s %s", | 1121 | snac_debug(snac, 1, xs_fmt("timeline_admire (%s) %s %s", |
| 1122 | like ? "Like" : "Announce", id, admirer)); | 1122 | like ? "Like" : "Announce", id, admirer)); |
| 1123 | |||
| 1124 | return ret; | ||
| 1123 | } | 1125 | } |
| 1124 | 1126 | ||
| 1125 | 1127 | ||
| @@ -133,7 +133,7 @@ int timeline_del(snac *snac, char *id); | |||
| 133 | xs_list *timeline_simple_list(snac *snac, const char *idx_name, int skip, int show); | 133 | xs_list *timeline_simple_list(snac *snac, const char *idx_name, int skip, int show); |
| 134 | xs_list *timeline_list(snac *snac, const char *idx_name, int skip, int show); | 134 | xs_list *timeline_list(snac *snac, const char *idx_name, int skip, int show); |
| 135 | int timeline_add(snac *snac, const char *id, const xs_dict *o_msg); | 135 | int timeline_add(snac *snac, const char *id, const xs_dict *o_msg); |
| 136 | void timeline_admire(snac *snac, const char *id, const char *admirer, int like); | 136 | int timeline_admire(snac *snac, const char *id, const char *admirer, int like); |
| 137 | 137 | ||
| 138 | xs_list *timeline_top_level(snac *snac, xs_list *list); | 138 | xs_list *timeline_top_level(snac *snac, xs_list *list); |
| 139 | xs_list *local_list(snac *snac, int max); | 139 | xs_list *local_list(snac *snac, int max); |