diff options
author | Fulup Ar Foll <fulup@iot.bzh> | 2015-12-22 23:09:04 +0100 |
---|---|---|
committer | Fulup Ar Foll <fulup@iot.bzh> | 2015-12-22 23:09:04 +0100 |
commit | 00857f9da5ae802794a4cb94aca576b11bfe6628 (patch) | |
tree | fb17939c9488de74e345bd5cc68a94b8894b8968 /plugins/session/token-api.c | |
parent | 1398adf363c182f25603f7d0c1ff52c5be8267b2 (diff) |
New Session Model [compile but not tested]
Diffstat (limited to 'plugins/session/token-api.c')
-rw-r--r-- | plugins/session/token-api.c | 21 |
1 files changed, 11 insertions, 10 deletions
diff --git a/plugins/session/token-api.c b/plugins/session/token-api.c index 585c3432..0a5a2be4 100644 --- a/plugins/session/token-api.c +++ b/plugins/session/token-api.c @@ -31,7 +31,7 @@ STATIC json_object* clientContextCreate (AFB_request *request) { json_object *jresp; // add an application specific client context to session - request->client->ctx = malloc (sizeof (MyClientApplicationHandle)); + request->context = malloc (sizeof (MyClientApplicationHandle)); // Send response to UI jresp = json_object_new_object(); @@ -66,23 +66,24 @@ STATIC json_object* clientContextCheck (AFB_request *request) { STATIC json_object* clientContextReset (AFB_request *request) { json_object *jresp; + /* after this call token will be reset + * - no further access to API will be possible + * - every context from any used plugin will be freed + */ + jresp = json_object_new_object(); - json_object_object_add(jresp, "uuid", json_object_new_string (request->client->uuid)); + json_object_object_add(jresp, "info", json_object_new_string ("Token and all resources are released")); + // WARNING: if you free context resource manually here do not forget to set request->context=NULL; return (jresp); } -// In this case or handle is quite basic -typedef struct { - int fd; -} appPostCtx; - // This function is call when Client Session Context is removed // Note: when freeCtxCB==NULL standard free/malloc is called -STATIC void clientContextFree(AFB_clientCtx *client) { - fprintf (stderr,"Plugin[%s] Closing Session uuid=[%s]\n", client->plugin->prefix, client->uuid); - free (client->ctx); +STATIC void clientContextFree(void *context, char* uuid) { + fprintf (stderr,"Plugin[token] Closing Session uuid=[%s]\n", uuid); + free (context); } STATIC AFB_restapi pluginApis[]= { |