X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=include%2Fsession.h;h=39f3368554ed28217564c3990906e69c1630169d;hb=7e5e845e5fd4665b1a75985b198f727872937efb;hp=34ed25d2da28cd347d3005e00e0e3da40608153e;hpb=580921d2458dd24174d4cd4392e572112d24501f;p=platform%2Fupstream%2Fconnman.git diff --git a/include/session.h b/include/session.h old mode 100644 new mode 100755 index 34ed25d..39f3368 --- a/include/session.h +++ b/include/session.h @@ -2,7 +2,7 @@ * * Connection Manager * - * Copyright (C) 2012 BMW Car IT GbmH. All rights reserved. + * Copyright (C) 2012-2014 BMW Car IT GmbH. * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License version 2 as @@ -22,8 +22,8 @@ #ifndef __CONNMAN_SESSION_H #define __CONNMAN_SESSION_H +#include #include -#include #ifdef __cplusplus extern "C" { @@ -43,48 +43,80 @@ 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; +enum connman_session_state { + CONNMAN_SESSION_STATE_DISCONNECTED = 0, + CONNMAN_SESSION_STATE_CONNECTED = 1, + CONNMAN_SESSION_STATE_ONLINE = 2, }; +struct connman_session; + struct connman_session_config { - connman_bool_t priority; + enum connman_session_id_type id_type; + char *id; + bool priority; enum connman_session_roaming_policy roaming_policy; enum connman_session_type type; - connman_bool_t ecall; + bool ecall; GSList *allowed_bearers; + char *allowed_interface; + bool source_ip_rule; + char *context_identifier; }; +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); - struct connman_session_config *(*create)( - struct connman_session *session); + bool (*autoconnect)(enum connman_service_connect_reason reason); + int (*create)(struct connman_session *session, + connman_session_config_func_t cb, + void *user_data); void (*destroy)(struct connman_session *session); + void (*session_changed)(struct connman_session *session, bool active, + GSList *bearers); + bool (*allowed)(struct connman_session *session, + struct connman_service *service); + void (*update_session_state)(struct connman_session* session, + enum connman_session_state state); + struct connman_service* (*get_service_for_session)(struct connman_session* session, + GSList* services); }; +uint32_t connman_session_firewall_get_fwmark(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); + +const char *connman_session_get_owner(struct connman_session *session); -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_connect(struct connman_service *service); +int connman_session_disconnect(struct connman_service *service); #ifdef __cplusplus }