summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--activitypub.c19
-rw-r--r--data.c6
-rw-r--r--snac.h2
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));
diff --git a/data.c b/data.c
index 4c2a4a8..1312790 100644
--- a/data.c
+++ b/data.c
@@ -1107,7 +1107,7 @@ int timeline_add(snac *snac, const char *id, const xs_dict *o_msg)
1107} 1107}
1108 1108
1109 1109
1110void timeline_admire(snac *snac, const char *id, const char *admirer, int like) 1110int 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
diff --git a/snac.h b/snac.h
index 0d05cb1..b95e4e1 100644
--- a/snac.h
+++ b/snac.h
@@ -133,7 +133,7 @@ int timeline_del(snac *snac, char *id);
133xs_list *timeline_simple_list(snac *snac, const char *idx_name, int skip, int show); 133xs_list *timeline_simple_list(snac *snac, const char *idx_name, int skip, int show);
134xs_list *timeline_list(snac *snac, const char *idx_name, int skip, int show); 134xs_list *timeline_list(snac *snac, const char *idx_name, int skip, int show);
135int timeline_add(snac *snac, const char *id, const xs_dict *o_msg); 135int timeline_add(snac *snac, const char *id, const xs_dict *o_msg);
136void timeline_admire(snac *snac, const char *id, const char *admirer, int like); 136int timeline_admire(snac *snac, const char *id, const char *admirer, int like);
137 137
138xs_list *timeline_top_level(snac *snac, xs_list *list); 138xs_list *timeline_top_level(snac *snac, xs_list *list);
139xs_list *local_list(snac *snac, int max); 139xs_list *local_list(snac *snac, int max);