X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=include%2Fsession.h;h=5b7e07bb143eaf8671b4f4255a51d55508024901;hb=f3b5215339f96df7fb3b5c7588d72bfde1c2ab6a;hp=edf9028bdc5befc027292413e51431c5dc4a56b0;hpb=ebf6aa36dd34c7dabdca48bd64dc6297f102ad1e;p=platform%2Fupstream%2Fconnman.git diff --git a/include/session.h b/include/session.h index edf9028..5b7e07b 100644 --- a/include/session.h +++ b/include/session.h @@ -33,30 +33,76 @@ 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 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_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 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); -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); + +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); + +const char *connman_session_get_owner(struct connman_session *session); #ifdef __cplusplus }