#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_bearer {
- char *name;
- connman_bool_t match_all;
- enum connman_service_type service_type;
+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);
+struct connman_session_config *connman_session_create_default_config(void);
#ifdef __cplusplus
}