X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=src%2Fconnection_profile.c;h=586c90190cccbdef7493f56c16a5e0f7adb6e75a;hb=cfc8c3d22389e71a3d504d5a96af8ca97d1b74fd;hp=29b9b3a9a87f26b590b8c13de9134f2931d15151;hpb=1c60931f4d893fd0253a75b26fa6f8a4404e1173;p=platform%2Fcore%2Fapi%2Fconnection.git diff --git a/src/connection_profile.c b/src/connection_profile.c index 29b9b3a..586c901 100755 --- a/src/connection_profile.c +++ b/src/connection_profile.c @@ -22,6 +22,7 @@ #include #include "net_connection_private.h" +#include "connection_extension.h" #define HTTP_PROXY "http_proxy" #define MAX_PREFIX_LENGTH 6 @@ -37,6 +38,8 @@ static net_dev_info_t* __profile_get_net_info(net_profile_info_t *profile_info) return &profile_info->ProfileInfo.Ethernet.net_info; //LCOV_EXCL_LINE case NET_DEVICE_BLUETOOTH: return &profile_info->ProfileInfo.Bluetooth.net_info; + case NET_DEVICE_MESH: + return &profile_info->ProfileInfo.Mesh.net_info; case NET_DEVICE_DEFAULT: case NET_DEVICE_USB: case NET_DEVICE_UNKNOWN: @@ -106,7 +109,7 @@ static void __profile_init_wifi_profile(net_profile_info_t *profile_info) } //LCOV_EXCL_START -static const char* __profile_get_ethernet_proxy(void) +static char* __profile_get_ethernet_proxy(void) { char *proxy; @@ -121,6 +124,30 @@ static const char* __profile_get_ethernet_proxy(void) } //LCOV_EXCL_STOP +static unsigned char __profile_convert_netmask_to_prefix_len(const char *netmask) +{ + if (netmask == NULL) + return 0; + + in_addr_t mask = inet_network(netmask); + in_addr_t host = ~mask; + unsigned char prefix_len = 0; + + /* a valid netmask must be 2^n - 1 */ + if ((host & (host + 1)) != 0) + return -1; + + for (; mask; mask <<= 1) + ++prefix_len; + + return prefix_len; +} + +static in_addr_t __profile_convert_prefix_len_to_netmask(int prefix_len) +{ + return (prefix_len ? (in_addr_t) 0xFFFFFFFFu >> (32 - prefix_len) : 0); +} + //LCOV_EXCL_START connection_cellular_service_type_e _profile_convert_to_connection_cellular_service_type(net_service_type_t svc_type) { @@ -245,20 +272,15 @@ EXPORT_API int connection_profile_create(connection_profile_type_e type, const c if (profile_info == NULL) return CONNECTION_ERROR_OUT_OF_MEMORY; - switch (type) { - case CONNECTION_PROFILE_TYPE_CELLULAR: + if (type == CONNECTION_PROFILE_TYPE_CELLULAR) { if (keyword == NULL) { CONNECTION_LOG(CONNECTION_ERROR, "Invalid parameter"); g_free(profile_info); return CONNECTION_ERROR_INVALID_PARAMETER; } __profile_init_cellular_profile(profile_info, keyword); - break; - case CONNECTION_PROFILE_TYPE_WIFI: + } else if (type == CONNECTION_PROFILE_TYPE_WIFI) { __profile_init_wifi_profile(profile_info); - break; - default: - break; } *profile = (connection_profile_h)profile_info; @@ -353,6 +375,9 @@ EXPORT_API int connection_profile_get_name(connection_profile_h profile, char** bt_name++; *profile_name = g_strdup(bt_name); } break; + case NET_DEVICE_MESH: + *profile_name = g_strdup(profile_info->ProfileInfo.Mesh.essid); + break; default: return CONNECTION_ERROR_INVALID_PARAMETER; } @@ -387,6 +412,9 @@ EXPORT_API int connection_profile_get_type(connection_profile_h profile, connect case NET_DEVICE_BLUETOOTH: *type = CONNECTION_PROFILE_TYPE_BT; break; + case NET_DEVICE_MESH: + *type = CONNECTION_PROFILE_TYPE_MESH; + break; default: CONNECTION_LOG(CONNECTION_ERROR, "Invalid profile type"); return CONNECTION_ERROR_OPERATION_FAILED; @@ -553,12 +581,16 @@ EXPORT_API int connection_profile_get_ip_address(connection_profile_h profile, if (net_info == NULL) return CONNECTION_ERROR_OPERATION_FAILED; - if (address_family == CONNECTION_ADDRESS_FAMILY_IPV6) - *ip_address = __profile_convert_ip_to_string(&net_info->IpAddr6, - address_family); - else + if (address_family == CONNECTION_ADDRESS_FAMILY_IPV4) { *ip_address = __profile_convert_ip_to_string(&net_info->IpAddr, address_family); + } else { + if (net_get_preferred_ipv6_address(net_info->ProfileName, ip_address) != NET_ERR_NONE) { + CONNECTION_LOG(CONNECTION_ERROR, "Failed to get preferred ipv6 address"); + *ip_address = __profile_convert_ip_to_string(&net_info->IpAddr6, + address_family); + } + } if (*ip_address == NULL) return CONNECTION_ERROR_OUT_OF_MEMORY; @@ -569,8 +601,6 @@ EXPORT_API int connection_profile_get_ip_address(connection_profile_h profile, EXPORT_API int connection_profile_get_subnet_mask(connection_profile_h profile, connection_address_family_e address_family, char** subnet_mask) { - char* prefixlen; - CHECK_FEATURE_SUPPORTED(TELEPHONY_FEATURE, WIFI_FEATURE, TETHERING_BLUETOOTH_FEATURE, ETHERNET_FEATURE); if (!(_connection_libnet_check_profile_validity(profile)) || @@ -581,22 +611,18 @@ EXPORT_API int connection_profile_get_subnet_mask(connection_profile_h profile, return CONNECTION_ERROR_INVALID_PARAMETER; } + if (address_family == CONNECTION_ADDRESS_FAMILY_IPV6) { + CONNECTION_LOG(CONNECTION_ERROR, + "Please uses connection_profile_get_prefix_length()"); + return CONNECTION_ERROR_NOT_SUPPORTED; + } + net_profile_info_t *profile_info = profile; net_dev_info_t *net_info = __profile_get_net_info(profile_info); if (net_info == NULL) return CONNECTION_ERROR_OPERATION_FAILED; - if (address_family == CONNECTION_ADDRESS_FAMILY_IPV6) { - //LCOV_EXCL_START - prefixlen = g_try_malloc0(MAX_PREFIX_LENGTH); - if (prefixlen != NULL) { - snprintf(prefixlen, MAX_PREFIX_LENGTH, "%d", net_info->PrefixLen6); - *subnet_mask = prefixlen; - } else - *subnet_mask = NULL; - //LCOV_EXCL_STOP - } else - *subnet_mask = __profile_convert_ip_to_string(&net_info->SubnetMask, + *subnet_mask = __profile_convert_ip_to_string(&net_info->SubnetMask, address_family); if (*subnet_mask == NULL) @@ -636,6 +662,73 @@ EXPORT_API int connection_profile_get_gateway_address(connection_profile_h profi return CONNECTION_ERROR_NONE; } +EXPORT_API int connection_profile_get_dhcp_server_address( + connection_profile_h profile, + connection_address_family_e address_family, char** dhcp_server) +{ + CHECK_FEATURE_SUPPORTED(TELEPHONY_FEATURE, WIFI_FEATURE, TETHERING_BLUETOOTH_FEATURE, ETHERNET_FEATURE); + + if (address_family == CONNECTION_ADDRESS_FAMILY_IPV6) { + CONNECTION_LOG(CONNECTION_ERROR, "Not supported"); + return CONNECTION_ERROR_ADDRESS_FAMILY_NOT_SUPPORTED; + } + + if (!(_connection_libnet_check_profile_validity(profile)) || + (address_family != CONNECTION_ADDRESS_FAMILY_IPV4) || + dhcp_server == NULL) { + CONNECTION_LOG(CONNECTION_ERROR, "Invalid parameter"); + return CONNECTION_ERROR_INVALID_PARAMETER; + } + + net_profile_info_t *profile_info = profile; + net_dev_info_t *net_info = __profile_get_net_info(profile_info); + if (net_info == NULL) + return CONNECTION_ERROR_OPERATION_FAILED; + + CONNECTION_LOG(CONNECTION_INFO, "IP Config %d, DHCP Server Address %s", + net_info->IpConfigType, (net_info->BServerAddr ? "TRUE" : "FALSE")); + + *dhcp_server = __profile_convert_ip_to_string(&net_info->ServerAddr, + address_family); + + if (*dhcp_server == NULL) + return CONNECTION_ERROR_OUT_OF_MEMORY; + + return CONNECTION_ERROR_NONE; +} + +EXPORT_API int connection_profile_get_dhcp_lease_duration( + connection_profile_h profile, + connection_address_family_e address_family, int* dhcp_lease_duration) +{ + CHECK_FEATURE_SUPPORTED(TELEPHONY_FEATURE, WIFI_FEATURE, TETHERING_BLUETOOTH_FEATURE, ETHERNET_FEATURE); + + if (!(_connection_libnet_check_profile_validity(profile)) || + (address_family != CONNECTION_ADDRESS_FAMILY_IPV4 && + address_family != CONNECTION_ADDRESS_FAMILY_IPV6) || + dhcp_lease_duration == NULL) { + CONNECTION_LOG(CONNECTION_ERROR, "Invalid parameter"); + return CONNECTION_ERROR_INVALID_PARAMETER; + } + + if (address_family == CONNECTION_ADDRESS_FAMILY_IPV6) { + CONNECTION_LOG(CONNECTION_ERROR, "Not supported"); + return CONNECTION_ERROR_ADDRESS_FAMILY_NOT_SUPPORTED; + } + + net_profile_info_t *profile_info = profile; + net_dev_info_t *net_info = __profile_get_net_info(profile_info); + if (net_info == NULL) + return CONNECTION_ERROR_OPERATION_FAILED; + + CONNECTION_LOG(CONNECTION_INFO, "Lease duration : %d", + net_info->DHCPLeaseDuration); + + *dhcp_lease_duration = net_info->DHCPLeaseDuration; + + return CONNECTION_ERROR_NONE; +} + EXPORT_API int connection_profile_get_dns_address(connection_profile_h profile, int order, connection_address_family_e address_family, char** dns_address) { @@ -662,8 +755,6 @@ EXPORT_API int connection_profile_get_dns_address(connection_profile_h profile, else if (address_family == CONNECTION_ADDRESS_FAMILY_IPV6) //LCOV_EXCL_LINE *dns_address = __profile_convert_ip_to_string(&net_info->DnsAddr6[order-1], //LCOV_EXCL_LINE address_family); - else - CONNECTION_LOG(CONNECTION_ERROR, "Invalid address family\n"); //LCOV_EXCL_LINE if (*dns_address == NULL) return CONNECTION_ERROR_OUT_OF_MEMORY; @@ -680,7 +771,6 @@ EXPORT_API int connection_profile_get_proxy_type(connection_profile_h profile, c return CONNECTION_ERROR_INVALID_PARAMETER; } - const char *proxy; net_profile_info_t *profile_info = profile; net_dev_info_t *net_info = __profile_get_net_info(profile_info); if (net_info == NULL) @@ -688,11 +778,13 @@ EXPORT_API int connection_profile_get_proxy_type(connection_profile_h profile, c //LCOV_EXCL_START if (profile_info->profile_type == NET_DEVICE_ETHERNET) { - proxy = __profile_get_ethernet_proxy(); - if (proxy == NULL) + char *proxy = __profile_get_ethernet_proxy(); + if (proxy == NULL) { *type = CONNECTION_PROXY_TYPE_DIRECT; - else + } else { *type = CONNECTION_PROXY_TYPE_MANUAL; + free(proxy); + } return CONNECTION_ERROR_NONE; } @@ -868,29 +960,32 @@ EXPORT_API int connection_profile_set_subnet_mask(connection_profile_h profile, CHECK_FEATURE_SUPPORTED(TELEPHONY_FEATURE, WIFI_FEATURE, TETHERING_BLUETOOTH_FEATURE, ETHERNET_FEATURE); if (!(_connection_libnet_check_profile_validity(profile)) || - (address_family != CONNECTION_ADDRESS_FAMILY_IPV4 && - address_family != CONNECTION_ADDRESS_FAMILY_IPV6)) { + (address_family != CONNECTION_ADDRESS_FAMILY_IPV4 && + address_family != CONNECTION_ADDRESS_FAMILY_IPV6)) { CONNECTION_LOG(CONNECTION_ERROR, "Invalid parameter"); return CONNECTION_ERROR_INVALID_PARAMETER; } + if (address_family == CONNECTION_ADDRESS_FAMILY_IPV6) { + CONNECTION_LOG(CONNECTION_ERROR, + "Please uses connection_profile_set_prefix_length()"); + return CONNECTION_ERROR_NOT_SUPPORTED; + } + net_profile_info_t *profile_info = profile; net_dev_info_t *net_info = __profile_get_net_info(profile_info); if (net_info == NULL) return CONNECTION_ERROR_OPERATION_FAILED; - if (address_family == CONNECTION_ADDRESS_FAMILY_IPV6) { - //LCOV_EXCL_START - if (subnet_mask == NULL) - net_info->PrefixLen6 = 0 ; - else - net_info->PrefixLen6 = atoi(subnet_mask) ; - //LCOV_EXCL_STOP - } else { - if (subnet_mask == NULL) - net_info->SubnetMask.Data.Ipv4.s_addr = 0; - else if (inet_pton(AF_INET, subnet_mask , &net_info->SubnetMask.Data.Ipv4) < 1) - return CONNECTION_ERROR_INVALID_PARAMETER; + if (subnet_mask == NULL) + net_info->SubnetMask.Data.Ipv4.s_addr = 0; + else if (inet_pton(AF_INET, subnet_mask , &net_info->SubnetMask.Data.Ipv4) < 1) + return CONNECTION_ERROR_INVALID_PARAMETER; + + net_info->PrefixLen = __profile_convert_netmask_to_prefix_len(subnet_mask); + if (net_info->PrefixLen <= 0 || net_info->PrefixLen > 31) { + CONNECTION_LOG(CONNECTION_ERROR, "Invalid Prefix length: %d", net_info->PrefixLen); + return CONNECTION_ERROR_INVALID_PARAMETER; } return CONNECTION_ERROR_NONE; @@ -1010,7 +1105,7 @@ EXPORT_API int connection_profile_set_proxy_address(connection_profile_h profile { CHECK_FEATURE_SUPPORTED(TELEPHONY_FEATURE, WIFI_FEATURE, TETHERING_BLUETOOTH_FEATURE, ETHERNET_FEATURE); - CONNECTION_LOG(CONNECTION_ERROR, "Address Family: ", address_family); + CONNECTION_LOG(CONNECTION_ERROR, "Address Family: %d", address_family); if (!(_connection_libnet_check_profile_validity(profile)) || (address_family != CONNECTION_ADDRESS_FAMILY_IPV4 && address_family != CONNECTION_ADDRESS_FAMILY_IPV6)) { @@ -1075,10 +1170,15 @@ EXPORT_API int connection_profile_get_wifi_essid(connection_profile_h profile, c net_profile_info_t *profile_info = profile; - if (profile_info->profile_type != NET_DEVICE_WIFI) + if (profile_info->profile_type != NET_DEVICE_WIFI && + profile_info->profile_type != NET_DEVICE_MESH) return CONNECTION_ERROR_INVALID_PARAMETER; - *essid = g_strdup(profile_info->ProfileInfo.Wlan.essid); + if (profile_info->profile_type == NET_DEVICE_WIFI) + *essid = g_strdup(profile_info->ProfileInfo.Wlan.essid); + else + *essid = g_strdup(profile_info->ProfileInfo.Mesh.essid); + if (*essid == NULL) return CONNECTION_ERROR_OUT_OF_MEMORY; @@ -1096,10 +1196,15 @@ EXPORT_API int connection_profile_get_wifi_bssid(connection_profile_h profile, c net_profile_info_t *profile_info = profile; - if (profile_info->profile_type != NET_DEVICE_WIFI) + if (profile_info->profile_type != NET_DEVICE_WIFI && + profile_info->profile_type != NET_DEVICE_MESH) return CONNECTION_ERROR_INVALID_PARAMETER; - *bssid = g_strdup(profile_info->ProfileInfo.Wlan.bssid); + if (profile_info->profile_type == NET_DEVICE_WIFI) + *bssid = g_strdup(profile_info->ProfileInfo.Wlan.bssid); + else + *bssid = g_strdup(profile_info->ProfileInfo.Mesh.bssid); + if (*bssid == NULL) return CONNECTION_ERROR_OUT_OF_MEMORY; @@ -1117,10 +1222,15 @@ EXPORT_API int connection_profile_get_wifi_rssi(connection_profile_h profile, in net_profile_info_t *profile_info = profile; - if (profile_info->profile_type != NET_DEVICE_WIFI) + if (profile_info->profile_type != NET_DEVICE_WIFI && + profile_info->profile_type != NET_DEVICE_MESH) return CONNECTION_ERROR_INVALID_PARAMETER; - *rssi = (int)profile_info->ProfileInfo.Wlan.Strength; + if (profile_info->profile_type == NET_DEVICE_WIFI) + *rssi = (int)profile_info->ProfileInfo.Wlan.Strength; + else + *rssi = (int)profile_info->ProfileInfo.Mesh.Strength; + return CONNECTION_ERROR_NONE; } @@ -1136,10 +1246,15 @@ EXPORT_API int connection_profile_get_wifi_frequency(connection_profile_h profil net_profile_info_t *profile_info = profile; - if (profile_info->profile_type != NET_DEVICE_WIFI) + if (profile_info->profile_type != NET_DEVICE_WIFI && + profile_info->profile_type != NET_DEVICE_MESH) return CONNECTION_ERROR_INVALID_PARAMETER; - *frequency = (int)profile_info->ProfileInfo.Wlan.frequency; + if (profile_info->profile_type == NET_DEVICE_WIFI) + *frequency = (int)profile_info->ProfileInfo.Wlan.frequency; + else + *frequency = (int)profile_info->ProfileInfo.Mesh.frequency; + return CONNECTION_ERROR_NONE; } @@ -1158,7 +1273,7 @@ EXPORT_API int connection_profile_get_wifi_max_speed(connection_profile_h profil if (profile_info->profile_type != NET_DEVICE_WIFI) return CONNECTION_ERROR_INVALID_PARAMETER; - *max_speed = (int)profile_info->ProfileInfo.Wlan.max_rate / 1000000; + *max_speed = profile_info->ProfileInfo.Wlan.max_rate; return CONNECTION_ERROR_NONE; } @@ -1174,10 +1289,17 @@ EXPORT_API int connection_profile_get_wifi_security_type(connection_profile_h pr net_profile_info_t *profile_info = profile; - if (profile_info->profile_type != NET_DEVICE_WIFI) + wlan_security_mode_type_t sec_mode; + if (profile_info->profile_type != NET_DEVICE_WIFI && + profile_info->profile_type != NET_DEVICE_MESH) return CONNECTION_ERROR_INVALID_PARAMETER; - switch (profile_info->ProfileInfo.Wlan.security_info.sec_mode) { + if (profile_info->profile_type == NET_DEVICE_WIFI) + sec_mode = profile_info->ProfileInfo.Wlan.security_info.sec_mode; + else + sec_mode = profile_info->ProfileInfo.Mesh.security_info.sec_mode; + + switch (sec_mode) { //LCOV_EXCL_START case WLAN_SEC_MODE_NONE: *type = CONNECTION_WIFI_SECURITY_TYPE_NONE; @@ -1194,6 +1316,9 @@ EXPORT_API int connection_profile_get_wifi_security_type(connection_profile_h pr case WLAN_SEC_MODE_WPA2_PSK: *type = CONNECTION_WIFI_SECURITY_TYPE_WPA2_PSK; break; + case WLAN_SEC_MODE_SAE: + *type = CONNECTION_WIFI_SECURITY_TYPE_SAE; + break; default: return CONNECTION_ERROR_OPERATION_FAILED; //LCOV_EXCL_STOP @@ -1252,7 +1377,9 @@ EXPORT_API int connection_profile_is_wifi_passphrase_required(connection_profile net_profile_info_t *profile_info = profile; - if (profile_info->profile_type != NET_DEVICE_WIFI) + wlan_security_mode_type_t sec_mode; + if (profile_info->profile_type != NET_DEVICE_WIFI && + profile_info->profile_type != NET_DEVICE_MESH) return CONNECTION_ERROR_INVALID_PARAMETER; if (profile_info->Favourite) { @@ -1260,7 +1387,12 @@ EXPORT_API int connection_profile_is_wifi_passphrase_required(connection_profile return CONNECTION_ERROR_NONE; } - switch (profile_info->ProfileInfo.Wlan.security_info.sec_mode) { + if (profile_info->profile_type == NET_DEVICE_WIFI) + sec_mode = profile_info->ProfileInfo.Wlan.security_info.sec_mode; + else + sec_mode = profile_info->ProfileInfo.Mesh.security_info.sec_mode; + + switch (sec_mode) { //LCOV_EXCL_START case WLAN_SEC_MODE_NONE: *required = false; @@ -1269,6 +1401,7 @@ EXPORT_API int connection_profile_is_wifi_passphrase_required(connection_profile case WLAN_SEC_MODE_IEEE8021X: case WLAN_SEC_MODE_WPA_PSK: case WLAN_SEC_MODE_WPA2_PSK: + case WLAN_SEC_MODE_SAE: *required = true; break; default: @@ -1290,11 +1423,16 @@ EXPORT_API int connection_profile_set_wifi_passphrase(connection_profile_h profi net_profile_info_t *profile_info = profile; - if (profile_info->profile_type != NET_DEVICE_WIFI) + if (profile_info->profile_type != NET_DEVICE_WIFI && + profile_info->profile_type != NET_DEVICE_MESH) return CONNECTION_ERROR_INVALID_PARAMETER; - g_strlcpy(profile_info->ProfileInfo.Wlan.security_info.authentication.psk.pskKey, - passphrase, NETPM_WLAN_MAX_PSK_PASSPHRASE_LEN); + if (profile_info->profile_type == NET_DEVICE_WIFI) + g_strlcpy(profile_info->ProfileInfo.Wlan.security_info.authentication.psk.pskKey, + passphrase, NETPM_WLAN_MAX_PSK_PASSPHRASE_LEN); + else + g_strlcpy(profile_info->ProfileInfo.Mesh.security_info.authentication.sae.saeKey, + passphrase, NETPM_WLAN_MAX_PSK_PASSPHRASE_LEN); return CONNECTION_ERROR_NONE; } @@ -1769,6 +1907,11 @@ EXPORT_API int connection_profile_set_cellular_pdn_type(connection_profile_h pro break; case CONNECTION_CELLULAR_PDN_TYPE_IPV4_IPv6: profile_info->ProfileInfo.Pdp.PdnType = NET_PDN_TYPE_IPV4_IPV6; + CONNECTION_LOG(CONNECTION_WARN, "DEPRECATION WARNINIG: CONNECTION_CELLULAR_PDN_TYPE_IPV4_IPv6 " \ + "from next release. Use CONNECTION_CELLULAR_PDN_TYPE_IPV4_IPV6 instead"); + break; + case CONNECTION_CELLULAR_PDN_TYPE_IPV4_IPV6: + profile_info->ProfileInfo.Pdp.PdnType = NET_PDN_TYPE_IPV4_IPV6; break; default: return CONNECTION_ERROR_INVALID_PARAMETER; @@ -1804,6 +1947,11 @@ EXPORT_API int connection_profile_set_cellular_roam_pdn_type(connection_profile_ break; case CONNECTION_CELLULAR_PDN_TYPE_IPV4_IPv6: profile_info->ProfileInfo.Pdp.RoamPdnType = NET_PDN_TYPE_IPV4_IPV6; + CONNECTION_LOG(CONNECTION_WARN, "DEPRECATION WARNINIG: CONNECTION_CELLULAR_PDN_TYPE_IPV4_IPv6 " \ + "from next release. Use CONNECTION_CELLULAR_PDN_TYPE_IPV4_IPV6 instead"); + break; + case CONNECTION_CELLULAR_PDN_TYPE_IPV4_IPV6: + profile_info->ProfileInfo.Pdp.RoamPdnType = NET_PDN_TYPE_IPV4_IPV6; break; default: return CONNECTION_ERROR_INVALID_PARAMETER; @@ -1812,3 +1960,158 @@ EXPORT_API int connection_profile_set_cellular_roam_pdn_type(connection_profile_ return CONNECTION_ERROR_NONE; } + +EXPORT_API int connection_profile_get_ipv6_state(connection_profile_h profile, connection_profile_state_e *state) +{ + CHECK_FEATURE_SUPPORTED(TELEPHONY_FEATURE, WIFI_FEATURE, + TETHERING_BLUETOOTH_FEATURE, ETHERNET_FEATURE); + + if (!(_connection_libnet_check_profile_validity(profile)) || + state == NULL) { + CONNECTION_LOG(CONNECTION_ERROR, "Invalid parameter"); + return CONNECTION_ERROR_INVALID_PARAMETER; + } + + net_profile_info_t *profile_info = profile; + *state = _profile_convert_to_cp_state(profile_info->ProfileState6); + if (*state < 0) + return CONNECTION_ERROR_OPERATION_FAILED; + + return CONNECTION_ERROR_NONE; +} + +EXPORT_API int connection_profile_set_dns_config_type(connection_profile_h profile, + connection_address_family_e address_family, connection_dns_config_type_e type) +{ + CHECK_FEATURE_SUPPORTED(TELEPHONY_FEATURE, WIFI_FEATURE, + TETHERING_BLUETOOTH_FEATURE, ETHERNET_FEATURE); + + if (!(_connection_libnet_check_profile_validity(profile))) { + CONNECTION_LOG(CONNECTION_ERROR, "Invalid parameter"); + return CONNECTION_ERROR_INVALID_PARAMETER; + } + + if ((address_family != CONNECTION_ADDRESS_FAMILY_IPV4 && + address_family != CONNECTION_ADDRESS_FAMILY_IPV6) || + (type != CONNECTION_DNS_CONFIG_TYPE_STATIC && + type != CONNECTION_DNS_CONFIG_TYPE_DYNAMIC)) { + CONNECTION_LOG(CONNECTION_ERROR, "Invalid parameter"); + return CONNECTION_ERROR_INVALID_PARAMETER; + } + + net_dns_config_type_t *profileType = NULL; + net_dns_config_type_t *profileType6 = NULL; + net_profile_info_t *profile_info = profile; + + net_dev_info_t *net_info = __profile_get_net_info(profile_info); + if (net_info == NULL) + return CONNECTION_ERROR_OPERATION_FAILED; + + if (address_family == CONNECTION_ADDRESS_FAMILY_IPV4) { + profileType = &net_info->DnsConfigType; + net_info->DnsAddr[0].Data.Ipv4.s_addr = 0; + net_info->DnsAddr[1].Data.Ipv4.s_addr = 0; + *profileType = type; + } else { + profileType6 = &net_info->DnsConfigType6; + inet_pton(AF_INET6, "::", &net_info->DnsAddr6[0].Data.Ipv6); + inet_pton(AF_INET6, "::", &net_info->DnsAddr6[1].Data.Ipv6); + *profileType6 = type; + } + + return CONNECTION_ERROR_NONE; +} + +EXPORT_API int connection_profile_get_dns_config_type(connection_profile_h profile, + connection_address_family_e address_family, connection_dns_config_type_e *type) +{ + CHECK_FEATURE_SUPPORTED(TELEPHONY_FEATURE, WIFI_FEATURE, + TETHERING_BLUETOOTH_FEATURE, ETHERNET_FEATURE); + + if (!(_connection_libnet_check_profile_validity(profile)) || + (address_family != CONNECTION_ADDRESS_FAMILY_IPV4 && + address_family != CONNECTION_ADDRESS_FAMILY_IPV6) || + type == NULL) { + CONNECTION_LOG(CONNECTION_ERROR, "Invalid parameter"); + return CONNECTION_ERROR_INVALID_PARAMETER; + } + + net_dns_config_type_t profileType; + net_profile_info_t *profile_info = profile; + net_dev_info_t *net_info = __profile_get_net_info(profile_info); + if (net_info == NULL) + return CONNECTION_ERROR_OPERATION_FAILED; + + if (address_family == CONNECTION_ADDRESS_FAMILY_IPV4) + profileType = net_info->DnsConfigType; + else + profileType = net_info->DnsConfigType6; + + switch (profileType) { + case NET_DNS_CONFIG_TYPE_STATIC: + *type = CONNECTION_DNS_CONFIG_TYPE_STATIC; + break; + case NET_DNS_CONFIG_TYPE_DYNAMIC: + *type = CONNECTION_DNS_CONFIG_TYPE_DYNAMIC; + break; + default: + *type = CONNECTION_DNS_CONFIG_TYPE_NONE; + break; + } + + return CONNECTION_ERROR_NONE; +} + +EXPORT_API int connection_profile_set_prefix_length(connection_profile_h profile, + connection_address_family_e address_family, int prefix_len) +{ + CHECK_FEATURE_SUPPORTED(TELEPHONY_FEATURE, WIFI_FEATURE, + TETHERING_BLUETOOTH_FEATURE, ETHERNET_FEATURE); + + if (!(_connection_libnet_check_profile_validity(profile)) || + (address_family != CONNECTION_ADDRESS_FAMILY_IPV4 && + address_family != CONNECTION_ADDRESS_FAMILY_IPV6)) { + CONNECTION_LOG(CONNECTION_ERROR, "Invalid parameter"); + return CONNECTION_ERROR_INVALID_PARAMETER; + } + + net_profile_info_t *profile_info = profile; + net_dev_info_t *net_info = __profile_get_net_info(profile_info); + if (net_info == NULL) + return CONNECTION_ERROR_OPERATION_FAILED; + + if (address_family == CONNECTION_ADDRESS_FAMILY_IPV4) { + net_info->PrefixLen = prefix_len; + net_info->SubnetMask.Data.Ipv4.s_addr = __profile_convert_prefix_len_to_netmask(prefix_len); + } else + net_info->PrefixLen6 = prefix_len; + + return CONNECTION_ERROR_NONE; +} + +EXPORT_API int connection_profile_get_prefix_length(connection_profile_h profile, + connection_address_family_e address_family, int *prefix_len) +{ + CHECK_FEATURE_SUPPORTED(TELEPHONY_FEATURE, WIFI_FEATURE, + TETHERING_BLUETOOTH_FEATURE, ETHERNET_FEATURE); + + if (!(_connection_libnet_check_profile_validity(profile)) || + (address_family != CONNECTION_ADDRESS_FAMILY_IPV4 && + address_family != CONNECTION_ADDRESS_FAMILY_IPV6) || + prefix_len == NULL) { + CONNECTION_LOG(CONNECTION_ERROR, "Invalid parameter"); + return CONNECTION_ERROR_INVALID_PARAMETER; + } + + net_profile_info_t *profile_info = profile; + net_dev_info_t *net_info = __profile_get_net_info(profile_info); + if (net_info == NULL) + return CONNECTION_ERROR_OPERATION_FAILED; + + if (address_family == CONNECTION_ADDRESS_FAMILY_IPV4) + *prefix_len = net_info->PrefixLen; + else if (address_family == CONNECTION_ADDRESS_FAMILY_IPV6) + *prefix_len = net_info->PrefixLen6; + + return CONNECTION_ERROR_NONE; +}