technology: When disabling technology, disble tethering too
[framework/connectivity/connman.git] / src / wpad.c
index 1102dad..0069c49 100644 (file)
@@ -23,6 +23,7 @@
 #include <config.h>
 #endif
 
+#include <errno.h>
 #include <stdlib.h>
 #include <string.h>
 
@@ -114,44 +115,47 @@ failed:
                                CONNMAN_SERVICE_PROXY_METHOD_DIRECT);
 }
 
-void __connman_wpad_start(struct connman_service *service)
+int __connman_wpad_start(struct connman_service *service)
 {
        struct connman_wpad *wpad;
-       const char *domainname, *nameserver;
+       const char *domainname;
+       char **nameservers;
        int index;
+       int i;
 
        DBG("service %p", service);
 
        if (wpad_list == NULL)
-               return;
+               return -EINVAL;
 
        index = __connman_service_get_index(service);
        if (index < 0)
-               return;
+               return -EINVAL;
 
        domainname = connman_service_get_domainname(service);
        if (domainname == NULL)
-               return;
+               return -EINVAL;
 
-       nameserver = connman_service_get_nameserver(service);
-       if (nameserver == NULL)
-               return;
+       nameservers = connman_service_get_nameservers(service);
+       if (nameservers == NULL)
+               return -EINVAL;
 
        wpad = g_try_new0(struct connman_wpad, 1);
        if (wpad == NULL)
-               return;
+               return -ENOMEM;
 
        wpad->service = service;
        wpad->resolv = g_resolv_new(index);
        if (wpad->resolv == NULL) {
                g_free(wpad);
-               return;
+               return -ENOMEM;
        }
 
        if (getenv("CONNMAN_RESOLV_DEBUG"))
                g_resolv_set_debug(wpad->resolv, resolv_debug, "RESOLV");
 
-       g_resolv_add_nameserver(wpad->resolv, nameserver, 53, 0);
+       for (i = 0; nameservers[i] != NULL; i++)
+               g_resolv_add_nameserver(wpad->resolv, nameservers[i], 53, 0);
 
        wpad->hostname = g_strdup_printf("wpad.%s", domainname);
 
@@ -161,6 +165,8 @@ void __connman_wpad_start(struct connman_service *service)
                                                        wpad_result, wpad);
 
        g_hash_table_replace(wpad_list, GINT_TO_POINTER(index), wpad);
+
+       return 0;
 }
 
 void __connman_wpad_stop(struct connman_service *service)