aboutsummaryrefslogtreecommitdiffstats
path: root/src/libcharon/plugins/eap_radius/eap_radius_plugin.c
diff options
context:
space:
mode:
authorMartin Willi <martin@revosec.ch>2012-02-24 16:41:10 +0100
committerMartin Willi <martin@revosec.ch>2012-03-05 18:06:15 +0100
commit99cb35396883c9eab3a872a3e4ec60cc3a7db884 (patch)
tree3157c39899232734da9d1acaa29e2503a29a4d0d /src/libcharon/plugins/eap_radius/eap_radius_plugin.c
parent007d5b92183803f79f336cf48853f7784fac963b (diff)
downloadstrongswan-99cb35396883c9eab3a872a3e4ec60cc3a7db884.tar.bz2
strongswan-99cb35396883c9eab3a872a3e4ec60cc3a7db884.tar.xz
Forward specifcied RADIUS attributes between AAA backend and client
Diffstat (limited to 'src/libcharon/plugins/eap_radius/eap_radius_plugin.c')
-rw-r--r--src/libcharon/plugins/eap_radius/eap_radius_plugin.c16
1 files changed, 16 insertions, 0 deletions
diff --git a/src/libcharon/plugins/eap_radius/eap_radius_plugin.c b/src/libcharon/plugins/eap_radius/eap_radius_plugin.c
index 62b53e5ac..e544aaf3e 100644
--- a/src/libcharon/plugins/eap_radius/eap_radius_plugin.c
+++ b/src/libcharon/plugins/eap_radius/eap_radius_plugin.c
@@ -18,6 +18,7 @@
#include "eap_radius.h"
#include "eap_radius_accounting.h"
#include "eap_radius_dae.h"
+#include "eap_radius_forward.h"
#include "radius_client.h"
#include "radius_server.h"
@@ -65,6 +66,11 @@ struct private_eap_radius_plugin_t {
* Dynamic authorization extensions
*/
eap_radius_dae_t *dae;
+
+ /**
+ * RADIUS <-> IKE attribute forwarding
+ */
+ eap_radius_forward_t *forward;
};
/**
@@ -194,6 +200,11 @@ METHOD(plugin_t, reload, bool,
METHOD(plugin_t, destroy, void,
private_eap_radius_plugin_t *this)
{
+ if (this->forward)
+ {
+ charon->bus->remove_listener(charon->bus, &this->forward->listener);
+ this->forward->destroy(this->forward);
+ }
DESTROY_IF(this->dae);
this->servers->destroy_offset(this->servers,
offsetof(radius_server_t, destroy));
@@ -223,6 +234,7 @@ plugin_t *eap_radius_plugin_create()
.servers = linked_list_create(),
.lock = rwlock_create(RWLOCK_TYPE_DEFAULT),
.accounting = eap_radius_accounting_create(),
+ .forward = eap_radius_forward_create(),
);
load_servers(this);
@@ -238,6 +250,10 @@ plugin_t *eap_radius_plugin_create()
{
this->dae = eap_radius_dae_create(this->accounting);
}
+ if (this->forward)
+ {
+ charon->bus->add_listener(charon->bus, &this->forward->listener);
+ }
return &this->public.plugin;
}