Propagate changes to CGI version
[blerg.git] / cgi / cgi_blerg.c
index c004a7d..1bba24d 100644 (file)
@@ -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;
@@ -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);
                }
@@ -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);