X-Git-Url: http://git.bytex64.net/?a=blobdiff_plain;f=cgi%2Fcgi_blerg.c;h=1bba24dff716d27d4ed05f5931b4bfa7f167c3ad;hb=b8df1ce6b0bb9bd51d46b8ad6dce195122126d5a;hp=99745138c447f784d1f6614c2cd7c56c8044e577;hpb=7d8ef1902ef3030991b50a9414116a0615ac49d9;p=blerg.git diff --git a/cgi/cgi_blerg.c b/cgi/cgi_blerg.c index 9974513..1bba24d 100644 --- a/cgi/cgi_blerg.c +++ b/cgi/cgi_blerg.c @@ -9,12 +9,28 @@ #include "database.h" #include "tags.h" #include "auth.h" +#include "subscription.h" #include "canned_responses.h" #include "app.h" #include "config.h" yajl_gen_config yajl_c = { 0, 0 }; +int check_auth(const char *username) { + if (username == NULL || username[0] == 0) { + respond_403(); + return 0; + } + + const char *given_token = cgi_getcookie("auth"); + if (!auth_check_token(username, given_token)) { + respond_403(); + return 0; + } + return 1; +} + + void respond_for_range(struct blerg *b, uint64_t from, uint64_t to) { const unsigned char *ybuf; unsigned int len; @@ -45,7 +61,7 @@ void respond_for_range(struct blerg *b, uint64_t from, uint64_t to) { yajl_gen_free(g); } -void respond_taglist(struct tag *results, int i) { +void respond_blergref_list(struct blergref * results, int i) { const unsigned char *ybuf; unsigned int len; struct blerg *b; @@ -110,17 +126,17 @@ int main(int argc, char *argv[]) { } ret = parse_url_info(path + 5, &info); - if ((ret & URL_INFO_AUTHOR) == 0) { + if ((ret & URL_INFO_NAME) == 0) { respond_404(); exit(0); } - if (!blerg_exists(info.author)) { + if (!blerg_exists(info.name)) { respond_404(); exit(0); } - struct blerg *b = blerg_open(info.author); + struct blerg *b = blerg_open(info.name); if ((ret & URL_INFO_RECORD) && (ret & URL_INFO_RECORD_TO)) { respond_for_range(b, info.record, info.record_to); @@ -157,25 +173,25 @@ int main(int argc, char *argv[]) { } ret = parse_url_info(path + 5, &info); - if ((ret & URL_INFO_AUTHOR) == 0) { + if ((ret & URL_INFO_NAME) == 0) { respond_404(); exit(0); } - if (info.author[0] == 'H') - info.author[0] = '#'; - if (!tag_exists(info.author)) { + if (info.name[0] == 'H') + info.name[0] = '#'; + if (!tag_exists(info.name)) { respond_404(); exit(0); } int recs = 50; - struct tag *taglist = tag_list(info.author, 0, &recs, -1); + struct blergref *taglist = tag_list(info.name, 0, &recs, -1); if (recs == 0) { respond_simple_data("[]", 2); } else { - respond_taglist(taglist, recs); + respond_blergref_list(taglist, recs); } } else if (strncmp(path, "/put", 4) == 0) { if (strcmp(request_method, "POST") != 0) { @@ -183,21 +199,17 @@ int main(int argc, char *argv[]) { exit(0); } + const char *username = cgi_getentrystr("username"); + if (!check_auth(username)) + exit(0); + if (path[4] == '/') { respond_404(); exit(0); } - const char *username = cgi_getentrystr("username"); const char *data = cgi_getentrystr("data"); - if (username == NULL || username[0] == 0 || - data == NULL || data[0] == 0) { - respond_JSON_Failure(); - exit(0); - } - - const char *given_token = cgi_getcookie("auth"); - if (!auth_check_token(username, given_token)) { + if (data == NULL || data[0] == 0) { respond_JSON_Failure(); exit(0); } @@ -227,17 +239,17 @@ int main(int argc, char *argv[]) { } ret = parse_url_info(path + 6, &info); - if ((ret & URL_INFO_AUTHOR) == 0) { + if ((ret & URL_INFO_NAME) == 0) { respond_404(); exit(0); } - if (!blerg_exists(info.author)) { + if (!blerg_exists(info.name)) { respond_404(); exit(0); } - struct blerg *b = blerg_open(info.author); + struct blerg *b = blerg_open(info.name); uint64_t record_count = blerg_get_record_count(b); blerg_close(b); @@ -312,19 +324,88 @@ int main(int argc, char *argv[]) { } const char *username = cgi_getentrystr("username"); - if (username == NULL || username[0] == 0) { - respond_JSON_Failure(); + if (!check_auth(username)) exit(0); + + auth_logout(username); + respond_JSON_Success(); + } else if (strncmp(path, "/subscribe", 11) == 0 || strncmp(path, "/unsubscribe", 13) == 0) { + + const char *username = cgi_getentrystr("username"); + if (!check_auth(username)) + exit(0); + + if (path[1] == 'u') { + if (path[12] != '/') { + respond_404(); + exit(0); + } + + ret = parse_url_info(path + 13, &info); + if ((ret & URL_INFO_NAME) == 0) { + respond_404(); + exit(0); + } + + subscription_remove(username, info.name); + } else { + if (path[10] != '/') { + respond_404(); + exit(0); + } + + ret = parse_url_info(path + 11, &info); + if ((ret & URL_INFO_NAME) == 0) { + respond_404(); + exit(0); + } + + subscription_add(username, info.name); } + respond_JSON_Success(); + } else if (strncmp(path, "/feed", 6) == 0) { + const char *username = cgi_getentrystr("username"); + if (!check_auth(username)) + exit(0); + int recs = 50; + struct blergref *feedlist = subscription_list(username, 0, &recs, -1); - const char *given_token = cgi_getcookie("auth"); - if (auth_check_token(username, given_token)) { - auth_logout(username); - respond_JSON_Success(); + if (recs == 0) { + respond_simple_data("[]", 2); } else { - respond_JSON_Failure(); + respond_blergref_list(feedlist, recs); + } + } else if (strncmp(path, "/feedinfo", 9) == 0) { + const char *username = cgi_getentrystr("username"); + if (!check_auth(username)) + exit(0); + + if (path[9] != '/') { + respond_404(); + exit(0); } + + ret = parse_url_info(path + 10, &info); + if ((ret & URL_INFO_NAME) == 0) { + respond_404(); + exit(0); + } + + yajl_gen g = yajl_gen_alloc(&yajl_c, NULL); + yajl_gen_map_open(g); + yajl_gen_string(g, "subscribed", 10); + yajl_gen_bool(g, is_subscribed(username, info.name)); + yajl_gen_map_close(g); + + const unsigned char *ybuf; + yajl_gen_get_buf(g, &ybuf, &len); + + printf("Content-type: application/json\r\n"); + printf("Content-length: %d\r\n\r\n", len); + fwrite(ybuf, len, 1, stdout); + + yajl_gen_free(g); } else { respond_404(); exit(0);