aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorMartin Willi <martin@revosec.ch>2011-12-19 14:29:57 +0100
committerMartin Willi <martin@revosec.ch>2012-03-20 17:31:27 +0100
commit3ed148b37e0159fd93a75fa033a699c8e0f09f0f (patch)
treee42765db26a62c78259c6bccf555bee01e69e122 /src
parent83c5fda053005668a35c675fd9f458a8b54d4bc8 (diff)
downloadstrongswan-3ed148b37e0159fd93a75fa033a699c8e0f09f0f.tar.bz2
strongswan-3ed148b37e0159fd93a75fa033a699c8e0f09f0f.tar.xz
Moved IKE_SA delete task creation to protocol specific task manager
Diffstat (limited to 'src')
-rw-r--r--src/libcharon/sa/ike_sa.c12
-rw-r--r--src/libcharon/sa/ikev1/task_manager_v1.c8
-rw-r--r--src/libcharon/sa/ikev2/task_manager_v2.c7
-rw-r--r--src/libcharon/sa/task_manager.h5
4 files changed, 21 insertions, 11 deletions
diff --git a/src/libcharon/sa/ike_sa.c b/src/libcharon/sa/ike_sa.c
index d3465acef..474703056 100644
--- a/src/libcharon/sa/ike_sa.c
+++ b/src/libcharon/sa/ike_sa.c
@@ -1302,21 +1302,11 @@ METHOD(ike_sa_t, destroy_child_sa, status_t,
METHOD(ike_sa_t, delete_, status_t,
private_ike_sa_t *this)
{
- task_t *task;
-
switch (this->state)
{
case IKE_ESTABLISHED:
case IKE_REKEYING:
- if (this->version == IKEV1)
- {
- task = (task_t*)isakmp_delete_create(&this->public, TRUE);
- }
- else
- {
- task = (task_t*)ike_delete_create(&this->public, TRUE);
- }
- this->task_manager->queue_task(this->task_manager, task);
+ this->task_manager->queue_ike_delete(this->task_manager);
return this->task_manager->initiate(this->task_manager);
case IKE_CREATED:
DBG1(DBG_IKE, "deleting unestablished IKE_SA");
diff --git a/src/libcharon/sa/ikev1/task_manager_v1.c b/src/libcharon/sa/ikev1/task_manager_v1.c
index 82c5c31bc..012890afa 100644
--- a/src/libcharon/sa/ikev1/task_manager_v1.c
+++ b/src/libcharon/sa/ikev1/task_manager_v1.c
@@ -29,6 +29,7 @@
#include <sa/ikev1/tasks/isakmp_vendor.h>
#include <sa/ikev1/tasks/isakmp_cert_pre.h>
#include <sa/ikev1/tasks/isakmp_cert_post.h>
+#include <sa/ikev1/tasks/isakmp_delete.h>
#include <processing/jobs/retransmit_job.h>
#include <processing/jobs/delete_ike_sa_job.h>
@@ -1022,6 +1023,12 @@ METHOD(task_manager_t, queue_ike, void,
queue_task(this, (task_t*)isakmp_natd_create(this->ike_sa, TRUE));
}
+METHOD(task_manager_t, queue_ike_delete, void,
+ private_task_manager_t *this)
+{
+ queue_task(this, (task_t*)isakmp_delete_create(this->ike_sa, TRUE));
+}
+
METHOD(task_manager_t, queue_child, void,
private_task_manager_t *this, child_cfg_t *cfg, u_int32_t reqid,
traffic_selector_t *tsi, traffic_selector_t *tsr)
@@ -1125,6 +1132,7 @@ task_manager_v1_t *task_manager_v1_create(ike_sa_t *ike_sa)
.process_message = _process_message,
.queue_task = _queue_task,
.queue_ike = _queue_ike,
+ .queue_ike_delete = _queue_ike_delete,
.queue_child = _queue_child,
.queue_child_rekey = _queue_child_rekey,
.queue_child_delete = _queue_child_delete,
diff --git a/src/libcharon/sa/ikev2/task_manager_v2.c b/src/libcharon/sa/ikev2/task_manager_v2.c
index ee2d536fe..5aa96cc4e 100644
--- a/src/libcharon/sa/ikev2/task_manager_v2.c
+++ b/src/libcharon/sa/ikev2/task_manager_v2.c
@@ -1200,6 +1200,12 @@ METHOD(task_manager_t, queue_ike, void,
#endif /* ME */
}
+METHOD(task_manager_t, queue_ike_delete, void,
+ private_task_manager_t *this)
+{
+ queue_task(this, (task_t*)ike_delete_create(this->ike_sa, TRUE));
+}
+
METHOD(task_manager_t, queue_child, void,
private_task_manager_t *this, child_cfg_t *cfg, u_int32_t reqid,
traffic_selector_t *tsi, traffic_selector_t *tsr)
@@ -1351,6 +1357,7 @@ task_manager_v2_t *task_manager_v2_create(ike_sa_t *ike_sa)
.process_message = _process_message,
.queue_task = _queue_task,
.queue_ike = _queue_ike,
+ .queue_ike_delete = _queue_ike_delete,
.queue_child = _queue_child,
.queue_child_rekey = _queue_child_rekey,
.queue_child_delete = _queue_child_delete,
diff --git a/src/libcharon/sa/task_manager.h b/src/libcharon/sa/task_manager.h
index cfec427e4..eeccb1aab 100644
--- a/src/libcharon/sa/task_manager.h
+++ b/src/libcharon/sa/task_manager.h
@@ -130,6 +130,11 @@ struct task_manager_t {
void (*queue_ike)(task_manager_t *this);
/**
+ * Queue IKE_SA delete tasks.
+ */
+ void (*queue_ike_delete)(task_manager_t *this);
+
+ /**
* Queue CHILD_SA establishing tasks.
*
* @param cfg CHILD_SA config to establish