Code Review
/
src
/
app-framework-binder.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
review
|
tree
raw
|
inline
| side by side
add test files for Angular.js (not finished)
[src/app-framework-binder.git]
/
src
/
session.h
diff --git
a/src/session.h
b/src/session.h
index
569af65
..
f6d67fe
100644
(file)
--- a/
src/session.h
+++ b/
src/session.h
@@
-14,10
+14,11
@@
* See the License for the specific language governing permissions and
* limitations under the License.
*/
* See the License for the specific language governing permissions and
* limitations under the License.
*/
-// User Client Session Context
#pragma once
#pragma once
+struct json_object;
+
struct afb_context
{
void *context;
struct afb_context
{
void *context;
@@
-27,14
+28,28
@@
struct afb_context
extern void *afb_context_get(struct afb_context *actx);
extern void afb_context_set(struct afb_context *actx, void *context, void (*free_context)(void*));
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_event_listener_itf
+{
+ void (*send)(void *closure, const char *event, struct json_object *object);
+};
+
+struct afb_event_listener
+{
+ const struct afb_event_listener_itf *itf;
+ void *closure;
+};
+
+struct afb_event_listener_list;
+
struct AFB_clientCtx
{
struct AFB_clientCtx
{
- time_t expiration; // expiration time of the token
int created;
unsigned refcount;
int created;
unsigned refcount;
+ time_t expiration; // expiration time of the token
struct afb_context *contexts;
char uuid[37]; // long term authentication of remote client
char token[37]; // short term authentication of remote client
struct afb_context *contexts;
char uuid[37]; // long term authentication of remote client
char token[37]; // short term authentication of remote client
+ struct afb_event_listener_list *listeners;
};
extern void ctxStoreInit (int max_session_count, int timeout, const char *initok, int context_count);
};
extern void ctxStoreInit (int max_session_count, int timeout, const char *initok, int context_count);
@@
-43,6
+58,11
@@
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 struct AFB_clientCtx *ctxClientGet(struct AFB_clientCtx *clientCtx);
extern void ctxClientPut(struct AFB_clientCtx *clientCtx);
extern void ctxClientClose (struct AFB_clientCtx *clientCtx);
+
+extern int ctxClientEventListenerAdd(struct AFB_clientCtx *clientCtx, struct afb_event_listener listener);
+extern void ctxClientEventListenerRemove(struct AFB_clientCtx *clientCtx, struct afb_event_listener listener);
+extern int ctxClientEventSend(struct AFB_clientCtx *clientCtx, const char *event, struct json_object *object);
+
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);
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);