X-Git-Url: https://gerrit.automotivelinux.org/gerrit/gitweb?a=blobdiff_plain;f=src%2Fafb-hreq.h;h=772cd677b3b9948b26b04e426c37d3eb001be5c6;hb=c94e1ef88adc641ebbab57377b97f8a7b6a70d1b;hp=41f499d08bd35c41873c4e7e26c6867a6c454894;hpb=56f9ef4581d567248b6f83a3b15f39a0aca42895;p=src%2Fapp-framework-binder.git diff --git a/src/afb-hreq.h b/src/afb-hreq.h index 41f499d0..772cd677 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,28 +15,42 @@ * 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 *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); @@ -47,7 +61,7 @@ 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 int afb_hreq_redirect_to(struct afb_hreq *request, const char *url, int add_query_part); extern const char *afb_hreq_get_cookie(struct afb_hreq *hreq, const char *name); @@ -61,6 +75,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_init_download_path(const char *directory); + +extern void afb_hreq_addref(struct afb_hreq *hreq); +extern void afb_hreq_unref(struct afb_hreq *hreq);