summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authordefault <nobody@localhost>2023-11-08 08:14:34 +0100
committerdefault <nobody@localhost>2023-11-08 08:14:34 +0100
commit895cf82a7d2b8704aeeabf002bc26a49336586ff (patch)
tree7266fc1e4609a7b51cdbfeb0ea4a8312afa7c0ec
parentd8db26258558d3058e7a125d0b480991c293f181 (diff)
New code for indexing tags.
-rw-r--r--data.c61
-rw-r--r--snac.h2
2 files changed, 63 insertions, 0 deletions
diff --git a/data.c b/data.c
index f06e99c..5026154 100644
--- a/data.c
+++ b/data.c
@@ -1081,6 +1081,8 @@ int timeline_add(snac *snac, const char *id, const xs_dict *o_msg)
int ret = object_add(id, o_msg);
timeline_update_indexes(snac, id);
+ tag_index(id, o_msg);
+
snac_debug(snac, 1, xs_fmt("timeline_add %s", id));
return ret;
@@ -1565,6 +1567,65 @@ int limited(snac *user, const char *id, int cmd)
}
+/** tag indexing **/
+
+void tag_index(const char *id, const xs_dict *obj)
+/* update the tag indexes for this object */
+{
+ xs_list *tags = xs_dict_get(obj, "tag");
+
+ if (is_msg_public(obj) && xs_type(tags) == XSTYPE_LIST && xs_list_len(tags) > 0) {
+ xs *md5_id = xs_md5_hex(id, strlen(id));
+ xs *g_tag_dir = xs_fmt("%s/tag", srv_basedir);
+
+ mkdirx(g_tag_dir);
+
+ xs_dict *v;
+ while (xs_list_iter(&tags, &v)) {
+ char *type = xs_dict_get(v, "type");
+ char *name = xs_dict_get(v, "name");
+
+ if (!xs_is_null(type) && !xs_is_null(name) && strcmp(type, "Hashtag") == 0) {
+ if (*name == '#')
+ name++;
+
+ name = xs_tolower_i(name);
+
+ xs *md5_tag = xs_md5_hex(name, strlen(name));
+ xs *tag_dir = xs_fmt("%s/%c%c", g_tag_dir, md5_tag[0], md5_tag[1]);
+ mkdirx(tag_dir);
+
+ xs *g_tag_idx = xs_fmt("%s/%s.idx", tag_dir, md5_tag);
+ index_add(g_tag_idx, md5_id);
+
+ FILE *f;
+ xs *g_tag_name = xs_replace(g_tag_idx, ".idx", ".tag");
+ if ((f = fopen(g_tag_name, "w")) != NULL) {
+ fprintf(f, "%s\n", name);
+ fclose(f);
+ }
+
+ srv_debug(0, xs_fmt("tagged %s #%s (%s #%s)", id, name, md5_id, md5_tag));
+ }
+ }
+ }
+}
+
+
+xs_list *tag_search(char *tag, int skip, int show)
+/* returns the list of posts tagged with tag */
+{
+ if (*tag == '#')
+ tag++;
+
+ xs *lw_tag = xs_tolower_i(xs_dup(tag));
+ xs *md5 = xs_md5_hex(lw_tag, strlen(lw_tag));
+ xs *idx = xs_fmt("%s/tag/%c%c/%s.idx", srv_basedir, md5[0], md5[1], md5);
+
+ return index_list_desc(idx, skip, show);
+}
+
+
/** static data **/
static int _load_raw_file(const char *fn, xs_val **data, int *size,
diff --git a/snac.h b/snac.h
index ed0f94d..582f5f1 100644
--- a/snac.h
+++ b/snac.h
@@ -143,6 +143,8 @@ int limited(snac *user, const char *id, int cmd);
void hide(snac *snac, const char *id);
int is_hidden(snac *snac, const char *id);
+void tag_index(const char *id, const xs_dict *obj);
+
int actor_add(const char *actor, xs_dict *msg);
int actor_get(const char *actor, xs_dict **data);