aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorMartin Willi <martin@revosec.ch>2011-12-19 14:39:05 +0100
committerMartin Willi <martin@revosec.ch>2012-03-20 17:31:27 +0100
commitcedb412e5a823907b9f3ea2ac0821cecb41f9699 (patch)
tree04f2ca604f8f1e547d469b1bcd9879b4457f25cf /src
parentdab60d6411ad97299cd9271232ecbc929e38315c (diff)
downloadstrongswan-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.c6
-rw-r--r--src/libcharon/sa/ikev1/task_manager_v1.c7
-rw-r--r--src/libcharon/sa/ikev2/task_manager_v2.c8
-rw-r--r--src/libcharon/sa/task_manager.h5
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);