#include "tags.h"
#include "auth.h"
#include "subscription.h"
+#include "json.h"
#include "canned_responses.h"
#include "app.h"
#include "config.h"
return 1;
}
+void respond_yajl(yajl_gen g) {
+ const unsigned char *ybuf;
+ 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", content_len);
+ fwrite(ybuf, content_len, 1, stdout);
+}
void respond_for_range(struct blerg *b, uint64_t from, uint64_t to) {
const unsigned char *ybuf;
struct url_info info;
char *data;
+ if (!blerg_init())
+ exit(1);
+
if (cgi_init() != CGIERR_NONE)
exit(0);
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);
-
- printf("Content-type: application/json\r\n");
- printf("Content-length: %d\r\n\r\n", len);
- fwrite(ybuf, len, 1, stdout);
+ respond_yajl(g);
yajl_gen_free(g);
} else if (strncmp(path, "/create", 8) == 0) {
}
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();
} else {
respond_blergref_list(feedlist, recs);
}
- } else if (strncmp(path, "/feedinfo", 9) == 0) {
+ } else if (strncmp(path, "/status", 7) == 0) {
const char *username = cgi_getentrystr("username");
if (!check_auth(username))
exit(0);
- yajl_gen g = yajl_gen_alloc(&yajl_c, NULL);
- yajl_gen_map_open(g);
- if (path[9] == 0) {
- struct blerg *b = blerg_open(username);
- uint64_t subscription_mark = blerg_get_subscription_mark(b);
- blerg_close(b);
+ if (strncmp(request_method, "POST", 4) != 0) {
+ respond_405();
+ exit(0);
+ }
- yajl_gen_string(g, "new", 3);
- yajl_gen_integer(g, subscription_count_items(username) - subscription_mark);
- } else {
- yajl_gen_string(g, "subscribed", 10);
- ret = parse_url_info(path + 10, &info);
+ yajl_gen g;
+
+ if (path[7] == 0) { /* No username */
+ const char *clear = cgi_getentrystr("clear");
+
+ if (clear != NULL) {
+ struct blerg *b = blerg_open(username);
+ if (strncmp(clear, "feed", 4) == 0) {
+ blerg_set_subscription_mark(b);
+ } else if (strncmp(clear, "mentioned", 9) == 0) {
+ blerg_set_status(b, BLERGSTATUS_MENTIONED, 0);
+ }
+ blerg_close(b);
+ respond_JSON_Success();
+ } else {
+ g = yajl_gen_alloc(&yajl_c, NULL);
+ yajl_gen_map_open(g);
+
+ struct blerg *b = blerg_open(username);
+ uint64_t subscription_mark = blerg_get_subscription_mark(b);
+ int mentioned = blerg_get_status(b, BLERGSTATUS_MENTIONED);
+ blerg_close(b);
+
+ yajl_gen_string(g, (unsigned char *)"feed_new", 8);
+ yajl_gen_integer(g, subscription_count_items(username) - subscription_mark);
+
+ yajl_gen_string(g, (unsigned char *)"mentioned", 9);
+ yajl_gen_bool(g, mentioned);
+
+ yajl_gen_map_close(g);
+ respond_yajl(g);
+ yajl_gen_free(g);
+ }
+ } else { /* with username */
+ g = yajl_gen_alloc(&yajl_c, NULL);
+ yajl_gen_map_open(g);
+
+ yajl_gen_string(g, (unsigned char *)"subscribed", 10);
+ ret = parse_url_info(path + 8, &info);
if ((ret & URL_INFO_NAME) == 1) {
yajl_gen_bool(g, is_subscribed(username, info.name));
} else {
yajl_gen_bool(g, 0);
}
- }
- 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_map_close(g);
+ respond_yajl(g);
+ yajl_gen_free(g);
+ }
+ } else if (strncmp(path, "/passwd", 7) == 0) {
+ const char *username = cgi_getentrystr("username");
+ if (!check_auth(username))
+ exit(0);
- yajl_gen_free(g);
+ const char *password = cgi_getentrystr("password");
+ const char *new_password = cgi_getentrystr("new_password");
+ if (password == NULL || new_password == NULL) {
+ respond_JSON_Failure();
+ } else {
+ if (auth_check_password(username, password)) {
+ auth_set_password(username, new_password);
+ respond_JSON_Success();
+ } else {
+ respond_JSON_Failure();
+ }
+ }
} else {
respond_404();
exit(0);
}
cgi_quit();
+
+ return 0;
}