diff options
author | default <nobody@localhost> | 2023-06-28 20:52:09 +0200 |
---|---|---|
committer | default <nobody@localhost> | 2023-06-28 20:52:09 +0200 |
commit | af180685bdb430e90e3c4057c87595520ee385b4 (patch) | |
tree | 65db25c5b4d5f273224a61109e18554ede0997d2 /data.c | |
parent | 394240b9ba6393794cffd7affa3a5cc6075774aa (diff) |
Added some error control to pinning.
Diffstat (limited to 'data.c')
-rw-r--r-- | data.c | 22 |
1 files changed, 12 insertions, 10 deletions
@@ -1352,7 +1352,7 @@ int is_muted(snac *snac, const char *actor) xs_str *_pinned_fn(snac *user, const char *id) { xs *md5 = xs_md5_hex(id, strlen(id)); - return xs_fmt("%s/pinned/%s", user->basedir, md5); + return xs_fmt("%s/pinned/%s.json", user->basedir, md5); } @@ -1367,26 +1367,28 @@ int is_pinned(snac *user, const char *id) int pin(snac *user, const char *id) /* pins a message */ { - int ret = 0; + int ret = -2; if (xs_startswith(id, user->actor)) { - /* create the subfolder, if it does not exist */ - xs *fn = xs_fmt("%s/pinned/", user->basedir); - mkdirx(fn); - - object_user_cache_add(user, id, "pinned"); + if (is_pinned(user, id)) + ret = -3; + else { + /* create the subfolder, if it does not exist */ + xs *fn = xs_fmt("%s/pinned/", user->basedir); + mkdirx(fn); - ret = 1; + ret = object_user_cache_add(user, id, "pinned"); + } } return ret; } -void unpin(snac *user, const char *id) +int unpin(snac *user, const char *id) /* unpin a message */ { - object_user_cache_del(user, id, "pinned"); + return object_user_cache_del(user, id, "pinned"); } |