Check for success on user creation
[blerg.git] / cgi / cgi_blerg.c
index 7e5c7df..becaa96 100644 (file)
@@ -10,6 +10,7 @@
 #include "tags.h"
 #include "auth.h"
 #include "subscription.h"
+#include "json.h"
 #include "canned_responses.h"
 #include "app.h"
 #include "config.h"
@@ -100,6 +101,9 @@ int main(int argc, char *argv[]) {
        struct url_info info;
        char *data;
 
+       if (!blerg_init())
+               exit(1);
+
        if (cgi_init() != CGIERR_NONE)
                exit(0);
 
@@ -256,17 +260,18 @@ int main(int argc, char *argv[]) {
                char number[21];
                yajl_gen g = yajl_gen_alloc(&yajl_c, NULL);
                yajl_gen_map_open(g);
-               yajl_gen_string(g, "record_count", 12);
+               yajl_gen_string(g, (unsigned char *)"record_count", 12);
                snprintf(number, 21, "%llu", record_count);
-               yajl_gen_string(g, number, strlen(number));
+               yajl_gen_string(g, (unsigned char *)number, strlen(number));
                yajl_gen_map_close(g);
 
                const unsigned char *ybuf;
-               yajl_gen_get_buf(g, &ybuf, &len);
+               unsigned int content_len;
+               yajl_gen_get_buf(g, &ybuf, &content_len);
 
                printf("Content-type: application/json\r\n");
-               printf("Content-length: %d\r\n\r\n", len);
-               fwrite(ybuf, len, 1, stdout);
+               printf("Content-length: %d\r\n\r\n", content_len);
+               fwrite(ybuf, content_len, 1, stdout);
 
                yajl_gen_free(g);
        } else if (strncmp(path, "/create", 8) == 0) {
@@ -289,10 +294,14 @@ int main(int argc, char *argv[]) {
                }
 
                struct blerg *b = blerg_open(username);
-               blerg_close(b);
-               auth_set_password(username, password);
-               
-               respond_JSON_Success();
+               if (b != NULL) {
+                       blerg_close(b);
+                       auth_set_password(username, password);
+                       
+                       respond_JSON_Success();
+               } else {
+                       respond_JSON_Failure();
+               }
        } else if (strncmp(path, "/login", 7) == 0) {
                if (strcmp(request_method, "POST") != 0) {
                        respond_405();
@@ -392,10 +401,10 @@ int main(int argc, char *argv[]) {
                        uint64_t subscription_mark = blerg_get_subscription_mark(b);
                        blerg_close(b);
 
-                       yajl_gen_string(g, "new", 3);
+                       yajl_gen_string(g, (unsigned char *)"new", 3);
                        yajl_gen_integer(g, subscription_count_items(username) - subscription_mark);
                } else {
-                       yajl_gen_string(g, "subscribed", 10);
+                       yajl_gen_string(g, (unsigned char *)"subscribed", 10);
                        ret = parse_url_info(path + 10, &info);
                        if ((ret & URL_INFO_NAME) == 1) {
                                yajl_gen_bool(g, is_subscribed(username, info.name));
@@ -406,11 +415,12 @@ int main(int argc, char *argv[]) {
                yajl_gen_map_close(g);
 
                const unsigned char *ybuf;
-               yajl_gen_get_buf(g, &ybuf, &len);
+               unsigned int content_len;
+               yajl_gen_get_buf(g, &ybuf, &content_len);
 
                printf("Content-type: application/json\r\n");
-               printf("Content-length: %d\r\n\r\n", len);
-               fwrite(ybuf, len, 1, stdout);
+               printf("Content-length: %d\r\n\r\n", content_len);
+               fwrite(ybuf, content_len, 1, stdout);
 
                yajl_gen_free(g);
        } else if (strncmp(path, "/passwd", 7) == 0) {