session: Export session parsing functions
[platform/upstream/connman.git] / include / session.h
index 3c6e6ff..a422952 100644 (file)
@@ -22,6 +22,7 @@
 #ifndef __CONNMAN_SESSION_H
 #define __CONNMAN_SESSION_H
 
+#include <connman/service.h>
 #include <connman/types.h>
 
 #ifdef __cplusplus
@@ -32,24 +33,58 @@ extern "C" {
 #define CONNMAN_SESSION_POLICY_PRIORITY_DEFAULT     0
 #define CONNMAN_SESSION_POLICY_PRIORITY_HIGH      100
 
+enum connman_session_roaming_policy {
+       CONNMAN_SESSION_ROAMING_POLICY_UNKNOWN          = 0,
+       CONNMAN_SESSION_ROAMING_POLICY_DEFAULT          = 1,
+       CONNMAN_SESSION_ROAMING_POLICY_ALWAYS           = 2,
+       CONNMAN_SESSION_ROAMING_POLICY_FORBIDDEN        = 3,
+       CONNMAN_SESSION_ROAMING_POLICY_NATIONAL         = 4,
+       CONNMAN_SESSION_ROAMING_POLICY_INTERNATIONAL    = 5,
+};
+
+enum connman_session_type {
+       CONNMAN_SESSION_TYPE_UNKNOWN  = 0,
+       CONNMAN_SESSION_TYPE_ANY      = 1,
+       CONNMAN_SESSION_TYPE_LOCAL    = 2,
+       CONNMAN_SESSION_TYPE_INTERNET = 3,
+};
+
 struct connman_session;
 
+struct connman_session_config {
+       connman_bool_t priority;
+       enum connman_session_roaming_policy roaming_policy;
+       enum connman_session_type type;
+       connman_bool_t ecall;
+       GSList *allowed_bearers;
+};
+
+typedef void (* connman_session_config_cb) (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_cb callback,
+                       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);
 
-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);
+int connman_session_config_update(struct connman_session *session);
+void connman_session_destroy(struct connman_session *session);
+
+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);
+
+const char *connman_session_get_owner(struct connman_session *session);
 
 #ifdef __cplusplus
 }