Mercurial > sci
diff scid/page-jobresults.c @ 41:00b9af607524
scid: implement /jobresults/id page
author | David Demelier <markand@malikania.fr> |
---|---|
date | Tue, 09 Aug 2022 14:52:34 +0200 |
parents | |
children | 6854efe15210 |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/scid/page-jobresults.c Tue Aug 09 14:52:34 2022 +0200 @@ -0,0 +1,72 @@ +/* + * page-jobresults.c -- page /jobresults/<id> route + * + * Copyright (c) 2021-2022 David Demelier <markand@malikania.fr> + * + * Permission to use, copy, modify, and/or distribute this software for any + * purpose with or without fee is hereby granted, provided that the above + * copyright notice and this permission notice appear in all copies. + * + * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES + * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF + * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR + * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES + * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN + * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF + * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + */ + +#include <assert.h> +#include <stdio.h> + +#include "db.h" +#include "page-jobresults.h" +#include "pageutil.h" +#include "theme.h" +#include "util.h" + +static void +list(struct kreq *r, intmax_t id) +{ + json_t *results, *doc; + char *data; + + if (!(results = db_jobresult_list_by_job(id))) + pageutil_status(r, KHTTP_404); + else { + doc = util_json_pack("{sI so}", + "job_id", (json_int_t)id, + "jobresults", results + ); + data = theme_page_jobresults(doc); + pageutil_render(r, KHTTP_200, KMIME_TEXT_HTML, data); + json_decref(doc); + free(data); + } +} + +static void +get(struct kreq *r) +{ + intmax_t id; + + if (sscanf(r->fullpath, "/jobresults/%jd", &id) != 1) + pageutil_status(r, KHTTP_400); + else + list(r, id); +} + +void +page_jobresults(struct kreq *r) +{ + (void)r; + + switch (r->method) { + case KMETHOD_GET: + get(r); + break; + default: + pageutil_status(r, KHTTP_400); + break; + } +}