Add new API to check whether metered or non metered
[platform/core/api/connection.git] / include / net_connection_private.h
old mode 100644 (file)
new mode 100755 (executable)
index c77f537..797893f
@@ -34,19 +34,41 @@ extern "C" {
 #define CONNECTION_ERROR       2
 #define CONNECTION_WARN                3
 
-typedef enum
-{
-       FEATURE_TYPE_TELEPHONY = 0,
-       FEATURE_TYPE_WIFI = 1,
-       FEATURE_TYPE_TETHERING_BLUETOOTH = 2
-} enable_feature_type_e;
-
-typedef enum
-{
+#define CONNECTION_MAC_INFO_LENGTH     17
+#define ETHERNET_MAC_INFO_FILE         "/sys/class/net/eth0/address"
+#define WIFI_MAC_INFO_FILE                     "/sys/class/net/wlan0/address"
+
+#define TELEPHONY_FEATURE                      "http://tizen.org/feature/network.telephony"
+#define WIFI_FEATURE                           "http://tizen.org/feature/network.wifi"
+#define TETHERING_BLUETOOTH_FEATURE    "http://tizen.org/feature/network.tethering.bluetooth"
+#define ETHERNET_FEATURE                       "http://tizen.org/feature/network.ethernet"
+
+typedef enum {
        CONNECTION_CELLULAR_SUBSCRIBER_1 = 0x00,
        CONNECTION_CELLULAR_SUBSCRIBER_2 = 0x01,
 } connection_cellular_subscriber_id_e;
 
+typedef enum {
+       CONNECTION_SUPPORTED_FEATURE_TELEPHONY,
+       CONNECTION_SUPPORTED_FEATURE_WIFI,
+       CONNECTION_SUPPORTED_FEATURE_TETHERING_BLUETOOTH,
+       CONNECTION_SUPPORTED_FEATURE_ETHERNET,
+       CONNECTION_SUPPORTED_FEATURE_MAX,
+} connection_supported_feature_e;
+
+#define CHECK_FEATURE_SUPPORTED(...) \
+       do { \
+               int rv = _connection_check_feature_supported(__VA_ARGS__, NULL); \
+               if (rv != CONNECTION_ERROR_NONE) \
+                       return rv; \
+       } while (0)
+
+#define DEPRECATED_LOG(origin, substitution) \
+       do { \
+               LOGW("DEPRECATION WARNING: %s() is deprecated and will be removed " \
+                               "from next release. Use %s() instead", origin, substitution); \
+       } while (0)
+
 #define CONNECTION_LOG(log_level, format, args...) \
        do { \
                switch (log_level) { \
@@ -59,10 +81,7 @@ typedef enum
                default: \
                        LOGI(format, ## args); \
                } \
-       } while(0)
-
-#define CONNECTION_MUTEX_LOCK _connection_inter_mutex_lock()
-#define CONNECTION_MUTEX_UNLOCK _connection_inter_mutex_unlock()
+       } while (0)
 
 #define SECURE_CONNECTION_LOG(log_level, format, args...) \
        do { \
@@ -76,28 +95,35 @@ typedef enum
                default: \
                        SECURE_LOGI(format, ## args); \
                } \
-       } while(0)
+       } while (0)
 
 #define VCONF_TELEPHONY_DEFAULT_DATA_SERVICE \
                        "db/telephony/dualsim/default_data_service"
 
-bool _connection_is_created(void);
-
-typedef struct _connection_handle_s
-{
+typedef struct _connection_handle_s {
        connection_type_changed_cb type_changed_callback;
        connection_address_changed_cb ip_changed_callback;
        connection_address_changed_cb proxy_changed_callback;
-       void *state_changed_user_data;
+       connection_ethernet_cable_state_changed_cb ethernet_cable_state_changed_callback;
+       void *type_changed_user_data;
        void *ip_changed_user_data;
        void *proxy_changed_user_data;
+       void *ethernet_cable_state_changed_user_data;
 } connection_handle_s;
 
+typedef void(*libnet_ethernet_cable_state_changed_cb)
+               (connection_ethernet_cable_state_e state);
+
+bool _connection_is_created(void);
 
-bool _connection_libnet_init(void);
+int _connection_libnet_init(void);
 bool _connection_libnet_deinit(void);
+int _connection_libnet_get_metered_state(bool* is_metered);
 int _connection_libnet_get_wifi_state(connection_wifi_state_e *state);
 int _connection_libnet_get_ethernet_state(connection_ethernet_state_e *state);
+int _connection_libnet_get_ethernet_cable_state(connection_ethernet_cable_state_e* state);
+int _connection_libnet_set_ethernet_cable_state_changed_cb(
+                               libnet_ethernet_cable_state_changed_cb callback);
 int _connection_libnet_get_bluetooth_state(connection_bt_state_e* state);
 bool _connection_libnet_check_profile_validity(connection_profile_h profile);
 bool _connection_libnet_check_profile_cb_validity(connection_profile_h profile);
@@ -116,6 +142,10 @@ int _connection_libnet_set_cellular_service_profile_async(connection_cellular_se
 int _connection_libnet_close_profile(connection_profile_h profile, connection_closed_cb callback, void *user_data);
 int _connection_libnet_add_route(const char *interface_name, const char *host_address);
 int _connection_libnet_remove_route(const char *interface_name, const char *host_address);
+int _connection_libnet_add_route_ipv6(const char *interface_name, const char *host_address, const char * gateway);
+int _connection_libnet_remove_route_ipv6(const char *interface_name, const char *host_address, const char * gateway);
+int _connection_libnet_add_route_entry(connection_address_family_e address_family, const char *interface_name, const char *host_address, const char * gateway);
+int _connection_libnet_remove_route_entry(connection_address_family_e address_family, const char *interface_name, const char *host_address, const char * gateway);
 void _connection_libnet_add_to_profile_list(connection_profile_h profile);
 void _connection_libnet_remove_from_profile_list(connection_profile_h profile);
 bool _connection_libnet_add_to_profile_cb_list(connection_profile_h profile,
@@ -126,9 +156,7 @@ int _connection_libnet_get_statistics(net_statistics_type_e statistics_type, uns
 int _connection_libnet_check_get_privilege();
 int _connection_libnet_check_profile_privilege();
 
-bool _connection_libnet_get_is_check_enable_feature();
-bool _connection_libnet_get_enable_feature_state(enable_feature_type_e feature_type);
-int _connection_libnet_check_enable_feature();
+int _connection_check_feature_supported(const char *feature_name, ...);
 
 guint _connection_callback_add(GSourceFunc func, gpointer user_data);
 void _connection_callback_cleanup(void);
@@ -139,8 +167,6 @@ net_service_type_t _connection_profile_convert_to_libnet_cellular_service_type(c
 net_state_type_t _connection_profile_convert_to_net_state(connection_profile_state_e state);
 
 int _connection_libnet_set_cellular_subscriber_id(connection_profile_h profile, connection_cellular_subscriber_id_e sim_id);
-void _connection_inter_mutex_lock(void);
-void _connection_inter_mutex_unlock(void);
 
 #ifdef __cplusplus
 }