X-Git-Url: https://gerrit.automotivelinux.org/gerrit/gitweb?a=blobdiff_plain;f=src%2Fafb-hswitch.c;h=8132f2324d43f9251af901bbe3a529c48e4d8468;hb=7ffecab08bf91e26ffedb393d9b8cb6151e2b836;hp=3fcd77de601d7d1db68ac8a2a4eedb5fcb8fcbc4;hpb=83ce3b29a598141f8f28afde655beb07ec78c312;p=src%2Fapp-framework-binder.git diff --git a/src/afb-hswitch.c b/src/afb-hswitch.c index 3fcd77de..8132f232 100644 --- a/src/afb-hswitch.c +++ b/src/afb-hswitch.c @@ -1,5 +1,5 @@ -/* - * Copyright (C) 2015 "IoT.bzh" +/* + * Copyright (C) 2015, 2016, 2017 "IoT.bzh" * Author "Fulup Ar Foll" * Author José Bollo * @@ -21,17 +21,19 @@ #include #include -#include "afb-req-itf.h" +#include + +#include "afb-context.h" #include "afb-hreq.h" -#include "afb-apis.h" -#include "session.h" +#include "afb-apiset.h" +#include "afb-session.h" #include "afb-websock.h" int afb_hswitch_apis(struct afb_hreq *hreq, void *data) { const char *api, *verb; size_t lenapi, lenverb; - struct AFB_clientCtx *context; + struct afb_apiset *apiset = data; api = &hreq->tail[strspn(hreq->tail, "/")]; lenapi = strcspn(api, "/"); @@ -42,8 +44,7 @@ int afb_hswitch_apis(struct afb_hreq *hreq, void *data) if (!(*api && *verb && lenapi && lenverb)) return 0; - context = afb_hreq_context(hreq); - afb_apis_call(afb_hreq_to_req(hreq), context, api, lenapi, verb, lenverb); + afb_hreq_call(hreq, apiset, api, lenapi, verb, lenverb); return 1; } @@ -69,24 +70,28 @@ int afb_hswitch_one_page_api_redirect(struct afb_hreq *hreq, void *data) url[plen++] = '#'; url[plen++] = '!'; memcpy(&url[plen], &hreq->tail[1], hreq->lentail); - return afb_hreq_redirect_to(hreq, url); + afb_hreq_redirect_to(hreq, url, 1); + return 1; } int afb_hswitch_websocket_switch(struct afb_hreq *hreq, void *data) { - int later; + struct afb_apiset *apiset = data; - afb_hreq_context(hreq); - if (hreq->lentail != 0 || !afb_websock_check(hreq, &later)) + if (hreq->lentail != 0) return 0; - if (!later) { - struct afb_websock *ws = afb_websock_create(hreq); - if (ws != NULL) - hreq->upgrade = 1; + if (afb_hreq_init_context(hreq) < 0) { + afb_hreq_reply_error(hreq, MHD_HTTP_INTERNAL_SERVER_ERROR); + return 1; } - return 1; -} + if (!hreq->xreq.context.validated) { + afb_hreq_reply_error(hreq, MHD_HTTP_UNAUTHORIZED); + return 1; + } + + return afb_websock_check_upgrade(hreq, apiset); +}