From 1a42fdc8bd4d5dc045a87108e73dcda4f633266b Mon Sep 17 00:00:00 2001 From: grunfink Date: Fri, 24 Oct 2025 05:02:28 +0200 Subject: Keep track of deleted users and return 410 Gone for them. --- activitypub.c | 10 ++++++---- data.c | 29 +++++++++++++++++++++++++++++ html.c | 5 +++-- httpd.c | 3 +++ snac.h | 2 ++ utils.c | 2 ++ 6 files changed, 45 insertions(+), 6 deletions(-) diff --git a/activitypub.c b/activitypub.c index 2d53cbe..0368ac8 100644 --- a/activitypub.c +++ b/activitypub.c @@ -3660,8 +3660,9 @@ int activitypub_get_handler(const xs_dict *req, const char *q_path, uid = xs_list_get(l, 1); if (!user_open(&snac, uid)) { /* invalid user */ - srv_debug(1, xs_fmt("activitypub_get_handler bad user %s", uid)); - return HTTP_STATUS_NOT_FOUND; + status = grave(uid, 0) ? HTTP_STATUS_GONE : HTTP_STATUS_NOT_FOUND; + srv_debug(1, xs_fmt("activitypub_get_handler bad user %s %d", uid, status)); + return status; } p_path = xs_list_get(l, 2); @@ -3854,8 +3855,9 @@ int activitypub_post_handler(const xs_dict *req, const char *q_path, const char *uid = xs_list_get(l, 1); if (!user_open(&snac, uid)) { /* invalid user */ - srv_debug(1, xs_fmt("activitypub_post_handler bad user %s", uid)); - return HTTP_STATUS_NOT_FOUND; + status = grave(uid, 0) ? HTTP_STATUS_GONE : HTTP_STATUS_NOT_FOUND; + srv_debug(1, xs_fmt("activitypub_post_handler bad user %s %d", uid, status)); + return status; } /* if it has a digest, check it now, because diff --git a/data.c b/data.c index 36f5101..d291ba7 100644 --- a/data.c +++ b/data.c @@ -3137,6 +3137,35 @@ int instance_failure(const char *url, int op) } +int grave(const char *objid, int op) +/* the graveyeard of deleted objects */ +{ + int ret = 0; + xs *dir = xs_fmt("%s/grave", srv_basedir); + xs *md5 = xs_md5_hex(objid, strlen(objid)); + xs *fn = xs_fmt("%s/%s", dir, md5); + FILE *f; + + switch (op) { + case 0: /** check **/ + ret = mtime(fn) > 0.0 ? 1 : 0; + break; + + case 1: /** add **/ + mkdirx(dir); + + if ((f = fopen(fn, "w")) != NULL) { + fprintf(f, "%s\n", objid); + fclose(f); + } + + break; + } + + return ret; +} + + /** notifications **/ xs_str *notify_check_time(snac *snac, int reset) diff --git a/html.c b/html.c index 584059b..2146c93 100644 --- a/html.c +++ b/html.c @@ -3830,8 +3830,9 @@ int html_get_handler(const xs_dict *req, const char *q_path, if (!uid || !user_open(&snac, uid)) { /* invalid user */ - srv_debug(1, xs_fmt("html_get_handler bad user %s", uid)); - return HTTP_STATUS_NOT_FOUND; + status = grave(uid, 0) ? HTTP_STATUS_GONE : HTTP_STATUS_NOT_FOUND; + srv_debug(1, xs_fmt("html_get_handler bad user %s %d", uid, status)); + return status; } user = &snac; /* for L() */ diff --git a/httpd.c b/httpd.c index 254d0e5..a8cd849 100644 --- a/httpd.c +++ b/httpd.c @@ -598,6 +598,9 @@ void httpd_connection(FILE *f) if (status == HTTP_STATUS_NOT_FOUND) body = xs_str_new("