New function timeline_admire().

This commit is contained in:
default 2022-09-25 17:42:39 +02:00
parent fe6440b363
commit bb70101fec
3 changed files with 104 additions and 36 deletions

View file

@ -221,7 +221,16 @@ void process_message(snac *snac, char *msg, char *req)
if (strcmp(type, "Accept") == 0) {
}
else
if (strcmp(type, "Like") == 0 || strcmp(type, "Announce") == 0) {
*/
if (strcmp(type, "Like") == 0) {
if (xs_type(object) == XSTYPE_STRING)
timeline_admire(snac, object, actor, 1);
else
snac_debug(snac, 2, xs_fmt("xs_type for 'Like' object not string"));
}
else
/*
|| strcmp(type, "Announce") == 0) {
}
else
if (strcmp(type, "Update") == 0) {

128
data.c
View file

@ -391,35 +391,11 @@ d_char *_timeline_new_fn(snac *snac, char *id)
}
void timeline_add(snac *snac, char *id, char *o_msg, char *parent)
/* adds a message to the timeline */
void _timeline_write(snac *snac, char *id, char *msg, char *parent)
/* writes a timeline entry and refreshes the ancestors */
{
xs *pfn = _timeline_find_fn(snac, id);
FILE *f;
if (pfn != NULL) {
snac_log(snac, xs_fmt("timeline_add refusing rewrite %s %s", id, pfn));
return;
}
/* build the new filename */
xs *fn = _timeline_new_fn(snac, id);
xs *msg = xs_dup(o_msg);
xs *md;
/* add metadata */
md = xs_json_loads("{"
"\"children\": [],"
"\"liked_by\": [],"
"\"announced_by\": [],"
"\"version\": \"snac/2.x\","
"\"parent\": null"
"}");
if (!xs_is_null(parent))
md = xs_dict_set(md, "parent", parent);
msg = xs_dict_set(msg, "_snac", md);
FILE *f;
if ((f = fopen(fn, "w")) != NULL) {
xs *j = xs_json_dumps_pp(msg, 4);
@ -427,7 +403,7 @@ void timeline_add(snac *snac, char *id, char *o_msg, char *parent)
fwrite(j, strlen(j), 1, f);
fclose(f);
snac_debug(snac, 1, xs_fmt("timeline_add %s %s", id, fn));
snac_debug(snac, 1, xs_fmt("_timeline_write %s %s", id, fn));
}
/* related to this user? link to local timeline */
@ -436,7 +412,7 @@ void timeline_add(snac *snac, char *id, char *o_msg, char *parent)
xs *lfn = xs_replace(fn, "/timeline/", "/local/");
link(fn, lfn);
snac_debug(snac, 1, xs_fmt("timeline_add (local) %s %s", id, lfn));
snac_debug(snac, 1, xs_fmt("_timeline_write (local) %s %s", id, lfn));
}
if (!xs_is_null(parent)) {
@ -459,8 +435,9 @@ void timeline_add(snac *snac, char *id, char *o_msg, char *parent)
xs *meta = xs_dup(xs_dict_get(p_msg, "_snac"));
xs *children = xs_dup(xs_dict_get(meta, "children"));
/* add the child */
children = xs_list_append(children, id);
/* add the child if it's not already there */
if (xs_list_in(children, id) == -1)
children = xs_list_append(children, id);
/* re-store */
meta = xs_dict_set(meta, "children", children);
@ -476,7 +453,8 @@ void timeline_add(snac *snac, char *id, char *o_msg, char *parent)
unlink(pfn);
snac_debug(snac, 2, xs_fmt("updated parent %s %s", parent, nfn));
snac_debug(snac, 1,
xs_fmt("_timeline_write updated parent %s %s", parent, nfn));
/* try to do the same with the local */
xs *olfn = xs_replace(pfn, "/timeline/", "/local/");
@ -486,7 +464,8 @@ void timeline_add(snac *snac, char *id, char *o_msg, char *parent)
link(nfn, nlfn);
snac_debug(snac, 2, xs_fmt("updated parent (local) %s %s", parent, nlfn));
snac_debug(snac, 1,
xs_fmt("_timeline_write updated parent (local) %s %s", parent, nlfn));
}
}
else
@ -506,7 +485,8 @@ void timeline_add(snac *snac, char *id, char *o_msg, char *parent)
rename(gofn, gnfn);
snac_debug(snac, 2, xs_fmt("updated grampa %s %s", grampa, gnfn));
snac_debug(snac, 2,
xs_fmt("_timeline_write updated grampa %s %s", grampa, gnfn));
/* try to do the same with the local */
xs *golfn = xs_replace(gofn, "/timeline/", "/local/");
@ -516,7 +496,8 @@ void timeline_add(snac *snac, char *id, char *o_msg, char *parent)
link(gnfn, gnlfn);
snac_debug(snac, 2, xs_fmt("updated grampa (local) %s %s", parent, gnlfn));
snac_debug(snac, 2,
xs_fmt("_timeline_write updated grampa (local) %s %s", parent, gnlfn));
}
/* now open it and get its own parent */
@ -540,6 +521,83 @@ void timeline_add(snac *snac, char *id, char *o_msg, char *parent)
}
void timeline_add(snac *snac, char *id, char *o_msg, char *parent)
/* adds a message to the timeline */
{
xs *pfn = _timeline_find_fn(snac, id);
if (pfn != NULL) {
snac_log(snac, xs_fmt("timeline_add refusing rewrite %s %s", id, pfn));
return;
}
xs *msg = xs_dup(o_msg);
xs *md;
/* add new metadata */
md = xs_json_loads("{"
"\"children\": [],"
"\"liked_by\": [],"
"\"announced_by\": [],"
"\"version\": \"snac/2.x\","
"\"parent\": null"
"}");
if (!xs_is_null(parent))
md = xs_dict_set(md, "parent", parent);
msg = xs_dict_set(msg, "_snac", md);
_timeline_write(snac, id, msg, parent);
}
void timeline_admire(snac *snac, char *id, char *admirer, int like)
/* updates a timeline entry with a new admiration */
{
xs *ofn = _timeline_find_fn(snac, id);
FILE *f;
if (ofn != NULL && (f = fopen(ofn, "r")) != NULL) {
int changed = 0;
xs *j1 = xs_readall(f);
fclose(f);
xs *msg = xs_json_loads(j1);
xs *meta = xs_dup(xs_dict_get(msg, "_snac"));
xs *list;
if (like)
list = xs_dup(xs_dict_get(meta, "liked_by"));
else
list = xs_dup(xs_dict_get(meta, "announced_by"));
/* add the admirer if it's not already there */
if (xs_list_in(list, admirer) == -1) {
list = xs_list_append(list, admirer);
changed = 1;
}
if (changed) {
/* re-store */
if (like)
meta = xs_dict_set(meta, "liked_by", list);
else
meta = xs_dict_set(meta, "announced_by", list);
msg = xs_dict_set(msg, "_snac", meta);
xs *j1 = xs_json_dumps_pp(msg, 4);
unlink(ofn);
_timeline_write(snac, id, msg, xs_dict_get(meta, "parent"));
}
}
}
d_char *_following_fn(snac *snac, char *actor)
{
xs *md5 = xs_md5_hex(actor, strlen(actor));

1
snac.h
View file

@ -56,6 +56,7 @@ void timeline_del(snac *snac, char *id);
d_char *timeline_get(snac *snac, char *fn);
d_char *timeline_list(snac *snac);
void timeline_add(snac *snac, char *id, char *msg, char *parent);
void timeline_admire(snac *snac, char *id, char *admirer, int like);
int following_add(snac *snac, char *actor, char *msg);
int following_del(snac *snac, char *actor);