diff options
author | 2017-09-04 11:37:39 +0200 | |
---|---|---|
committer | 2017-09-07 09:43:13 +0200 | |
commit | 85bca06fe0ee2923421f013da3e9f53abbfff673 (patch) | |
tree | 9760887748d9250f90e5ad068413f0d4f913e015 /src/afb-xreq.c | |
parent | 91c12808e08fb30e58a3d2e008569933f409d6db (diff) |
Implement afb_req_has_permission
This new verb is available in bindings to check
whether the client identified by a request has
a given permission or not.
Change-Id: I5eaa0892d8260d26bd76f37123251c103c981e10
Signed-off-by: José Bollo <jose.bollo@iot.bzh>
Diffstat (limited to 'src/afb-xreq.c')
-rw-r--r-- | src/afb-xreq.c | 19 |
1 files changed, 17 insertions, 2 deletions
diff --git a/src/afb-xreq.c b/src/afb-xreq.c index 8c7a38d5..3535ce5c 100644 --- a/src/afb-xreq.c +++ b/src/afb-xreq.c @@ -448,6 +448,12 @@ static struct afb_stored_req *xreq_store_cb(void *closure) return closure; } +static int xreq_has_permission_cb(void*closure, const char *permission) +{ + struct afb_xreq *xreq = closure; + return afb_auth_has_permission(xreq, permission); +} + /******************************************************************************/ static struct json_object *xreq_hooked_json_cb(void *closure) @@ -627,6 +633,13 @@ static struct afb_stored_req *xreq_hooked_store_cb(void *closure) return r; } +static int xreq_hooked_has_permission_cb(void*closure, const char *permission) +{ + struct afb_xreq *xreq = closure; + int r = xreq_has_permission_cb(closure, permission); + return afb_hook_xreq_has_permission(xreq, permission, r); +} + /******************************************************************************/ const struct afb_req_itf xreq_itf = { @@ -648,7 +661,8 @@ const struct afb_req_itf xreq_itf = { .subcallsync = xreq_subcallsync_cb, .vverbose = xreq_vverbose_cb, .store = xreq_store_cb, - .subcall_req = xreq_subcall_req_cb + .subcall_req = xreq_subcall_req_cb, + .has_permission = xreq_has_permission_cb }; const struct afb_req_itf xreq_hooked_itf = { @@ -670,7 +684,8 @@ const struct afb_req_itf xreq_hooked_itf = { .subcallsync = xreq_hooked_subcallsync_cb, .vverbose = xreq_hooked_vverbose_cb, .store = xreq_hooked_store_cb, - .subcall_req = xreq_hooked_subcall_req_cb + .subcall_req = xreq_hooked_subcall_req_cb, + .has_permission = xreq_hooked_has_permission_cb }; /******************************************************************************/ |