*/
// User Client Session Context
-struct AFB_clientCtx
+#pragma once
+
+struct afb_context
{
- time_t timeStamp; // last time token was refresh
- void **contexts; // application specific context [one per plugin]]
- char uuid[37]; // long term authentication of remote client
- char token[37]; // short term authentication of remote client
+ void *context;
+ void (*free_context)(void*);
};
-typedef struct AFB_clientCtx AFB_clientCtx;
-extern void ctxStoreGarbage ();
+extern void *afb_context_get(struct afb_context *actx);
+extern void afb_context_set(struct afb_context *actx, void *context, void (*free_context)(void*));
+
+struct AFB_clientCtx
+{
+ time_t expiration; // expiration time of the token
+ int created;
+ unsigned refcount;
+ struct afb_context *contexts;
+ char uuid[37]; // long term authentication of remote client
+ char token[37]; // short term authentication of remote client
+};
-extern void ctxStoreInit (int nbSession, int timeout, int apicount, const char *initok);
+extern void ctxStoreInit (int max_session_count, int timeout, const char *initok, int context_count);
-extern AFB_clientCtx *ctxClientGet (const char *uuid);
-extern int ctxClientClose (AFB_clientCtx *clientCtx);
-extern int ctxTokenCheck (AFB_clientCtx *clientCtx, const char *token);
-extern int ctxTokenNew (AFB_clientCtx *clientCtx);
+extern struct AFB_clientCtx *ctxClientGetForUuid (const char *uuid);
+extern struct AFB_clientCtx *ctxClientGet(struct AFB_clientCtx *clientCtx);
+extern void ctxClientPut(struct AFB_clientCtx *clientCtx);
+extern void ctxClientClose (struct AFB_clientCtx *clientCtx);
+extern int ctxTokenCheck (struct AFB_clientCtx *clientCtx, const char *token);
+extern int ctxTokenCheckLen (struct AFB_clientCtx *clientCtx, const char *token, size_t length);
+extern void ctxTokenNew (struct AFB_clientCtx *clientCtx);