refactoring (in progress, tbf)
[src/app-framework-binder.git] / src / session.h
index 6c0b1d8..0862b37 100644 (file)
  * See the License for the specific language governing permissions and
  * limitations under the License.
  */
+// User Client Session Context
 
+struct AFB_clientCtx
+{
+  time_t timeStamp;     // last time token was refresh
+  int   restfull;       // client does not use cookie
+  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
+};
+typedef struct AFB_clientCtx AFB_clientCtx;
+
+/*
 extern AFB_error ctxTokenRefresh (AFB_clientCtx *clientCtx, AFB_request *request);
 extern AFB_error ctxTokenCreate (AFB_clientCtx *clientCtx, AFB_request *request);
 extern AFB_error ctxTokenCheck (AFB_clientCtx *clientCtx, AFB_request *request);
 extern AFB_error ctxTokenReset (AFB_clientCtx *clientCtx, AFB_request *request);
 extern AFB_clientCtx *ctxClientGet (AFB_request *request);
-extern void ctxStoreInit (int nbSession, int timeout, int apicount);
+*/
+extern void ctxStoreGarbage ();
+
+extern void ctxStoreInit (int nbSession, int timeout, int apicount, const char *initok);
+
+extern AFB_clientCtx *_ctxClientGet (const char *uuid);
+extern AFB_error _ctxClientDel (AFB_clientCtx *clientCtx);
+extern AFB_error _ctxTokenCheck (AFB_clientCtx *clientCtx, const char *token);
+extern AFB_error _ctxTokenNew (AFB_clientCtx *clientCtx);