X-Git-Url: https://gerrit.automotivelinux.org/gerrit/gitweb?a=blobdiff_plain;f=plugins%2Fsession%2Ftoken-api.c;h=783e96ed11dc5348a6525180f5580ca2ee9b2c5d;hb=69b098942bd6c5b54d4849564407f9d20e598c06;hp=80289486a62feb0245e2b575f2ed9f0d33e36ee7;hpb=c7e9786d408f13d8f8f43c6b68da916bbb1ed5f3;p=src%2Fapp-framework-binder.git diff --git a/plugins/session/token-api.c b/plugins/session/token-api.c index 80289486..783e96ed 100644 --- a/plugins/session/token-api.c +++ b/plugins/session/token-api.c @@ -19,7 +19,7 @@ #include #include -#include "afb-plugin.h" +#include // Dummy sample of Client Application Context typedef struct { @@ -36,7 +36,7 @@ static void clientContextFree(void *context) { } // Request Creation of new context if it does not exist -static void clientContextCreate (struct afb_req request) +static void clientContextLogin (struct afb_req request) { json_object *jresp; @@ -48,6 +48,8 @@ static void clientContextCreate (struct afb_req request) json_object_object_add(jresp, "token", json_object_new_string ("A New Token and Session Context Was Created")); afb_req_success(request, jresp, NULL); + + afb_req_session_set_LOA(request, 1); } // Before entering here token will be check and renew @@ -73,7 +75,7 @@ static void clientContextCheck (struct afb_req request) { // Close and Free context -static void clientContextReset (struct afb_req request) { +static void clientContextLogout (struct afb_req request) { json_object *jresp; /* after this call token will be reset @@ -86,6 +88,8 @@ static void clientContextReset (struct afb_req request) { // WARNING: if you free context resource manually here do not forget to set *request.context=NULL; afb_req_success(request, jresp, NULL); + + afb_req_session_set_LOA(request, 0); } // Close and Free context static void clientGetPing (struct afb_req request) { @@ -99,23 +103,25 @@ static void clientGetPing (struct afb_req request) { } -static const struct AFB_restapi pluginApis[]= { - {"ping" , AFB_SESSION_NONE , clientGetPing ,"Ping Rest Test Service"}, - {"create" , AFB_SESSION_CREATE, clientContextCreate ,"Request Client Context Creation"}, - {"refresh" , AFB_SESSION_RENEW , clientContextRefresh,"Refresh Client Context Token"}, - {"check" , AFB_SESSION_CHECK , clientContextCheck ,"Check Client Context Token"}, - {"reset" , AFB_SESSION_CLOSE , clientContextReset ,"Close Client Context and Free resources"}, +static const struct AFB_verb_desc_v1 verbs[]= { + {"ping" , AFB_SESSION_NONE , clientGetPing ,"Ping Rest Test Service"}, + {"create" , AFB_SESSION_LOA_EQ_0 | AFB_SESSION_RENEW, clientContextLogin ,"Request Client Context Creation"}, + {"refresh" , AFB_SESSION_LOA_GE_1 | AFB_SESSION_RENEW, clientContextRefresh,"Refresh Client Context Token"}, + {"check" , AFB_SESSION_LOA_GE_1 , clientContextCheck ,"Check Client Context Token"}, + {"reset" , AFB_SESSION_LOA_GE_1 | AFB_SESSION_CLOSE, clientContextLogout ,"Close Client Context and Free resources"}, {NULL} }; static const struct AFB_plugin plugin_desc = { - .type = AFB_PLUGIN_JSON, - .info = "Application Framework Binder Service", - .prefix = "token", - .apis = pluginApis + .type = AFB_PLUGIN_VERSION_1, + .v1 = { + .info = "Application Framework Binder Service", + .prefix = "token", + .verbs = verbs + } }; -const struct AFB_plugin *pluginRegister (const struct AFB_interface *itf) +const struct AFB_plugin *pluginAfbV1Register (const struct AFB_interface *itf) { return &plugin_desc; }