+
+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;
+}
+
+EXPORT_API int connection_profile_start_tcpdump(connection_h connection)
+{
+ int ret = 0;
+
+ if (!(__connection_check_handle_validity(connection))) {
+ CONNECTION_LOG(CONNECTION_ERROR, "Invalid parameter");
+ return CONNECTION_ERROR_INVALID_PARAMETER;
+ }
+
+ ret = _connection_libnet_start_tcpdump();
+ if (ret != CONNECTION_ERROR_NONE) {
+ CONNECTION_LOG(CONNECTION_ERROR, "Failed to start tcpdump (%d)", ret);
+ return ret;
+ }
+
+ return CONNECTION_ERROR_NONE;
+}
+
+EXPORT_API int connection_profile_stop_tcpdump(connection_h connection)
+{
+ int ret = 0;
+
+ if (!(__connection_check_handle_validity(connection))) {
+ CONNECTION_LOG(CONNECTION_ERROR, "Invalid parameter");
+ return CONNECTION_ERROR_INVALID_PARAMETER;
+ }
+
+ ret = _connection_libnet_stop_tcpdump();
+ if (ret != CONNECTION_ERROR_NONE) {
+ CONNECTION_LOG(CONNECTION_ERROR, "Failed to stop tcpdump (%d)", ret);
+ return ret;
+ }
+
+ return CONNECTION_ERROR_NONE;
+}
+
+EXPORT_API int connection_profile_get_tcpdump_state(connection_h connection, gboolean *tcpdump_state)
+{
+ int ret = 0;
+
+ if (!(__connection_check_handle_validity(connection)) || !tcpdump_state) {
+ CONNECTION_LOG(CONNECTION_ERROR, "Invalid parameter");
+ return CONNECTION_ERROR_INVALID_PARAMETER;
+ }
+
+ ret = _connection_libnet_get_tcpdump_state(tcpdump_state);
+ if (ret != CONNECTION_ERROR_NONE) {
+ CONNECTION_LOG(CONNECTION_ERROR, "Failed to get the tcpdump state (%d)", ret);
+ return ret;
+ }
+
+ return CONNECTION_ERROR_NONE;
+}