#include <glib.h>
#include <stdio.h>
+#include <stdlib.h>
#include <string.h>
#include <vconf/vconf.h>
+#include <system_info.h>
#include "net_connection_private.h"
static __thread GSList *conn_handle_list = NULL;
+static int tv_profile = -1; // Unknown
//LCOV_EXCL_START
static int __connection_convert_net_state(int status)
if (callback)
callback(ip_addr, NULL, data);
- g_free(ip_addr);
+ free(ip_addr);
return FALSE;
}
if (callback)
callback(proxy, NULL, data);
- g_free(proxy);
+ free(proxy);
return FALSE;
}
__connection_cb_ethernet_cable_state_changed_cb);
} else {
- if (__connection_get_ethernet_cable_state_changed_callback_count() == 1)
+ if (__connection_get_ethernet_cable_state_changed_callback_count() == 1 &&
+ local_handle->ethernet_cable_state_changed_callback)
_connection_libnet_set_ethernet_cable_state_changed_cb(NULL);
}
switch (address_family) {
case CONNECTION_ADDRESS_FAMILY_IPV4:
- case CONNECTION_ADDRESS_FAMILY_IPV6:
*ip_address = vconf_get_str(VCONFKEY_NETWORK_IP);
break;
+ case CONNECTION_ADDRESS_FAMILY_IPV6:
+ *ip_address = vconf_get_str(VCONFKEY_NETWORK_IP6);
+ break;
default:
CONNECTION_LOG(CONNECTION_ERROR, "Invalid parameter");
return CONNECTION_ERROR_INVALID_PARAMETER;
switch (type) {
case CONNECTION_TYPE_WIFI:
-#if defined TIZEN_TV
- fp = fopen(WIFI_MAC_INFO_FILE, "r");
- if (fp == NULL) {
- CONNECTION_LOG(CONNECTION_ERROR, "Failed to open file %s", WIFI_MAC_INFO_FILE); //LCOV_EXCL_LINE
- return CONNECTION_ERROR_OUT_OF_MEMORY; //LCOV_EXCL_LINE
+ if (__builtin_expect(tv_profile == -1, 0)) {
+ char *profileName;
+ system_info_get_platform_string("http://tizen.org/feature/profile", &profileName);
+ if (*profileName == 't' || *profileName == 'T')
+ tv_profile = 1;
+ else
+ tv_profile = 0;
+ free(profileName);
}
+ if (tv_profile == 1) {
+ fp = fopen(WIFI_MAC_INFO_FILE, "r");
+ if (fp == NULL) {
+ CONNECTION_LOG(CONNECTION_ERROR, "Failed to open file %s", WIFI_MAC_INFO_FILE); //LCOV_EXCL_LINE
+ return CONNECTION_ERROR_OUT_OF_MEMORY; //LCOV_EXCL_LINE
+ }
- if (fgets(buf, sizeof(buf), fp) == NULL) {
- CONNECTION_LOG(CONNECTION_ERROR, "Failed to get MAC info from %s", WIFI_MAC_INFO_FILE); //LCOV_EXCL_LINE
- fclose(fp); //LCOV_EXCL_LINE
- return CONNECTION_ERROR_OPERATION_FAILED;
- }
+ if (fgets(buf, sizeof(buf), fp) == NULL) {
+ CONNECTION_LOG(CONNECTION_ERROR, "Failed to get MAC info from %s", WIFI_MAC_INFO_FILE); //LCOV_EXCL_LINE
+ fclose(fp); //LCOV_EXCL_LINE
+ return CONNECTION_ERROR_OPERATION_FAILED;
+ }
- CONNECTION_LOG(CONNECTION_INFO, "%s : %s", WIFI_MAC_INFO_FILE, buf);
+ CONNECTION_LOG(CONNECTION_INFO, "%s : %s", WIFI_MAC_INFO_FILE, buf);
- *mac_addr = (char *)malloc(CONNECTION_MAC_INFO_LENGTH + 1);
- if (*mac_addr == NULL) {
- CONNECTION_LOG(CONNECTION_ERROR, "malloc() failed"); //LCOV_EXCL_LINE
- fclose(fp); //LCOV_EXCL_LINE
- return CONNECTION_ERROR_OUT_OF_MEMORY; //LCOV_EXCL_LINE
- }
- g_strlcpy(*mac_addr, buf, CONNECTION_MAC_INFO_LENGTH + 1);
- fclose(fp);
-#else
- *mac_addr = vconf_get_str(VCONFKEY_WIFI_BSSID_ADDRESS);
+ *mac_addr = (char *)malloc(CONNECTION_MAC_INFO_LENGTH + 1);
+ if (*mac_addr == NULL) {
+ CONNECTION_LOG(CONNECTION_ERROR, "malloc() failed"); //LCOV_EXCL_LINE
+ fclose(fp); //LCOV_EXCL_LINE
+ return CONNECTION_ERROR_OUT_OF_MEMORY; //LCOV_EXCL_LINE
+ }
+ g_strlcpy(*mac_addr, buf, CONNECTION_MAC_INFO_LENGTH + 1);
+ fclose(fp);
+ } else {
+ *mac_addr = vconf_get_str(VCONFKEY_WIFI_BSSID_ADDRESS);
- if (*mac_addr == NULL) {
- CONNECTION_LOG(CONNECTION_ERROR, "Failed to get vconf from %s", VCONFKEY_WIFI_BSSID_ADDRESS); //LCOV_EXCL_LINE
- return CONNECTION_ERROR_OPERATION_FAILED; //LCOV_EXCL_LINE
+ if (*mac_addr == NULL) {
+ CONNECTION_LOG(CONNECTION_ERROR, "Failed to get vconf from %s", VCONFKEY_WIFI_BSSID_ADDRESS); //LCOV_EXCL_LINE
+ return CONNECTION_ERROR_OPERATION_FAILED; //LCOV_EXCL_LINE
+ }
}
-#endif
break;
//LCOV_EXCL_START
case CONNECTION_TYPE_ETHERNET:
break;
//LCOV_EXCL_STOP
- default :
+ default:
CONNECTION_LOG(CONNECTION_ERROR, "Invalid parameter"); //LCOV_EXCL_LINE
return CONNECTION_ERROR_INVALID_PARAMETER; //LCOV_EXCL_LINE
}
return __reset_statistic(connection_type, statistics_type);
}
+EXPORT_API int connection_foreach_ipv6_address(connection_h connection,
+ connection_type_e connection_type, connection_ipv6_address_cb callback,
+ void *user_data)
+{
+ CHECK_FEATURE_SUPPORTED(TELEPHONY_FEATURE, WIFI_FEATURE,
+ TETHERING_BLUETOOTH_FEATURE, ETHERNET_FEATURE);
+
+ GSList *ipv6_address_list = NULL;
+
+ if (!(__connection_check_handle_validity(connection))) {
+ CONNECTION_LOG(CONNECTION_ERROR, "Invalid parameter");
+ return CONNECTION_ERROR_INVALID_PARAMETER;
+ }
+
+ int rv = CONNECTION_ERROR_NONE;
+
+ switch (connection_type) {
+ case CONNECTION_TYPE_WIFI:
+ rv = net_foreach_ipv6_address(NET_DEVICE_WIFI,
+ &ipv6_address_list);
+ break;
+ case CONNECTION_TYPE_CELLULAR:
+ rv = net_foreach_ipv6_address(NET_DEVICE_CELLULAR,
+ &ipv6_address_list);
+ break;
+ case CONNECTION_TYPE_ETHERNET:
+ rv = net_foreach_ipv6_address(NET_DEVICE_ETHERNET,
+ &ipv6_address_list);
+ break;
+ case CONNECTION_TYPE_BT:
+ rv = net_foreach_ipv6_address(NET_DEVICE_BLUETOOTH,
+ &ipv6_address_list);
+ break;
+ default:
+ CONNECTION_LOG(CONNECTION_ERROR, "Invalid parameter");
+ return CONNECTION_ERROR_INVALID_PARAMETER;
+ }
+
+ if (rv != NET_ERR_NONE) {
+ CONNECTION_LOG(CONNECTION_ERROR, "net_get_multiple_id_address"
+ " Failed = %d\n", rv);
+ return CONNECTION_ERROR_OPERATION_FAILED;
+ }
+
+ GSList *list;
+ for (list = ipv6_address_list; list; list = list->next) {
+ rv = callback((char *)list->data, user_data);
+ if (rv == false)
+ break;
+ }
+
+ g_slist_free_full(ipv6_address_list, g_free);
+ ipv6_address_list = NULL;
+
+ return CONNECTION_ERROR_NONE;
+}
+