* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
* 02110-1301 USA
*/
-
+#define _XOPEN_SOURCE_EXTENDED
#define _XOPEN_SOURCE
-#include <time.h>
-
-
#include <stdlib.h>
#include <stdio.h>
+#include <string.h>
+#include <time.h>
#include "lp_json.h"
#include "lp_ws.h"
-struct binary_package_publishing_history *
-json_object_to_binary_package_publishing_history(json_object *o)
+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;
+
+ 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;
+
+ str = time_to_str(t);
+
+ if (str)
+ return json_object_new_string(str);
+ else
+ return NULL;
+}
+
+static struct bpph *json_to_bpph(json_object *o)
{
const char *binary_package_name;
const char *binary_package_version;
const char *distro_arch_series_link;
const char *self_link;
- int architecture_specific;
+ 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,
+ status,
+ arch_specific,
+ date_created);
- return binary_package_publishing_history_new(binary_package_name,
- binary_package_version,
- distro_arch_series_link,
- self_link,
- architecture_specific);
+ return bpph;
+}
+
+static json_object *bpph_to_json(struct bpph *bpph)
+{
+ json_object *json;
+
+ json = json_object_new_object();
+
+ json_object_object_add
+ (json,
+ "binary_package_name",
+ json_object_new_string(bpph->binary_package_name));
+
+ json_object_object_add
+ (json,
+ "binary_package_version",
+ json_object_new_string(bpph->binary_package_version));
+
+ json_object_object_add
+ (json,
+ "distro_arch_series_link",
+ json_object_new_string(bpph->distro_arch_series_link));
+
+ json_object_object_add
+ (json, "self_link", json_object_new_string(bpph->self_link));
+
+ json_object_object_add
+ (json,
+ "architecture_specific",
+ json_object_new_boolean(bpph->architecture_specific));
+
+ json_object_object_add
+ (json, "status", json_object_new_string(bpph->status));
+
+ json_object_object_add
+ (json, "date_created", time_to_json(bpph->date_created));
+
+ return json;
}
struct distro_arch_series *json_object_to_distro_arch_series(json_object *o)
boolean is_nominated_arch_indep;
const char *distroseries_link;
-
display_name = json_object_get_string
(json_object_object_get(o, "display_name"));
displayname = json_object_get_string
(json_object_object_get(o, "displayname"));
- title = json_object_get_string
- (json_object_object_get(o, "title"));
+ title = json_object_get_string(json_object_object_get(o, "title"));
- version = json_object_get_string
- (json_object_object_get(o, "version"));
+ version = json_object_get_string(json_object_object_get(o, "version"));
- name = json_object_get_string
- (json_object_object_get(o, "name"));
+ name = json_object_get_string(json_object_object_get(o, "name"));
return distro_series_new(name,
version,
displayname);
}
-struct binary_package_publishing_history * *
-json_object_to_binary_package_publishing_history_list(json_object *o)
+struct bpph **json_object_to_bpph_list(json_object *o)
{
json_object *o_entries;
int i, n, i2;
- struct binary_package_publishing_history **entries;
- struct binary_package_publishing_history *h;
+ struct bpph **entries, *h;
const struct distro_arch_series *distro;
o_entries = json_object_object_get(o, "entries");
n = json_object_array_length(o_entries);
entries = malloc
- (sizeof(struct binary_package_publishing_history *)*(n+1));
+ (sizeof(struct bpph *)*(n+1));
for (i = 0, i2 = 0; i < n; i++) {
- h = json_object_to_binary_package_publishing_history
- (json_object_array_get_idx(o_entries, i));
+ h = json_to_bpph(json_object_array_get_idx(o_entries,
+ i));
if (!h->architecture_specific) {
distro = get_distro_arch_series
(h->distro_arch_series_link);
if (!distro || !distro->is_nominated_arch_indep) {
- binary_package_publishing_history_free(h);
+ bpph_free(h);
continue ;
}
}
return entries;
}
+json_object *bpph_list_to_json(struct bpph **list)
+{
+ json_object *result, *entries;
+ struct bpph **cur;
+
+ result = json_object_new_object();
+
+ entries = json_object_new_array();
+ json_object_object_add(result, "entries", entries);
+
+ if (list)
+ for (cur = list; *cur; cur++)
+ json_object_array_add(entries, bpph_to_json(*cur));
+
+ return result;
+}
+
struct daily_download_total *
json_object_to_daily_download_total(const char *d, json_object *o_c)
{