mirror of
https://codeberg.org/grunfink/snac2.git
synced 2024-11-22 13:25:04 +00:00
Added some follower functions.
This commit is contained in:
parent
c30a610a41
commit
839cb552f4
2 changed files with 109 additions and 11 deletions
109
data.c
109
data.c
|
@ -4,6 +4,7 @@
|
||||||
#include "xs.h"
|
#include "xs.h"
|
||||||
#include "xs_io.h"
|
#include "xs_io.h"
|
||||||
#include "xs_json.h"
|
#include "xs_json.h"
|
||||||
|
#include "xs_openssl.h"
|
||||||
|
|
||||||
#include "snac.h"
|
#include "snac.h"
|
||||||
|
|
||||||
|
@ -16,13 +17,17 @@ int srv_open(char *basedir)
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
xs *cfg_file = NULL;
|
xs *cfg_file = NULL;
|
||||||
FILE *f;
|
FILE *f;
|
||||||
|
d_char *error = NULL;
|
||||||
|
|
||||||
srv_basedir = xs_str_new(basedir);
|
srv_basedir = xs_str_new(basedir);
|
||||||
|
|
||||||
|
if (xs_endswith(srv_basedir, "/"))
|
||||||
|
srv_basedir = xs_crop(srv_basedir, 0, -1);
|
||||||
|
|
||||||
cfg_file = xs_fmt("%s/server.json", basedir);
|
cfg_file = xs_fmt("%s/server.json", basedir);
|
||||||
|
|
||||||
if ((f = fopen(cfg_file, "r")) == NULL)
|
if ((f = fopen(cfg_file, "r")) == NULL)
|
||||||
srv_log(xs_fmt("error opening '%s'", cfg_file));
|
error = xs_fmt("error opening '%s'", cfg_file);
|
||||||
else {
|
else {
|
||||||
xs *cfg_data;
|
xs *cfg_data;
|
||||||
|
|
||||||
|
@ -33,7 +38,7 @@ int srv_open(char *basedir)
|
||||||
srv_config = xs_json_loads(cfg_data);
|
srv_config = xs_json_loads(cfg_data);
|
||||||
|
|
||||||
if (srv_config == NULL)
|
if (srv_config == NULL)
|
||||||
srv_log(xs_fmt("cannot parse '%s'", cfg_file));
|
error = xs_fmt("cannot parse '%s'", cfg_file);
|
||||||
else {
|
else {
|
||||||
char *host;
|
char *host;
|
||||||
char *prefix;
|
char *prefix;
|
||||||
|
@ -44,7 +49,7 @@ int srv_open(char *basedir)
|
||||||
dbglvl = xs_dict_get(srv_config, "dbglevel");
|
dbglvl = xs_dict_get(srv_config, "dbglevel");
|
||||||
|
|
||||||
if (host == NULL || prefix == NULL)
|
if (host == NULL || prefix == NULL)
|
||||||
srv_log(xs_str_new("cannot get server data"));
|
error = xs_str_new("cannot get server data");
|
||||||
else {
|
else {
|
||||||
srv_baseurl = xs_fmt("https://%s%s", host, prefix);
|
srv_baseurl = xs_fmt("https://%s%s", host, prefix);
|
||||||
|
|
||||||
|
@ -52,7 +57,7 @@ int srv_open(char *basedir)
|
||||||
|
|
||||||
if ((dbglvl = getenv("DEBUG")) != NULL) {
|
if ((dbglvl = getenv("DEBUG")) != NULL) {
|
||||||
dbglevel = atoi(dbglvl);
|
dbglevel = atoi(dbglvl);
|
||||||
srv_log(xs_fmt("DEBUG level set to %d from environment", dbglevel));
|
error = xs_fmt("DEBUG level set to %d from environment", dbglevel);
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = 1;
|
ret = 1;
|
||||||
|
@ -60,6 +65,9 @@ int srv_open(char *basedir)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (ret == 0 && error != NULL)
|
||||||
|
srv_log(error);
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -144,7 +152,7 @@ d_char *user_list(void)
|
||||||
globbuf.gl_offs = 1;
|
globbuf.gl_offs = 1;
|
||||||
|
|
||||||
list = xs_list_new();
|
list = xs_list_new();
|
||||||
spec = xs_fmt("%s/user/*", srv_basedir); /**/
|
spec = xs_fmt("%s/user/" "*", srv_basedir);
|
||||||
|
|
||||||
if (glob(spec, 0, NULL, &globbuf) == 0) {
|
if (glob(spec, 0, NULL, &globbuf) == 0) {
|
||||||
int n;
|
int n;
|
||||||
|
@ -161,3 +169,94 @@ d_char *user_list(void)
|
||||||
return list;
|
return list;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
float mtime(char *fn)
|
||||||
|
/* returns the mtime of a file or directory, or 0.0 */
|
||||||
|
{
|
||||||
|
struct stat st;
|
||||||
|
float r = 0.0;
|
||||||
|
|
||||||
|
if (stat(fn, &st) != -1)
|
||||||
|
r = (float)st.st_mtim.tv_sec;
|
||||||
|
|
||||||
|
return r;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
d_char *_follower_fn(snac *snac, char *actor)
|
||||||
|
{
|
||||||
|
xs *md5 = xs_md5_hex(actor, strlen(actor));
|
||||||
|
return xs_fmt("%s/followers/%s.json", snac->basedir, md5);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
int follower_add(snac *snac, char *actor, char *msg)
|
||||||
|
/* adds a follower */
|
||||||
|
{
|
||||||
|
int ret = 201; /* created */
|
||||||
|
xs *fn = _follower_fn(snac, actor);
|
||||||
|
FILE *f;
|
||||||
|
|
||||||
|
if ((f = fopen(fn, "w")) != NULL) {
|
||||||
|
xs *j = xs_json_dumps_pp(msg, 4);
|
||||||
|
|
||||||
|
fwrite(j, 1, strlen(j), f);
|
||||||
|
fclose(f);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
ret = 500;
|
||||||
|
|
||||||
|
snac_debug(snac, 2, xs_fmt("follower_add %s %s", actor, fn));
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
int follower_del(snac *snac, char *actor)
|
||||||
|
/* deletes a follower */
|
||||||
|
{
|
||||||
|
xs *fn = _follower_fn(snac, actor);
|
||||||
|
|
||||||
|
unlink(fn);
|
||||||
|
|
||||||
|
snac_debug(snac, 2, xs_fmt("follower_del %s %s", actor, fn));
|
||||||
|
|
||||||
|
return 200;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
int follower_check(snac *snac, char *actor)
|
||||||
|
/* checks if someone is a follower */
|
||||||
|
{
|
||||||
|
xs *fn = _follower_fn(snac, actor);
|
||||||
|
|
||||||
|
return !!(mtime(fn) != 0.0);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
d_char *follower_list(snac *snac)
|
||||||
|
/* returns the list of followers */
|
||||||
|
{
|
||||||
|
d_char *list;
|
||||||
|
xs *spec;
|
||||||
|
glob_t globbuf;
|
||||||
|
|
||||||
|
list = xs_list_new();
|
||||||
|
spec = xs_fmt("%s/followers/" "*.json", snac->basedir);
|
||||||
|
|
||||||
|
if (glob(spec, 0, NULL, &globbuf) == 0) {
|
||||||
|
int n;
|
||||||
|
char *p;
|
||||||
|
|
||||||
|
for (n = 0; (p = globbuf.gl_pathv[n]) != NULL; n++) {
|
||||||
|
FILE *f;
|
||||||
|
|
||||||
|
if ((f = fopen(p, "r")) != NULL) {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
globfree(&globbuf);
|
||||||
|
|
||||||
|
return list;
|
||||||
|
}
|
||||||
|
|
11
main.c
11
main.c
|
@ -11,7 +11,7 @@ int main(int argc, char *argv[])
|
||||||
|
|
||||||
printf("%s\n", tid());
|
printf("%s\n", tid());
|
||||||
|
|
||||||
srv_open("/home/angel/lib/snac/comam.es");
|
srv_open("/home/angel/lib/snac/comam.es/");
|
||||||
|
|
||||||
user_open(&snac, "mike");
|
user_open(&snac, "mike");
|
||||||
snac_log(&snac, xs_str_new("ok"));
|
snac_log(&snac, xs_str_new("ok"));
|
||||||
|
@ -22,11 +22,10 @@ int main(int argc, char *argv[])
|
||||||
|
|
||||||
p = list;
|
p = list;
|
||||||
while (xs_list_iter(&p, &uid)) {
|
while (xs_list_iter(&p, &uid)) {
|
||||||
user_open(&snac, uid);
|
if (user_open(&snac, uid)) {
|
||||||
|
printf("%s (%s)\n", uid, xs_dict_get(snac.config, "name"));
|
||||||
printf("%s (%s)\n", uid, xs_dict_get(snac.config, "name"));
|
user_free(&snac);
|
||||||
|
}
|
||||||
user_free(&snac);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue