refactoring
[src/app-framework-binder.git] / src / afb-hreq.c
index 19efd4b..f7f3bb1 100644 (file)
 
 #include "../include/local-def.h"
 #include "afb-method.h"
+#include "afb-req-itf.h"
 #include "afb-hreq.h"
 
-
 static char empty_string[1] = "";
 
+
 /* a valid subpath is a relative path not looking deeper than root using .. */
 static int validsubpath(const char *subpath)
 {
@@ -74,7 +75,7 @@ int afb_hreq_unprefix(struct afb_hreq *hreq, const char *prefix, size_t length)
 {
        /* check the prefix ? */
        if (length > hreq->lentail || (hreq->tail[length] && hreq->tail[length] != '/')
-           || memcmp(prefix, hreq->tail, length))
+           || strncasecmp(prefix, hreq->tail, length))
                return 0;
 
        /* removes successives / */
@@ -229,3 +230,23 @@ int afb_hreq_redirect_to(struct afb_hreq *hreq, const char *url)
        return 1;
 }
 
+const char *afb_hreq_get_cookie(struct afb_hreq *hreq, const char *name)
+{
+       return MHD_lookup_connection_value(hreq->connection, MHD_COOKIE_KIND, name);
+}
+
+const char *afb_hreq_get_argument(struct afb_hreq *hreq, const char *name)
+{
+       return MHD_lookup_connection_value(hreq->connection, MHD_GET_ARGUMENT_KIND, name);
+}
+
+const char *afb_hreq_get_header(struct afb_hreq *hreq, const char *name)
+{
+       return MHD_lookup_connection_value(hreq->connection, MHD_HEADER_KIND, name);
+}
+
+struct afb_req_itf afb_hreq_itf = {
+       .get_cookie = (void*)afb_hreq_get_cookie,
+       .get_argument = (void*)afb_hreq_get_argument
+};
+