X-Git-Url: http://git.maemo.org/git/?a=blobdiff_plain;f=plugins%2Fresolvconf.c;h=df3a834bf6b6ae152d874133f43d6fc249cd1e20;hb=0660600746db49600bdf10d96835abe9aeee5ac1;hp=e512f2b7c4e5bac2f02f06a5868f065cf89f00be;hpb=2657bbff7f718c5f822bdffd4b10b70ce3b21a33;p=connman diff --git a/plugins/resolvconf.c b/plugins/resolvconf.c index e512f2b..df3a834 100644 --- a/plugins/resolvconf.c +++ b/plugins/resolvconf.c @@ -2,7 +2,7 @@ * * Connection Manager * - * Copyright (C) 2007-2008 Intel Corporation. All rights reserved. + * Copyright (C) 2007-2009 Intel Corporation. All rights reserved. * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License version 2 as @@ -23,36 +23,30 @@ #include #endif +#include #include #include +#define CONNMAN_API_SUBJECT_TO_CHANGE #include -#include +#include #include -#define RESOLVCONF "/sbin/resolvconf" +#include -static int resolvconf_probe(struct connman_element *element) +static int resolvconf_append(const char *interface, const char *domain, + const char *server) { - const char *nameserver = NULL; - struct connman_element *internet; - gchar *cmd; + char *cmd; int err; - DBG("element %p name %s", element, element->name); + DBG("interface %s server %s", interface, server); if (access(RESOLVCONF, X_OK) < 0) return -errno; - connman_element_get_value(element, - CONNMAN_PROPERTY_TYPE_IPV4_NAMESERVER, &nameserver); - - if (nameserver == NULL) - return -EINVAL; - cmd = g_strdup_printf("echo \"nameserver %s\" | %s -a %s", - RESOLVCONF, nameserver, - element->netdev.name); + server, RESOLVCONF, interface); DBG("%s", cmd); @@ -60,48 +54,44 @@ static int resolvconf_probe(struct connman_element *element) g_free(cmd); - internet = connman_element_create(); - - internet->type = CONNMAN_ELEMENT_TYPE_INTERNET; - - connman_element_register(internet, element); - - return 0; + return err; } -static void resolvconf_remove(struct connman_element *element) +static int resolvconf_remove(const char *interface, const char *domain, + const char *server) { - gchar *cmd; + char *cmd; int err; - DBG("element %p name %s", element, element->name); + DBG("interface %s server %s", interface, server); - cmd = g_strdup_printf("%s -d %s", RESOLVCONF, element->netdev.name); + cmd = g_strdup_printf("%s -d %s", RESOLVCONF, interface); DBG("%s", cmd); err = system(cmd); g_free(cmd); + + return err; } -static struct connman_driver resolvconf_driver = { +static struct connman_resolver resolvconf_resolver = { .name = "resolvconf", - .type = CONNMAN_ELEMENT_TYPE_RESOLVER, - .priority = CONNMAN_DRIVER_PRIORITY_HIGH, - .probe = resolvconf_probe, + .priority = CONNMAN_RESOLVER_PRIORITY_DEFAULT, + .append = resolvconf_append, .remove = resolvconf_remove, }; static int resolvconf_init(void) { - return connman_driver_register(&resolvconf_driver); + return connman_resolver_register(&resolvconf_resolver); } static void resolvconf_exit(void) { - connman_driver_unregister(&resolvconf_driver); + connman_resolver_unregister(&resolvconf_resolver); } -CONNMAN_PLUGIN_DEFINE("resolvconf", "Name resolver plugin", VERSION, - resolvconf_init, resolvconf_exit) +CONNMAN_PLUGIN_DEFINE(resolvconf, "Name resolver plugin", VERSION, + CONNMAN_PLUGIN_PRIORITY_DEFAULT, resolvconf_init, resolvconf_exit)