/*
- * Copyright (C) 2011-2012 jeanfi@gmail.com
+ * Copyright (C) 2011-2014 jeanfi@gmail.com
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License as
#include "lp_json.h"
#include "lp_ws.h"
+#include <ptime.h>
+
+static time_t json_to_time(json_object *json)
+{
+ const char *str;
+ struct tm tm;
+ char *ret;
+
+ str = json_object_get_string(json);
+ if (!str)
+ return -1;
+
+
+ memset(&tm, 0, sizeof(struct tm));
+ tm.tm_isdst = -1;
+ ret = strptime(str, "%FT%T", &tm);
+
+ if (ret)
+ return mktime(&tm);
+ else
+ return -1;
+}
+
+static json_object *time_to_json(time_t t)
+{
+ char *str;
+ json_object *j;
+
+ str = time_to_ISO8601_time(&t);
+
+ if (str) {
+ j = json_object_new_string(str);
+ free(str);
+ return j;
+ } else {
+ return NULL;
+ }
+}
static struct bpph *json_to_bpph(json_object *o)
{
const char *binary_package_version;
const char *distro_arch_series_link;
const char *self_link;
- int architecture_specific;
- const char *date_created;
+ int arch_specific;
struct bpph *bpph;
const char *status;
+ time_t date_created;
binary_package_name = json_object_get_string
(json_object_object_get(o, "binary_package_name"));
self_link = json_object_get_string
(json_object_object_get(o, "self_link"));
- if (json_object_get_boolean
- (json_object_object_get(o, "architecture_specific")))
- architecture_specific = 1;
- else
- architecture_specific = 0;
+ arch_specific = json_object_get_boolean
+ (json_object_object_get(o, "architecture_specific"));
+
+ date_created = json_to_time(json_object_object_get(o, "date_created"));
+
+ status = json_object_get_string(json_object_object_get(o, "status"));
bpph = bpph_new(binary_package_name,
binary_package_version,
distro_arch_series_link,
self_link,
- architecture_specific);
-
- date_created = json_object_get_string
- (json_object_object_get(o, "date_created"));
- if (date_created)
- strptime(date_created, "%FT%T", &bpph->date_created);
-
- status = json_object_get_string(json_object_object_get(o, "status"));
- if (status)
- bpph->status = strdup(status);
+ status,
+ arch_specific,
+ date_created);
return bpph;
}
static json_object *bpph_to_json(struct bpph *bpph)
{
- json_object *json;
- char *date;
+ json_object *json, *time;
json = json_object_new_object();
json_object_new_string(bpph->distro_arch_series_link));
json_object_object_add
- (json,
- "self_link",
- json_object_new_string(bpph->self_link));
+ (json, "self_link", json_object_new_string(bpph->self_link));
json_object_object_add
(json,
json_object_object_add
(json, "status", json_object_new_string(bpph->status));
- date = malloc(strlen("YY-MM-DDThh:mm:ss+xxx") + 1);
- strftime(date,
- strlen("YY-MM-DDThh:mm:ss+xxx") + 1,
- "%FT%T",
- &bpph->date_created);
-
+ time = time_to_json(bpph->date_created);
json_object_object_add
- (json, "date_created", json_object_new_string(date));
- free(date);
+ (json, "date_created", time);
return json;
}
const char *display_name;
const char *title;
const char *architecture_tag;
- boolean is_nominated_arch_indep;
+ json_bool is_nominated_arch_indep;
const char *distroseries_link;
display_name = json_object_get_string
result = malloc(sizeof(struct daily_download_total));
result->count = json_object_get_int(o_c);
+ memset(&result->date, 0, sizeof(struct tm));
strptime(d, "%FT%T%z", &result->date);
return result;
return result;
}
+
+struct json_object *date_to_json(struct tm *tm)
+{
+ json_object *json;
+
+ json = json_object_new_array();
+ json_object_array_add(json, json_object_new_int(tm->tm_year+1900));
+ json_object_array_add(json, json_object_new_int(tm->tm_mon+1));
+ json_object_array_add(json, json_object_new_int(tm->tm_mday));
+
+ return json;
+}
+
+json_object *ddts_to_json(struct daily_download_total **ddts)
+{
+ json_object *json_ddt, *json_ddts;
+ struct daily_download_total *ddt;
+
+ json_ddts = json_object_new_array();
+
+ while (ddts && *ddts) {
+ ddt = *ddts;
+
+ json_ddt = json_object_new_object();
+ json_object_object_add(json_ddt,
+ "value",
+ json_object_new_int(ddt->count));
+ json_object_object_add(json_ddt,
+ "time",
+ date_to_json(&ddt->date));
+
+ json_object_array_add(json_ddts, json_ddt);
+
+ ddts++;
+ }
+
+ return json_ddts;
+}