mirror of
https://codeberg.org/grunfink/snac2.git
synced 2024-11-15 01:55:03 +00:00
Also purge stray index files.
This commit is contained in:
parent
1d82d13d62
commit
3a9ea8aa1c
1 changed files with 49 additions and 18 deletions
67
data.c
67
data.c
|
@ -549,9 +549,6 @@ int _object_add(const char *id, d_char *obj, int ow)
|
||||||
/* update the children index of the parent */
|
/* update the children index of the parent */
|
||||||
xs *c_idx = _object_fn(in_reply_to);
|
xs *c_idx = _object_fn(in_reply_to);
|
||||||
|
|
||||||
if (mtime(c_idx) == 0.0)
|
|
||||||
srv_debug(0, xs_fmt("object_add (warn) parent object not here %s", c_idx));
|
|
||||||
|
|
||||||
c_idx = xs_replace_i(c_idx, ".json", "_c.idx");
|
c_idx = xs_replace_i(c_idx, ".json", "_c.idx");
|
||||||
|
|
||||||
if (!index_in(c_idx, id)) {
|
if (!index_in(c_idx, id)) {
|
||||||
|
@ -1631,34 +1628,68 @@ void purge_server(void)
|
||||||
{
|
{
|
||||||
xs *spec = xs_fmt("%s/object/??", srv_basedir);
|
xs *spec = xs_fmt("%s/object/??", srv_basedir);
|
||||||
xs *dirs = xs_glob(spec, 0, 0);
|
xs *dirs = xs_glob(spec, 0, 0);
|
||||||
char *p, *v;
|
xs_list *p;
|
||||||
|
xs_str *v;
|
||||||
int cnt = 0;
|
int cnt = 0;
|
||||||
|
int icnt = 0;
|
||||||
|
|
||||||
time_t mt = time(NULL) - 7 * 24 * 3600;
|
time_t mt = time(NULL) - 7 * 24 * 3600;
|
||||||
|
|
||||||
p = dirs;
|
p = dirs;
|
||||||
while (xs_list_iter(&p, &v)) {
|
while (xs_list_iter(&p, &v)) {
|
||||||
xs *spec2 = xs_fmt("%s/" "*.json", v);
|
xs_list *p2;
|
||||||
xs *files = xs_glob(spec2, 0, 0);
|
xs_str *v2;
|
||||||
char *p2, *v2;
|
|
||||||
|
|
||||||
p2 = files;
|
{
|
||||||
while (xs_list_iter(&p2, &v2)) {
|
xs *spec2 = xs_fmt("%s/" "*.json", v);
|
||||||
int n_link;
|
xs *files = xs_glob(spec2, 0, 0);
|
||||||
|
|
||||||
/* old and with no hard links? */
|
p2 = files;
|
||||||
if (mtime_nl(v2, &n_link) < mt && n_link < 2) {
|
while (xs_list_iter(&p2, &v2)) {
|
||||||
xs *s1 = xs_replace(v2, ".json", "");
|
int n_link;
|
||||||
xs *l = xs_split(s1, "/");
|
|
||||||
char *md5 = xs_list_get(l, -1);
|
|
||||||
|
|
||||||
object_del_by_md5(md5);
|
/* old and with no hard links? */
|
||||||
cnt++;
|
if (mtime_nl(v2, &n_link) < mt && n_link < 2) {
|
||||||
|
xs *s1 = xs_replace(v2, ".json", "");
|
||||||
|
xs *l = xs_split(s1, "/");
|
||||||
|
char *md5 = xs_list_get(l, -1);
|
||||||
|
|
||||||
|
object_del_by_md5(md5);
|
||||||
|
cnt++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
/* look for stray indexes */
|
||||||
|
xs *speci = xs_fmt("%s/" "*_?.idx", v);
|
||||||
|
xs *idxfs = xs_glob(speci, 0, 0);
|
||||||
|
|
||||||
|
p2 = idxfs;
|
||||||
|
while (xs_list_iter(&p2, &v2)) {
|
||||||
|
/* old enough to consider? */
|
||||||
|
if (mtime(v2) < mt) {
|
||||||
|
/* check if the indexed object is here */
|
||||||
|
xs *o = xs_dup(v2);
|
||||||
|
char *ext = strchr(o, '_');
|
||||||
|
|
||||||
|
if (ext) {
|
||||||
|
*ext = '\0';
|
||||||
|
o = xs_str_cat(o, ".json");
|
||||||
|
|
||||||
|
if (mtime(o) == 0.0) {
|
||||||
|
/* delete */
|
||||||
|
unlink(v2);
|
||||||
|
srv_debug(1, xs_fmt("purged %s", v2));
|
||||||
|
icnt++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
srv_debug(0, xs_fmt("purge: global %d", cnt));
|
srv_debug(0, xs_fmt("purge: global (obj: %d, idx: %d)", cnt, icnt));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue