diff options
author | Martin Willi <martin@revosec.ch> | 2011-12-19 14:39:05 +0100 |
---|---|---|
committer | Martin Willi <martin@revosec.ch> | 2012-03-20 17:31:27 +0100 |
commit | cedb412e5a823907b9f3ea2ac0821cecb41f9699 (patch) | |
tree | 04f2ca604f8f1e547d469b1bcd9879b4457f25cf /src | |
parent | dab60d6411ad97299cd9271232ecbc929e38315c (diff) | |
download | strongswan-cedb412e5a823907b9f3ea2ac0821cecb41f9699.tar.bz2 strongswan-cedb412e5a823907b9f3ea2ac0821cecb41f9699.tar.xz |
Moved IKE_SA reauth task creation to protocol specific task manager
Diffstat (limited to 'src')
-rw-r--r-- | src/libcharon/sa/ike_sa.c | 6 | ||||
-rw-r--r-- | src/libcharon/sa/ikev1/task_manager_v1.c | 7 | ||||
-rw-r--r-- | src/libcharon/sa/ikev2/task_manager_v2.c | 8 | ||||
-rw-r--r-- | src/libcharon/sa/task_manager.h | 5 |
4 files changed, 21 insertions, 5 deletions
diff --git a/src/libcharon/sa/ike_sa.c b/src/libcharon/sa/ike_sa.c index 7e2fccdb3..d3aad94df 100644 --- a/src/libcharon/sa/ike_sa.c +++ b/src/libcharon/sa/ike_sa.c @@ -1332,8 +1332,6 @@ METHOD(ike_sa_t, rekey, status_t, METHOD(ike_sa_t, reauth, status_t, private_ike_sa_t *this) { - task_t *task; - /* we can't reauthenticate as responder when we use EAP or virtual IPs. * If the peer does not support RFC4478, there is no way to keep the * IKE_SA up. */ @@ -1359,9 +1357,7 @@ METHOD(ike_sa_t, reauth, status_t, DBG1(DBG_IKE, "reauthenticating actively"); } } - task = (task_t*)ike_reauth_create(&this->public); - this->task_manager->queue_task(this->task_manager, task); - + this->task_manager->queue_ike_reauth(this->task_manager); return this->task_manager->initiate(this->task_manager); } diff --git a/src/libcharon/sa/ikev1/task_manager_v1.c b/src/libcharon/sa/ikev1/task_manager_v1.c index f135d0262..d23b237fa 100644 --- a/src/libcharon/sa/ikev1/task_manager_v1.c +++ b/src/libcharon/sa/ikev1/task_manager_v1.c @@ -1029,6 +1029,12 @@ METHOD(task_manager_t, queue_ike_rekey, void, /* TODO-IKEv1: IKE_SA rekeying */ } +METHOD(task_manager_t, queue_ike_reauth, void, + private_task_manager_t *this) +{ + /* TODO-IKEv1: IKE_SA reauth */ +} + METHOD(task_manager_t, queue_ike_delete, void, private_task_manager_t *this) { @@ -1139,6 +1145,7 @@ task_manager_v1_t *task_manager_v1_create(ike_sa_t *ike_sa) .queue_task = _queue_task, .queue_ike = _queue_ike, .queue_ike_rekey = _queue_ike_rekey, + .queue_ike_reauth = _queue_ike_reauth, .queue_ike_delete = _queue_ike_delete, .queue_child = _queue_child, .queue_child_rekey = _queue_child_rekey, diff --git a/src/libcharon/sa/ikev2/task_manager_v2.c b/src/libcharon/sa/ikev2/task_manager_v2.c index fd9572d92..f2cfad2a1 100644 --- a/src/libcharon/sa/ikev2/task_manager_v2.c +++ b/src/libcharon/sa/ikev2/task_manager_v2.c @@ -27,6 +27,7 @@ #include <sa/ikev2/tasks/ike_cert_pre.h> #include <sa/ikev2/tasks/ike_cert_post.h> #include <sa/ikev2/tasks/ike_rekey.h> +#include <sa/ikev2/tasks/ike_reauth.h> #include <sa/ikev2/tasks/ike_delete.h> #include <sa/ikev2/tasks/ike_config.h> #include <sa/ikev2/tasks/ike_dpd.h> @@ -1206,6 +1207,12 @@ METHOD(task_manager_t, queue_ike_rekey, void, queue_task(this, (task_t*)ike_rekey_create(this->ike_sa, TRUE)); } +METHOD(task_manager_t, queue_ike_reauth, void, + private_task_manager_t *this) +{ + queue_task(this, (task_t*)ike_reauth_create(this->ike_sa)); +} + METHOD(task_manager_t, queue_ike_delete, void, private_task_manager_t *this) { @@ -1364,6 +1371,7 @@ task_manager_v2_t *task_manager_v2_create(ike_sa_t *ike_sa) .queue_task = _queue_task, .queue_ike = _queue_ike, .queue_ike_rekey = _queue_ike_rekey, + .queue_ike_reauth = _queue_ike_reauth, .queue_ike_delete = _queue_ike_delete, .queue_child = _queue_child, .queue_child_rekey = _queue_child_rekey, diff --git a/src/libcharon/sa/task_manager.h b/src/libcharon/sa/task_manager.h index 6ea48fa1c..4087265c7 100644 --- a/src/libcharon/sa/task_manager.h +++ b/src/libcharon/sa/task_manager.h @@ -135,6 +135,11 @@ struct task_manager_t { void (*queue_ike_rekey)(task_manager_t *this); /** + * Queue IKE_SA reauth tasks. + */ + void (*queue_ike_reauth)(task_manager_t *this); + + /** * Queue IKE_SA delete tasks. */ void (*queue_ike_delete)(task_manager_t *this); |