X-Git-Url: https://gerrit.automotivelinux.org/gerrit/gitweb?a=blobdiff_plain;f=src%2Fafbs-api.c;h=42ea75979b653533d535b4415c474a8eac7ac5dd;hb=d00571d3c5365f40e7ec2ec3ab0f636afa0db480;hp=40e89d02e33ae7eda77209e31b4b77a11a951fc1;hpb=c2bda43c447016a20ed061078b0dff3e64d09940;p=src%2Fapp-framework-binder.git diff --git a/src/afbs-api.c b/src/afbs-api.c index 40e89d02..42ea7597 100644 --- a/src/afbs-api.c +++ b/src/afbs-api.c @@ -19,40 +19,109 @@ #include "local-def.h" -STATIC json_object* pingAfbs (AFB_session *session, AFB_request *request) { - static pingcount=0; - json_object *response; - const char * argval; +// Dummy sample of Client Application Context +typedef struct { + int something; + void *whateveryouwant; +} MyClientApplicationHandle; + + +// Request Creation of new context if it does not exist +STATIC json_object* clientContextCreate (AFB_request *request) { + json_object *jresp; + int res; + char *token; + AFB_clientCtx *client=request->client; // get client context from request + + // check we do not already have a session + if ((client != NULL) && (client->handle != NULL)) { + request->errcode=MHD_HTTP_FORBIDDEN; + return (jsonNewMessage(AFB_FAIL, "Token exist use refresh")); + } + + // request a new client context token and check result + if (AFB_SUCCESS != ctxTokenCreate (request)) { + request->errcode=MHD_HTTP_UNAUTHORIZED; + jresp= jsonNewMessage(AFB_FAIL, "Token Session Not Activated [restart with --token=xxxx]"); + return (jresp); + } + + // add a client handle to session + client->handle = malloc (sizeof (MyClientApplicationHandle)); - argval=getQueryValue (request, "arg"); - if (argval == NULL) { - argval="No present in query"; - }; + // Send response to UI + jresp = json_object_new_object(); + json_object_object_add(jresp, "token", json_object_new_string (client->token)); + + return (jresp); +} + +// Renew an existing context +STATIC json_object* clientContextRefresh (AFB_request *request) { + json_object *jresp; + + // note: we do not need to parse the old token as clientContextRefresh doit for us + if (AFB_SUCCESS != ctxTokenRefresh (request)) { + request->errcode=MHD_HTTP_UNAUTHORIZED; + jresp= jsonNewMessage(AFB_FAIL, "Token Exchange Broken Refresh Refused"); + } else { + jresp = json_object_new_object(); + json_object_object_add(jresp, "token", json_object_new_string (request->client->token)); + } + + return (jresp); +} + + +// Verify a context is still valid +STATIC json_object* clientContextCheck (AFB_request *request) { - response = jsonNewMessage(AFB_SUCCESS, "Ping Application Framework %d [arg=%s]", pingcount++, argval); - if (verbose) fprintf(stderr, "%d: \n", pingcount); - return (response); -}; + json_object *jresp = json_object_new_object(); + + // add an error code to respond + if (AFB_SUCCESS != ctxTokenCheck (request)) { + request->errcode=MHD_HTTP_UNAUTHORIZED; + json_object_object_add(jresp, "isvalid", json_object_new_boolean (FALSE)); + } else { + json_object_object_add(jresp, "isvalid", json_object_new_boolean (TRUE)); + } + + return (jresp); +} + +// Close and Free context +STATIC json_object* clientContextReset (AFB_request *request) { + json_object *jresp; + + // note: we do not need to parse the old token as clientContextRefresh doit for us + if (AFB_SUCCESS != ctxTokenReset (request)) { + request->errcode=MHD_HTTP_UNAUTHORIZED; + jresp= jsonNewMessage(AFB_FAIL, "No Token Client Context [use --token=xxx]"); + } else { + jresp = json_object_new_object(); + json_object_object_add(jresp, "uuid", json_object_new_string (request->client->uuid)); + } + + return (jresp); +} STATIC AFB_restapi pluginApis[]= { - {"ping" , (AFB_apiCB)pingSample ,"Ping Service"}, - {"get-all" , (AFB_apiCB)pingAfbs ,"Ping Application Framework"}, - {"get-one" , (AFB_apiCB)pingSample ,"Verbose Mode"}, - {"start-one", (AFB_apiCB)pingSample ,"Verbose Mode"}, - {"stop-one" , (AFB_apiCB)pingSample ,"Verbose Mode"}, - {"probe-one", (AFB_apiCB)pingSample ,"Verbose Mode"}, - {"ctx-store", (AFB_apiCB)pingSample ,"Verbose Mode"}, - {"ctx-load" , (AFB_apiCB)pingSample ,"Verbose Mode"}, - {0,0,0} + {"ping" , (AFB_apiCB)apiPingTest ,"Ping Rest Test Service"}, + {"token-create" , (AFB_apiCB)clientContextCreate ,"Request Client Context Creation"}, + {"token-refresh" , (AFB_apiCB)clientContextRefresh,"Refresh Client Context Token"}, + {"token-check" , (AFB_apiCB)clientContextCheck ,"Check Client Context Token"}, + {"token-reset" , (AFB_apiCB)clientContextReset ,"Close Client Context and Free resources"}, + {NULL} }; -PUBLIC AFB_plugin *afsvRegister (AFB_session *session) { +PUBLIC AFB_plugin *afsvRegister () { AFB_plugin *plugin = malloc (sizeof (AFB_plugin)); - plugin->type = AFB_PLUGIN; + plugin->type = AFB_PLUGIN_JSON; plugin->info = "Application Framework Binder Service"; plugin->prefix= "afbs"; // url base plugin->apis = pluginApis; + plugin->handle= (void*) "What ever you want"; return (plugin); }; \ No newline at end of file