From 13d4fde316c8281e3100017b4b8eca4fc0dfc925 Mon Sep 17 00:00:00 2001 From: default Date: Thu, 19 Dec 2024 10:05:11 +0100 Subject: [PATCH] Avoid adding repeated attachments. --- activitypub.c | 29 ++++++++++++++++++++--------- format.c | 48 ++++++++++++++++++++++++++++++++++++------------ 2 files changed, 56 insertions(+), 21 deletions(-) diff --git a/activitypub.c b/activitypub.c index 773df78..4d52efa 100644 --- a/activitypub.c +++ b/activitypub.c @@ -1476,20 +1476,31 @@ xs_dict *msg_note(snac *snac, const xs_str *content, const xs_val *rcpts, /* create the attachment list, if there are any */ if (!xs_is_null(attach)) { - int c = 0; - while (xs_list_next(attach, &v, &c)) { - xs *d = xs_dict_new(); + xs_list_foreach(attach, v) { const char *url = xs_list_get(v, 0); const char *alt = xs_list_get(v, 1); const char *mime = xs_mime_by_ext(url); + int add = 1; - d = xs_dict_append(d, "mediaType", mime); - d = xs_dict_append(d, "url", url); - d = xs_dict_append(d, "name", alt); - d = xs_dict_append(d, "type", - xs_startswith(mime, "image/") ? "Image" : "Document"); + /* check if it's already here */ + const xs_dict *ad; + xs_list_foreach(atls, ad) { + if (strcmp(xs_dict_get_def(ad, "url", ""), url) == 0) { + add = 0; + break; + } + } - atls = xs_list_append(atls, d); + if (add) { + xs *d = xs_dict_new(); + d = xs_dict_append(d, "mediaType", mime); + d = xs_dict_append(d, "url", url); + d = xs_dict_append(d, "name", alt); + d = xs_dict_append(d, "type", + xs_startswith(mime, "image/") ? "Image" : "Document"); + + atls = xs_list_append(atls, d); + } } } diff --git a/format.c b/format.c index d0b535d..12783ae 100644 --- a/format.c +++ b/format.c @@ -163,14 +163,26 @@ static xs_str *format_line(const char *line, xs_list **attach) const char *mime = xs_mime_by_ext(img_url); if (attach != NULL && xs_startswith(mime, "image/")) { - xs *d = xs_dict_new(); + const xs_dict *ad; + int add = 1; - d = xs_dict_append(d, "mediaType", mime); - d = xs_dict_append(d, "url", img_url); - d = xs_dict_append(d, "name", alt_text); - d = xs_dict_append(d, "type", "Image"); + xs_list_foreach(*attach, ad) { + if (strcmp(xs_dict_get_def(ad, "url", ""), img_url) == 0) { + add = 0; + break; + } + } - *attach = xs_list_append(*attach, d); + if (add) { + xs *d = xs_dict_new(); + + d = xs_dict_append(d, "mediaType", mime); + d = xs_dict_append(d, "url", img_url); + d = xs_dict_append(d, "name", alt_text); + d = xs_dict_append(d, "type", "Image"); + + *attach = xs_list_append(*attach, d); + } } else { xs *link = xs_fmt("%s", img_url, alt_text); @@ -191,14 +203,26 @@ static xs_str *format_line(const char *line, xs_list **attach) if (attach != NULL && xs_startswith(mime, "image/")) { /* if it's a link to an image, insert it as an attachment */ - xs *d = xs_dict_new(); + const xs_dict *ad; + int add = 1; - d = xs_dict_append(d, "mediaType", mime); - d = xs_dict_append(d, "url", v2); - d = xs_dict_append(d, "name", ""); - d = xs_dict_append(d, "type", "Image"); + xs_list_foreach(*attach, ad) { + if (strcmp(xs_dict_get_def(ad, "url", ""), v2) == 0) { + add = 0; + break; + } + } - *attach = xs_list_append(*attach, d); + if (add) { + xs *d = xs_dict_new(); + + d = xs_dict_append(d, "mediaType", mime); + d = xs_dict_append(d, "url", v2); + d = xs_dict_append(d, "name", ""); + d = xs_dict_append(d, "type", "Image"); + + *attach = xs_list_append(*attach, d); + } } else { xs *s1 = xs_fmt("%s", v2, u);