use upoll for event loop
[src/app-framework-binder.git] / src / session.h
index 6c0b1d8..0a61612 100644 (file)
  * See the License for the specific language governing permissions and
  * limitations under the License.
  */
+// User Client Session Context
 
-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);
+#pragma once
+
+struct AFB_clientCtx
+{
+       time_t expiration;    // expiration time of the token
+       int created;
+       unsigned refcount;
+       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
+};
+
+extern void ctxStoreInit (int nbSession, int timeout, const char *initok);
+
+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);