diff options
| author | Tobias Brunner <tobias@strongswan.org> | 2013-03-02 15:57:00 +0100 |
|---|---|---|
| committer | Tobias Brunner <tobias@strongswan.org> | 2013-03-02 18:27:23 +0100 |
| commit | 9804fccea383ca708eca871ef9f2af4e77594b64 (patch) | |
| tree | 84c6c00a00ebbdcac6034bb6444a7dbb0a492c86 /src/libcharon/plugins/android_dns | |
| parent | b038c62e4a5092a44deb36b725061e6d02ddd8b1 (diff) | |
| download | strongswan-9804fccea383ca708eca871ef9f2af4e77594b64.tar.bz2 strongswan-9804fccea383ca708eca871ef9f2af4e77594b64.tar.xz | |
Removed backend for old Android frontend patch
Moved the remaining DNS handler to a new plugin.
Diffstat (limited to 'src/libcharon/plugins/android_dns')
5 files changed, 421 insertions, 0 deletions
diff --git a/src/libcharon/plugins/android_dns/Makefile.am b/src/libcharon/plugins/android_dns/Makefile.am new file mode 100644 index 000000000..0d25f11d7 --- /dev/null +++ b/src/libcharon/plugins/android_dns/Makefile.am @@ -0,0 +1,18 @@ + +INCLUDES = -I$(top_srcdir)/src/libstrongswan -I$(top_srcdir)/src/libhydra \ + -I$(top_srcdir)/src/libcharon + +AM_CFLAGS = -rdynamic + +if MONOLITHIC +noinst_LTLIBRARIES = libstrongswan-android-dns.la +else +plugin_LTLIBRARIES = libstrongswan-android-dns.la +endif + +libstrongswan_android_dns_la_SOURCES = \ + android_dns_plugin.c android_dns_plugin.h \ + android_dns_handler.c android_dns_handler.h + +libstrongswan_android_dns_la_LDFLAGS = -module -avoid-version +libstrongswan_android_dns_la_LIBADD = -lcutils
\ No newline at end of file diff --git a/src/libcharon/plugins/android_dns/android_dns_handler.c b/src/libcharon/plugins/android_dns/android_dns_handler.c new file mode 100644 index 000000000..526810355 --- /dev/null +++ b/src/libcharon/plugins/android_dns/android_dns_handler.c @@ -0,0 +1,235 @@ +/* + * Copyright (C) 2010-2013 Tobias Brunner + * Copyright (C) 2010 Martin Willi + * Hochschule fuer Technik Rapperswil + * + * This program is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License as published by the + * Free Software Foundation; either version 2 of the License, or (at your + * option) any later version. See <http://www.fsf.org/copyleft/gpl.txt>. + * + * This program is distributed in the hope that it will be useful, but + * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY + * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * for more details. + */ + +#include "android_dns_handler.h" + +#include <networking/host.h> +#include <collections/linked_list.h> + +#include <cutils/properties.h> + +typedef struct private_android_dns_handler_t private_android_dns_handler_t; + +/** + * Private data of an android_dns_handler_t object. + */ +struct private_android_dns_handler_t { + + /** + * Public interface + */ + android_dns_handler_t public; + + /** + * List of registered DNS servers + */ + linked_list_t *dns; +}; + +/** + * Prefix to be used when installing DNS servers + */ +#define DNS_PREFIX_DEFAULT "net" + +/** + * Struct to store a pair of old and installed DNS servers + */ +typedef struct { + /** installed dns server */ + host_t *dns; + /** old dns server */ + host_t *old; +} dns_pair_t; + +/** + * Destroy a pair of old and installed DNS servers + */ +static void destroy_dns_pair(dns_pair_t *this) +{ + DESTROY_IF(this->dns); + DESTROY_IF(this->old); + free(this); +} + +/** + * Filter pairs of DNS servers + */ +static bool filter_dns_pair(void *data, dns_pair_t **in, host_t **out) +{ + *out = (*in)->dns; + return TRUE; +} + +/** + * Read DNS server property with a given index + */ +static host_t *get_dns_server(private_android_dns_handler_t *this, int index) +{ + host_t *dns = NULL; + char key[10], value[PROPERTY_VALUE_MAX], + *prefix = DNS_PREFIX_DEFAULT; + + if (snprintf(key, sizeof(key), "%s.dns%d", prefix, index) >= sizeof(key)) + { + return NULL; + } + + if (property_get(key, value, NULL) > 0) + { + dns = host_create_from_string(value, 0); + } + return dns; +} + +/** + * Set DNS server property with a given index + */ +static bool set_dns_server(private_android_dns_handler_t *this, int index, + host_t *dns) +{ + char key[10], value[PROPERTY_VALUE_MAX], + *prefix = DNS_PREFIX_DEFAULT; + + if (snprintf(key, sizeof(key), "%s.dns%d", prefix, index) >= sizeof(key)) + { + return FALSE; + } + + if (dns) + { + if (snprintf(value, sizeof(value), "%H", dns) >= sizeof(value)) + { + return FALSE; + } + } + else + { + value[0] = '\0'; + } + + if (property_set(key, value) != 0) + { + return FALSE; + } + return TRUE; +} + +METHOD(attribute_handler_t, handle, bool, + private_android_dns_handler_t *this, identification_t *id, + configuration_attribute_type_t type, chunk_t data) +{ + switch (type) + { + case INTERNAL_IP4_DNS: + { + host_t *dns; + dns_pair_t *pair; + int index; + + dns = host_create_from_chunk(AF_INET, data, 0); + if (dns) + { + pair = malloc_thing(dns_pair_t); + pair->dns = dns; + index = this->dns->get_count(this->dns) + 1; + pair->old = get_dns_server(this, index); + set_dns_server(this, index, dns); + this->dns->insert_last(this->dns, pair); + return TRUE; + } + return FALSE; + } + default: + return FALSE; + } +} + +METHOD(attribute_handler_t, release, void, + private_android_dns_handler_t *this, identification_t *server, + configuration_attribute_type_t type, chunk_t data) +{ + if (type == INTERNAL_IP4_DNS) + { + enumerator_t *enumerator; + dns_pair_t *pair; + int index; + + enumerator = this->dns->create_enumerator(this->dns); + for (index = 1; enumerator->enumerate(enumerator, &pair); index++) + { + if (chunk_equals(pair->dns->get_address(pair->dns), data)) + { + this->dns->remove_at(this->dns, enumerator); + set_dns_server(this, index, pair->old); + destroy_dns_pair(pair); + } + } + enumerator->destroy(enumerator); + } +} + +METHOD(enumerator_t, enumerate_dns, bool, + enumerator_t *this, configuration_attribute_type_t *type, chunk_t *data) +{ + *type = INTERNAL_IP4_DNS; + *data = chunk_empty; + /* stop enumeration */ + this->enumerate = (void*)return_false; + return TRUE; +} + +METHOD(attribute_handler_t, create_attribute_enumerator, enumerator_t *, + private_android_dns_handler_t *this, identification_t *id, + linked_list_t *vips) +{ + enumerator_t *enumerator; + + INIT(enumerator, + .enumerate = (void*)_enumerate_dns, + .destroy = (void*)free, + ); + return enumerator; +} + +METHOD(android_dns_handler_t, destroy, void, + private_android_dns_handler_t *this) +{ + this->dns->destroy_function(this->dns, (void*)destroy_dns_pair); + free(this); +} + +/** + * See header + */ +android_dns_handler_t *android_dns_handler_create() +{ + private_android_dns_handler_t *this; + + INIT(this, + .public = { + .handler = { + .handle = _handle, + .release = _release, + .create_attribute_enumerator = _create_attribute_enumerator, + }, + .destroy = _destroy, + }, + .dns = linked_list_create(), + ); + + return &this->public; +} + diff --git a/src/libcharon/plugins/android_dns/android_dns_handler.h b/src/libcharon/plugins/android_dns/android_dns_handler.h new file mode 100644 index 000000000..d7b089dca --- /dev/null +++ b/src/libcharon/plugins/android_dns/android_dns_handler.h @@ -0,0 +1,50 @@ +/* + * Copyright (C) 2010-2011 Tobias Brunner + * Copyright (C) 2010 Martin Willi + * Hochschule fuer Technik Rapperswil + * + * This program is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License as published by the + * Free Software Foundation; either version 2 of the License, or (at your + * option) any later version. See <http://www.fsf.org/copyleft/gpl.txt>. + * + * This program is distributed in the hope that it will be useful, but + * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY + * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * for more details. + */ + +/** + * @defgroup android_dns_handler android_dns_handler + * @{ @ingroup android_dns + */ + +#ifndef ANDROID_DNS_HANDLER_H_ +#define ANDROID_DNS_HANDLER_H_ + +#include <attributes/attribute_handler.h> + +typedef struct android_dns_handler_t android_dns_handler_t; + +/** + * Android specific DNS attribute handler. + */ +struct android_dns_handler_t { + + /** + * Implements attribute_handler_t. + */ + attribute_handler_t handler; + + /** + * Destroy a android_dns_handler_t. + */ + void (*destroy)(android_dns_handler_t *this); +}; + +/** + * Create an android_dns_handler_t instance. + */ +android_dns_handler_t *android_dns_handler_create(); + +#endif /** ANDROID_DNS_HANDLER_H_ @}*/ diff --git a/src/libcharon/plugins/android_dns/android_dns_plugin.c b/src/libcharon/plugins/android_dns/android_dns_plugin.c new file mode 100644 index 000000000..4e2b5f58b --- /dev/null +++ b/src/libcharon/plugins/android_dns/android_dns_plugin.c @@ -0,0 +1,76 @@ +/* + * Copyright (C) 2010-2013 Tobias Brunner + * Hochschule fuer Technik Rapperswil + * + * This program is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License as published by the + * Free Software Foundation; either version 2 of the License, or (at your + * option) any later version. See <http://www.fsf.org/copyleft/gpl.txt>. + * + * This program is distributed in the hope that it will be useful, but + * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY + * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * for more details. + */ + +#include "android_dns_plugin.h" +#include "android_dns_handler.h" + +#include <hydra.h> +#include <daemon.h> + +typedef struct private_android_dns_plugin_t private_android_dns_plugin_t; + +/** + * Private data of an android_dns_plugin_t object. + */ +struct private_android_dns_plugin_t { + + /** + * Public interface + */ + android_dns_plugin_t public; + + /** + * Android specific DNS handler + */ + android_dns_handler_t *handler; +}; + +METHOD(plugin_t, get_name, char*, + private_android_dns_plugin_t *this) +{ + return "android-dns"; +} + +METHOD(plugin_t, destroy, void, + private_android_dns_plugin_t *this) +{ + hydra->attributes->remove_handler(hydra->attributes, + &this->handler->handler); + this->handler->destroy(this->handler); + free(this); +} + +/** + * See header + */ +plugin_t *android_dns_plugin_create() +{ + private_android_dns_plugin_t *this; + + INIT(this, + .public = { + .plugin = { + .get_name = _get_name, + .reload = (void*)return_false, + .destroy = _destroy, + }, + }, + .handler = android_dns_handler_create(), + ); + + hydra->attributes->add_handler(hydra->attributes, &this->handler->handler); + + return &this->public.plugin; +} diff --git a/src/libcharon/plugins/android_dns/android_dns_plugin.h b/src/libcharon/plugins/android_dns/android_dns_plugin.h new file mode 100644 index 000000000..e9e57dc24 --- /dev/null +++ b/src/libcharon/plugins/android_dns/android_dns_plugin.h @@ -0,0 +1,42 @@ +/* + * Copyright (C) 2013 Tobias Brunner + * Hochschule fuer Technik Rapperswil + * + * This program is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License as published by the + * Free Software Foundation; either version 2 of the License, or (at your + * option) any later version. See <http://www.fsf.org/copyleft/gpl.txt>. + * + * This program is distributed in the hope that it will be useful, but + * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY + * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * for more details. + */ + +/** + * @defgroup android_dns android_dns + * @ingroup cplugins + * + * @defgroup android_dns_plugin android_dns_plugin + * @{ @ingroup android_dns + */ + +#ifndef ANDROID_DNS_PLUGIN_H_ +#define ANDROID_DNS_PLUGIN_H_ + +#include <plugins/plugin.h> + +typedef struct android_dns_plugin_t android_dns_plugin_t; + +/** + * Plugin providing an Android-specific handler for DNS servers. + */ +struct android_dns_plugin_t { + + /** + * Implements plugin interface. + */ + plugin_t plugin; +}; + +#endif /** ANDROID_DNS_PLUGIN_H_ @}*/ |
