%3$s
\n" "%4$s
\n"; -const char http_error_icon[] = - " \n"; - - const char http_warning_doc[] = "%1$i
\n" "%2$s :)
\n" "%3$s
\n" "%4$s
\n"; -const char http_warning_icon[] = - " \n"; - - const char http_success_doc[] = "%1$i
\n" "%2$s :)
\n" "%3$s
\n" "%4$s
\n"; -const char http_success_icon[] = - " \n"; - - const char http_info_doc[] = "%1$i
\n" "%2$s :)
\n" "%3$s
\n" "%4$s
\n"; - -const char http_info_icon[] = - " \n"; diff --git a/src/lib/res.h b/src/lib/res.h index 1bac5bf..658613d 100644 --- a/src/lib/res.h +++ b/src/lib/res.h @@ -16,6 +16,22 @@ #define http_style_doc _binary_bin_res_style_txt_start #define http_style_doc_size ((unsigned int) (_binary_bin_res_style_txt_end - _binary_bin_res_style_txt_start) - 1) +#define http_icon_error _binary_bin_res_icon_error_txt_start +#define http_icon_error_size ((unsigned int) (_binary_bin_res_icon_error_txt_end - _binary_bin_res_icon_error_txt_start) - 1) +#define http_icon_info _binary_bin_res_icon_info_txt_start +#define http_icon_info_size ((unsigned int) (_binary_bin_res_icon_info_txt_end - _binary_bin_res_icon_info_txt_start) - 1) +#define http_icon_success _binary_bin_res_icon_success_txt_start +#define http_icon_success_size ((unsigned int) (_binary_bin_res_icon_success_txt_end - _binary_bin_res_icon_success_txt_start) - 1) +#define http_icon_warning _binary_bin_res_icon_warning_txt_start +#define http_icon_warning_size ((unsigned int) (_binary_bin_res_icon_warning_txt_end - _binary_bin_res_icon_warning_txt_start) - 1) + +typedef struct { + const char *name; + const char *type; + const char *content; + const unsigned int size; +} res_t; + extern const char _binary_bin_res_default_txt_start[]; extern const char _binary_bin_res_default_txt_end[]; @@ -25,4 +41,16 @@ extern const char _binary_bin_res_proxy_txt_end[]; extern const char _binary_bin_res_style_txt_start[]; extern const char _binary_bin_res_style_txt_end[]; +extern const char _binary_bin_res_icon_error_txt_start[]; +extern const char _binary_bin_res_icon_error_txt_end[]; + +extern const char _binary_bin_res_icon_info_txt_start[]; +extern const char _binary_bin_res_icon_info_txt_end[]; + +extern const char _binary_bin_res_icon_success_txt_start[]; +extern const char _binary_bin_res_icon_success_txt_end[]; + +extern const char _binary_bin_res_icon_warning_txt_start[]; +extern const char _binary_bin_res_icon_warning_txt_end[]; + #endif //SESIMOS_RES_H diff --git a/src/worker/request_handler.c b/src/worker/request_handler.c index 0a90031..cbcc23f 100644 --- a/src/worker/request_handler.c +++ b/src/worker/request_handler.c @@ -130,12 +130,28 @@ static int request_handler(client_ctx_t *ctx) { logger_set_prefix("[%s%*s%s]%s", BLD_STR, INET6_ADDRSTRLEN, ctx->req_host, CLR_STR, ctx->log_prefix); info(BLD_STR "%s %s", req->method, req->uri); - if (strcmp(req->uri, "/.sesimos/style.css") == 0 && (strcmp(req->method, "GET") == 0 || strcmp(req->method, "HEAD") == 0)) { - ctx->msg_buf = (char *) http_style_doc; - ctx->content_length = http_style_doc_size; - res->status= http_get_status(200); - http_add_header_field(&res->hdr, "Content-Type", "text/css; charset=UTF-8"); - http_add_header_field(&res->hdr, "Cache-Control", "public, max-age=3600"); + if (strncmp(req->uri, "/.sesimos/res/", 14) == 0 && (strcmp(req->method, "GET") == 0 || strcmp(req->method, "HEAD") == 0)) { + const res_t resources[] = { + {"style.css", "text/css; charset=UTF-8", http_style_doc, http_style_doc_size}, + {"icon-error.svg", "image/svg+xml; charset=UTF-8", http_icon_error, http_icon_error_size}, + {"icon-info.svg", "image/svg+xml; charset=UTF-8", http_icon_info, http_icon_info_size}, + {"icon-success.svg", "image/svg+xml; charset=UTF-8", http_icon_success, http_icon_success_size}, + {"icon-warning.svg", "image/svg+xml; charset=UTF-8", http_icon_warning, http_icon_warning_size}, + }; + + res->status = http_get_status(404); + for (int i = 0; i < sizeof(resources) / sizeof(res_t); i++) { + const res_t *r = &resources[i]; + if (strcmp(req->uri + 14, r->name) == 0) { + res->status = http_get_status(200); + http_add_header_field(&res->hdr, "Content-Type", r->type); + http_add_header_field(&res->hdr, "Cache-Control", "public, max-age=86400"); + ctx->msg_buf = (char *) r->content; + ctx->content_length = r->size; + break; + } + } + return 0; }