*/
#include <stdio.h>
+#include <stdlib.h>
#include <string.h>
+#include <glib.h>
#include <json/json.h>
-#include "phttp.h"
-#include "ttrss.h"
+#include "http.h"
+#include "io.h"
+#include "log.h"
+#include "ttrss_wsasync.h"
#include "url.h"
-static char *session_id;
-static char *session_url;
+static struct feed **data;
+static char *cache_dir;
-static struct json_object *create_op(const char *op)
+static const char *get_cache_dir()
{
- struct json_object *j;
+ char *home;
- j = json_object_new_object();
- json_object_object_add(j, "op", json_object_new_string(op));
+ if (!cache_dir) {
+ home = getenv("HOME");
- if (session_id && strcmp(op, "login"))
- json_object_object_add(j,
- "sid",
- json_object_new_string(session_id));
+ if (!home)
+ return NULL;
- return j;
-}
-
-void ttrss_login(const char *url, const char *user, const char *password)
-{
- struct json_object *content, *rp, *error, *sid, *rq;
- char *tmp;
-
- if (session_url)
- free(session_url);
-
- tmp = url_normalize(url);
- session_url = malloc(strlen(tmp) + strlen("/api/") + 1);
- strcpy(session_url, tmp);
- strcat(session_url, "/api/");
- free(tmp);
-
-
- rq = create_op("login");
- json_object_object_add(rq, "user", json_object_new_string(user));
- json_object_object_add(rq,
- "password",
- json_object_new_string(password));
-
- rp = post_json_object(session_url, rq);
- json_object_put(rq);
-
- content = json_object_object_get(rp, "content");
- if (!content) {
- fprintf(stderr, "Login failed: no content");
- return ;
+ cache_dir = path_append(home, ".prss/cache");
+ mkdirs(cache_dir, 0777);
}
- error = json_object_object_get(content, "error");
- if (error) {
- fprintf(stderr, "Login failed");
- return ;
- }
+ return cache_dir;
+}
- sid = json_object_object_get(content, "session_id");
+static void file_set_content(const char *path, const char *content)
+{
+ FILE *fp;
- if (session_id) {
- free(session_id);
- session_id = NULL;
+ fp = fopen(path, "w");
+ if (fp) {
+ fwrite(content, 1, strlen(content), fp);
+ fclose(fp);
}
-
- session_id = strdup(json_object_get_string(sid));
-
- printf("Session id: %s\n", session_id);
-
- json_object_put(rp);
}
-static struct headline **get_headlines(int feed_id)
+char *ttrss_get_headline_content(struct headline *h)
{
- struct json_object *rp, *rq, *content, *jheadline, *j;
- int i, n;
- struct headline **headlines, *h;
-
- printf("get_headlines %d\n", feed_id);
-
- rq = create_op("getHeadlines");
- json_object_object_add(rq, "feed_id", json_object_new_int(feed_id));
- json_object_object_add(rq, "show_excerpt", json_object_new_boolean(1));
- json_object_object_add(rq, "show_content", json_object_new_boolean(1));
-
- rp = post_json_object(session_url, rq);
-
- json_object_put(rq);
+ const char *cache_dir;
+ char *path, *content;
- content = json_object_object_get(rp, "content");
+ cache_dir = get_cache_dir();
+ if (cache_dir) {
+ path = g_strdup_printf("%s/%d", cache_dir, h->id);
- if (content) {
- n = json_object_array_length(content);
- headlines = malloc((n+1)*sizeof(struct headline *));
- for (i = 0; i < n; i++) {
- jheadline = json_object_array_get_idx(content, i);
+ content = file_get_content(path);
- h = malloc(sizeof(struct headline));
-
- j = json_object_object_get(jheadline, "title");
- h->title = strdup(json_object_get_string(j));
-
- j = json_object_object_get(jheadline, "excerpt");
- h->excerpt = strdup(json_object_get_string(j));
-
- j = json_object_object_get(jheadline, "content");
- h->content = strdup(json_object_get_string(j));
-
- j = json_object_object_get(jheadline, "unread");
- h->unread = json_object_get_boolean(j);
-
- headlines[i] = h;
+ if (!content) {
+ content = ws_get_article_content(h->id);
+ file_set_content(path, content);
}
- headlines[n] = NULL;
- } else {
- headlines = NULL;
- }
- json_object_put(rp);
+ g_free(path);
- printf("get_headlines %d end\n", feed_id);
+ return content;
+ }
- return headlines;
+ return NULL;
}
struct feed **ttrss_get_feeds()
{
- struct json_object *rp, *rq, *content, *jfeed, *j;
- int i, n;
- struct feed **feeds, *feed;
-
- printf("ttrss_get_feeds\n");
-
- rq = create_op("getFeeds");
-
- rp = post_json_object(session_url, rq);
- json_object_put(rq);
-
- content = json_object_object_get(rp, "content");
-
- if (content) {
- n = json_object_array_length(content);
+ data = ws_update_feeds(data);
- feeds = malloc((n+1) * sizeof(struct feed *));
- for (i = 0; i < n; i++) {
- jfeed = json_object_array_get_idx(content, i);
-
- feed = malloc(sizeof(struct feed));
-
- j = json_object_object_get(jfeed, "title");
- feed->title = strdup(json_object_get_string(j));
-
- j = json_object_object_get(jfeed, "feed_url");
- feed->url = strdup(json_object_get_string(j));
-
- j = json_object_object_get(jfeed, "id");
- feed->id = json_object_get_int(j);
+ return data;
+}
- j = json_object_object_get(jfeed, "unread");
- feed->unread = json_object_get_int(j);
+struct headline **ttrss_feed_get_headlines(struct feed *f)
+{
+ if (!f->headlines)
+ ws_update_headlines(f);
- feed->headlines = NULL;
+ return f->headlines;
+}
- feeds[i] = feed;
- }
- feeds[n] = NULL;
- } else {
- feeds = NULL;
- }
+void ttrss_set_article_unread(int id, int unread)
+{
+ log_debug("ttrss_set_article_unread(%d,%d)", id, unread);
- json_object_put(rp);
+ ws_async_set_article_unread(id, unread);
- printf("ttrss_get_feeds ended\n");
+ log_debug("ttrss_set_article_unread(%d,%d)", id, unread);
+}
- return feeds;
+void ttrss_set_config(const char *url, const char *user, const char *pwd)
+{
+ feeds_free(data);
+ data = NULL;
+ ws_set_config(url, user, pwd);
}
-struct headline **ttrss_get_headlines(struct feed *f)
+struct feed *ttrss_get_feed(int id)
{
- if (!f->headlines)
- f->headlines = get_headlines(f->id);
+ return feeds_get_feed(data, id);
+}
- return f->headlines;
+struct headline *ttrss_get_headline(int id)
+{
+ return feeds_get_headline(data, id);
}