X-Git-Url: https://gerrit.automotivelinux.org/gerrit/gitweb?a=blobdiff_plain;f=src%2Fafb-hreq.h;h=3d7954a9d64acbf1c8988beca846cd3620523ac9;hb=677813c6a26eca5629ef8201fd0616511400a99e;hp=8fbc56347708fa11472c50454799ce1d0a9b3814;hpb=94014f46d4751492133f65b12f1dea1cfa36d021;p=src%2Fapp-framework-binder.git diff --git a/src/afb-hreq.h b/src/afb-hreq.h index 8fbc5634..3d7954a9 100644 --- a/src/afb-hreq.h +++ b/src/afb-hreq.h @@ -1,5 +1,5 @@ /* - * Copyright 2016 IoT.bzh + * Copyright (C) 2016 "IoT.bzh" * Author: José Bollo * * Licensed under the Apache License, Version 2.0 (the "License"); @@ -15,26 +15,43 @@ * limitations under the License. */ -struct AFB_session; +#pragma once + struct AFB_clientCtx; +struct json_object; +struct hreq_data; +struct afb_hsrv; +struct afb_req_itf; + +extern const struct afb_req_itf afb_hreq_req_itf; struct afb_hreq { + /* + * CAUTION: 'context' field should be the first because there + * is an implicit convertion to struct afb_context + */ + struct afb_context context; + int refcount; + struct afb_hsrv *hsrv; const char *cacheTimeout; struct MHD_Connection *connection; int method; + int reqid; + int scanned; + int suspended; + int replied; const char *version; + const char *lang; const char *url; size_t lenurl; const char *tail; size_t lentail; struct MHD_PostProcessor *postform; - struct AFB_clientCtx *context; struct hreq_data *data; + struct json_object *json; int upgrade; }; -extern void afb_hreq_free(struct afb_hreq *request); - extern int afb_hreq_unprefix(struct afb_hreq *request, const char *prefix, size_t length); extern int afb_hreq_valid_tail(struct afb_hreq *request); @@ -45,7 +62,9 @@ extern int afb_hreq_reply_file_if_exist(struct afb_hreq *request, int dirfd, con extern int afb_hreq_reply_file(struct afb_hreq *request, int dirfd, const char *filename); -extern int afb_hreq_redirect_to(struct afb_hreq *request, const char *url); +extern void afb_hreq_redirect_to(struct afb_hreq *request, const char *url, int add_query_part); + +extern int afb_hreq_redirect_to_ending_slash_if_needed(struct afb_hreq *hreq); extern const char *afb_hreq_get_cookie(struct afb_hreq *hreq, const char *name); @@ -59,11 +78,21 @@ extern int afb_hreq_post_add(struct afb_hreq *hreq, const char *name, const char extern struct afb_req afb_hreq_to_req(struct afb_hreq *hreq); -extern struct AFB_clientCtx *afb_hreq_context(struct afb_hreq *hreq); +extern int afb_hreq_init_context(struct afb_hreq *hreq); + +extern int afb_hreq_init_cookie(int port, const char *path, int maxage); + +extern void afb_hreq_reply_static(struct afb_hreq *hreq, unsigned status, size_t size, const char *buffer, ...); + +extern void afb_hreq_reply_copy(struct afb_hreq *hreq, unsigned status, size_t size, const char *buffer, ...); + +extern void afb_hreq_reply_free(struct afb_hreq *hreq, unsigned status, size_t size, char *buffer, ...); + +extern void afb_hreq_reply_empty(struct afb_hreq *hreq, unsigned status, ...); -extern int afb_hreq_one_page_api_redirect(struct afb_hreq *hreq, void *data); +extern int afb_hreq_init_download_path(const char *directory); -extern int afb_hreq_websocket_switch(struct afb_hreq *hreq, void *data); +extern void afb_hreq_addref(struct afb_hreq *hreq); -extern int afb_hreq_rest_api(struct afb_hreq *hreq, void *data); +extern void afb_hreq_unref(struct afb_hreq *hreq);