session: Add session identification method to config
[platform/upstream/connman.git] / include / session.h
index 2f5c80b..61cc264 100644 (file)
@@ -43,20 +43,41 @@ enum connman_session_roaming_policy {
 };
 
 enum connman_session_type {
-       CONNMAN_SESSION_TYPE_ANY      = 0,
-       CONNMAN_SESSION_TYPE_LOCAL    = 1,
-       CONNMAN_SESSION_TYPE_INTERNET = 2,
+       CONNMAN_SESSION_TYPE_UNKNOWN  = 0,
+       CONNMAN_SESSION_TYPE_ANY      = 1,
+       CONNMAN_SESSION_TYPE_LOCAL    = 2,
+       CONNMAN_SESSION_TYPE_INTERNET = 3,
 };
 
-struct connman_session;
+enum connman_session_id_type {
+       CONNMAN_SESSION_ID_TYPE_UNKNOWN = 0,
+       CONNMAN_SESSION_ID_TYPE_UID     = 1,
+       CONNMAN_SESSION_ID_TYPE_GID     = 2,
+       CONNMAN_SESSION_ID_TYPE_LSM     = 3,
+};
 
-struct connman_session_bearer {
-       char *name;
-       connman_bool_t match_all;
-       enum connman_service_type service_type;
+struct cb_data {
+       void *cb;
+       void *user_data;
+       void *data;
 };
 
+static inline struct cb_data *cb_data_new(void *cb, void *user_data)
+{
+       struct cb_data *ret;
+
+       ret = g_new0(struct cb_data, 1);
+       ret->cb = cb;
+       ret->user_data = user_data;
+
+       return ret;
+}
+
+struct connman_session;
+
 struct connman_session_config {
+       enum connman_session_id_type id_type;
+       char *id;
        connman_bool_t priority;
        enum connman_session_roaming_policy roaming_policy;
        enum connman_session_type type;
@@ -64,24 +85,33 @@ struct connman_session_config {
        GSList *allowed_bearers;
 };
 
+typedef int (* connman_session_config_func_t) (struct connman_session *session,
+                                       struct connman_session_config *config,
+                                       void *user_data, int err);
+
 struct connman_session_policy {
        const char *name;
        int priority;
-       int (*get_bool) (struct connman_session *session,
-                               const char *key, connman_bool_t *val);
-       int (*get_string) (struct connman_session *session,
-                               const char *key, char **val);
+       int (*create)(struct connman_session *session,
+                       connman_session_config_func_t cb,
+                       void *user_data);
+       void (*destroy)(struct connman_session *session);
 };
 
 int connman_session_policy_register(struct connman_session_policy *config);
 void connman_session_policy_unregister(struct connman_session_policy *config);
 
-GSList *connman_session_allowed_bearers_any(void);
+int connman_session_config_update(struct connman_session *session);
+void connman_session_destroy(struct connman_session *session);
+
+void connman_session_set_default_config(struct connman_session_config *config);
+struct connman_session_config *connman_session_create_default_config(void);
+
+enum connman_session_roaming_policy connman_session_parse_roaming_policy(const char *policy);
+enum connman_session_type connman_session_parse_connection_type(const char *type);
+int connman_session_parse_bearers(const char *token, GSList **list);
 
-int connman_session_update_bool(struct connman_session *session, const char *key,
-                               connman_bool_t val);
-int connman_session_update_string(struct connman_session *session, const char *key,
-                                       const char *val);
+const char *connman_session_get_owner(struct connman_session *session);
 
 #ifdef __cplusplus
 }