service: Return DIRECT proxy if wpad_start fails
authorSamuel Ortiz <sameo@linux.intel.com>
Wed, 12 Jan 2011 22:40:30 +0000 (23:40 +0100)
committerSamuel Ortiz <sameo@linux.intel.com>
Wed, 12 Jan 2011 23:37:21 +0000 (00:37 +0100)
src/connman.h
src/service.c
src/wpad.c

index b58f903..7c1395b 100644 (file)
@@ -290,7 +290,7 @@ gboolean __connman_connection_update_gateway(void);
 
 int __connman_wpad_init(void);
 void __connman_wpad_cleanup(void);
-void __connman_wpad_start(struct connman_service *service);
+int __connman_wpad_start(struct connman_service *service);
 void __connman_wpad_stop(struct connman_service *service);
 
 int __connman_wispr_init(void);
index caee973..a99b919 100644 (file)
@@ -3134,7 +3134,9 @@ int __connman_service_indicate_state(struct connman_service *service,
                                (proxy_config ==
                                        CONNMAN_SERVICE_PROXY_METHOD_AUTO &&
                                        service->pac == NULL)))
-                       __connman_wpad_start(service);
+                       if (__connman_wpad_start(service) < 0)
+                               service->proxy =
+                                       CONNMAN_SERVICE_PROXY_METHOD_DIRECT;
 
                __connman_notifier_connect(service->type);
 
index 1102dad..2de8e6e 100644 (file)
@@ -114,7 +114,7 @@ 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;
@@ -123,29 +123,29 @@ void __connman_wpad_start(struct connman_service *service)
        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;
+               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"))
@@ -161,6 +161,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)