mirror of
https://codeberg.org/grunfink/snac2.git
synced 2024-11-25 22:45:05 +00:00
Simplified pinning functions.
This commit is contained in:
parent
3ff7e6233f
commit
9a67b19a7c
1 changed files with 19 additions and 27 deletions
46
data.c
46
data.c
|
@ -1013,10 +1013,16 @@ int object_unadmire(const char *id, const char *actor, int like)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
xs_str *object_user_cache_fn_by_md5(snac *user, const char *md5, const char *cachedir)
|
||||||
|
{
|
||||||
|
return xs_fmt("%s/%s/%s.json", user->basedir, cachedir, md5);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
xs_str *object_user_cache_fn(snac *user, const char *id, const char *cachedir)
|
xs_str *object_user_cache_fn(snac *user, const char *id, const char *cachedir)
|
||||||
{
|
{
|
||||||
xs *md5 = xs_md5_hex(id, strlen(id));
|
xs *md5 = xs_md5_hex(id, strlen(id));
|
||||||
return xs_fmt("%s/%s/%s.json", user->basedir, cachedir, md5);
|
return object_user_cache_fn_by_md5(user, md5, cachedir);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -1067,6 +1073,14 @@ int object_user_cache_in(snac *user, const char *id, const char *cachedir)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
int object_user_cache_in_by_md5(snac *user, const char *md5, const char *cachedir)
|
||||||
|
/* checks if an object is stored in a cache */
|
||||||
|
{
|
||||||
|
xs *cfn = object_user_cache_fn_by_md5(user, md5, cachedir);
|
||||||
|
return !!(mtime(cfn) != 0.0);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
xs_list *object_user_cache_list(snac *user, const char *cachedir, int max, int inv)
|
xs_list *object_user_cache_list(snac *user, const char *cachedir, int max, int inv)
|
||||||
/* returns the objects in a cache as a list */
|
/* returns the objects in a cache as a list */
|
||||||
{
|
{
|
||||||
|
@ -1571,25 +1585,16 @@ int unbookmark(snac *user, const char *id)
|
||||||
|
|
||||||
/** pinning **/
|
/** pinning **/
|
||||||
|
|
||||||
xs_str *_pinned_fn(snac *user, const char *id)
|
|
||||||
{
|
|
||||||
xs *md5 = xs_md5_hex(id, strlen(id));
|
|
||||||
return xs_fmt("%s/pinned/%s.json", user->basedir, md5);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
int is_pinned(snac *user, const char *id)
|
int is_pinned(snac *user, const char *id)
|
||||||
/* returns true if this note is pinned */
|
/* returns true if this note is pinned */
|
||||||
{
|
{
|
||||||
xs *fn = _pinned_fn(user, id);
|
return object_user_cache_in(user, id, "pinned");
|
||||||
return !!(mtime(fn) != 0.0);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int is_pinned_by_md5(snac *user, const char *md5)
|
int is_pinned_by_md5(snac *user, const char *md5)
|
||||||
{
|
{
|
||||||
xs *fn = xs_fmt("%s/pinned/%s.json", user->basedir, md5);
|
return object_user_cache_in_by_md5(user, md5, "pinned");
|
||||||
return !!(mtime(fn) != 0.0);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -1601,14 +1606,9 @@ int pin(snac *user, const char *id)
|
||||||
if (xs_startswith(id, user->actor)) {
|
if (xs_startswith(id, user->actor)) {
|
||||||
if (is_pinned(user, id))
|
if (is_pinned(user, id))
|
||||||
ret = -3;
|
ret = -3;
|
||||||
else {
|
else
|
||||||
/* create the subfolder, if it does not exist */
|
|
||||||
xs *fn = xs_fmt("%s/pinned/", user->basedir);
|
|
||||||
mkdirx(fn);
|
|
||||||
|
|
||||||
ret = object_user_cache_add(user, id, "pinned");
|
ret = object_user_cache_add(user, id, "pinned");
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
@ -1617,15 +1617,7 @@ int pin(snac *user, const char *id)
|
||||||
int unpin(snac *user, const char *id)
|
int unpin(snac *user, const char *id)
|
||||||
/* unpin a message */
|
/* unpin a message */
|
||||||
{
|
{
|
||||||
int ret = object_user_cache_del(user, id, "pinned");
|
return object_user_cache_del(user, id, "pinned");
|
||||||
|
|
||||||
if (ret != -1) {
|
|
||||||
/* delete from the index */
|
|
||||||
xs *idx = xs_fmt("%s/pinned.idx", user->basedir);
|
|
||||||
index_del(idx, id);
|
|
||||||
}
|
|
||||||
|
|
||||||
return ret;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue