#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_UNAUTH == ctxTokenCreate (request)) {
+ request->errcode=MHD_HTTP_UNAUTHORIZED;
+ jresp= jsonNewMessage(AFB_FAIL, "No/Invalid initial token provided [should match --token=xxxx]");
+ return (jresp);
+ }
- argval=getQueryValue (request, "arg");
- if (argval == NULL) {
- argval="No present in query";
- };
+ // 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));
- response = jsonNewMessage(AFB_SUCCESS, "Ping Application Framework %d [arg=%s]", pingcount++, argval);
- if (verbose) fprintf(stderr, "%d: \n", pingcount);
- return (response);
-};
+ // 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) {
+
+ 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) {
- AFB_plugin plugin;
- plugin.type = AFB_PLUGIN;
- plugin.info = "Application Framework Binder Service";
- plugin.prefix= "afbs"; // url base
- plugin.apis = pluginApis;
+PUBLIC AFB_plugin *afsvRegister () {
+ AFB_plugin *plugin = malloc (sizeof (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);
+ return (plugin);
};
\ No newline at end of file