diff options
author | Martin Willi <martin@revosec.ch> | 2011-12-19 14:29:57 +0100 |
---|---|---|
committer | Martin Willi <martin@revosec.ch> | 2012-03-20 17:31:27 +0100 |
commit | 3ed148b37e0159fd93a75fa033a699c8e0f09f0f (patch) | |
tree | e42765db26a62c78259c6bccf555bee01e69e122 /src | |
parent | 83c5fda053005668a35c675fd9f458a8b54d4bc8 (diff) | |
download | strongswan-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.c | 12 | ||||
-rw-r--r-- | src/libcharon/sa/ikev1/task_manager_v1.c | 8 | ||||
-rw-r--r-- | src/libcharon/sa/ikev2/task_manager_v2.c | 7 | ||||
-rw-r--r-- | src/libcharon/sa/task_manager.h | 5 |
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 |