diff options
author | Martin Willi <martin@revosec.ch> | 2011-12-19 14:25:14 +0100 |
---|---|---|
committer | Martin Willi <martin@revosec.ch> | 2012-03-20 17:31:27 +0100 |
commit | 83c5fda053005668a35c675fd9f458a8b54d4bc8 (patch) | |
tree | 8254c7d47df9555f278df345da85ae6236bb81d5 /src | |
parent | 463a73cc0f152d5abcf1855826fdaf06441f273e (diff) | |
download | strongswan-83c5fda053005668a35c675fd9f458a8b54d4bc8.tar.bz2 strongswan-83c5fda053005668a35c675fd9f458a8b54d4bc8.tar.xz |
Moved CHILD_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 | 9 | ||||
-rw-r--r-- | src/libcharon/sa/ikev2/task_manager_v2.c | 7 | ||||
-rw-r--r-- | src/libcharon/sa/task_manager.h | 9 |
4 files changed, 26 insertions, 11 deletions
diff --git a/src/libcharon/sa/ike_sa.c b/src/libcharon/sa/ike_sa.c index 7026608f0..d3465acef 100644 --- a/src/libcharon/sa/ike_sa.c +++ b/src/libcharon/sa/ike_sa.c @@ -1272,17 +1272,7 @@ METHOD(ike_sa_t, rekey_child_sa, status_t, METHOD(ike_sa_t, delete_child_sa, status_t, private_ike_sa_t *this, protocol_id_t protocol, u_int32_t spi) { - task_t *task; - - if (this->version == IKEV1) - { - task = (task_t*)quick_delete_create(&this->public, protocol, spi, FALSE); - } - else - { - task = (task_t*)child_delete_create(&this->public, protocol, spi); - } - this->task_manager->queue_task(this->task_manager, task); + this->task_manager->queue_child_delete(this->task_manager, protocol, spi); 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 a4509e69c..82c5c31bc 100644 --- a/src/libcharon/sa/ikev1/task_manager_v1.c +++ b/src/libcharon/sa/ikev1/task_manager_v1.c @@ -21,6 +21,7 @@ #include <daemon.h> #include <sa/ikev1/tasks/main_mode.h> #include <sa/ikev1/tasks/quick_mode.h> +#include <sa/ikev1/tasks/quick_delete.h> #include <sa/ikev1/tasks/xauth.h> #include <sa/ikev1/tasks/mode_config.h> #include <sa/ikev1/tasks/informational.h> @@ -1034,6 +1035,13 @@ METHOD(task_manager_t, queue_child_rekey, void, /* TODO-IKEv1: CHILD rekeying */ } +METHOD(task_manager_t, queue_child_delete, void, + private_task_manager_t *this, protocol_id_t protocol, u_int32_t spi) +{ + queue_task(this, (task_t*)quick_delete_create(this->ike_sa, protocol, + spi, FALSE)); +} + METHOD(task_manager_t, queue_dpd, void, private_task_manager_t *this) { @@ -1119,6 +1127,7 @@ task_manager_v1_t *task_manager_v1_create(ike_sa_t *ike_sa) .queue_ike = _queue_ike, .queue_child = _queue_child, .queue_child_rekey = _queue_child_rekey, + .queue_child_delete = _queue_child_delete, .queue_dpd = _queue_dpd, .initiate = _initiate, .retransmit = _retransmit, diff --git a/src/libcharon/sa/ikev2/task_manager_v2.c b/src/libcharon/sa/ikev2/task_manager_v2.c index d8dc9b8c3..ee2d536fe 100644 --- a/src/libcharon/sa/ikev2/task_manager_v2.c +++ b/src/libcharon/sa/ikev2/task_manager_v2.c @@ -1220,6 +1220,12 @@ METHOD(task_manager_t, queue_child_rekey, void, queue_task(this, (task_t*)child_rekey_create(this->ike_sa, protocol, spi)); } +METHOD(task_manager_t, queue_child_delete, void, + private_task_manager_t *this, protocol_id_t protocol, u_int32_t spi) +{ + queue_task(this, (task_t*)child_delete_create(this->ike_sa, protocol, spi)); +} + METHOD(task_manager_t, queue_dpd, void, private_task_manager_t *this) { @@ -1347,6 +1353,7 @@ task_manager_v2_t *task_manager_v2_create(ike_sa_t *ike_sa) .queue_ike = _queue_ike, .queue_child = _queue_child, .queue_child_rekey = _queue_child_rekey, + .queue_child_delete = _queue_child_delete, .queue_dpd = _queue_dpd, .initiate = _initiate, .retransmit = _retransmit, diff --git a/src/libcharon/sa/task_manager.h b/src/libcharon/sa/task_manager.h index e2e797c3f..cfec427e4 100644 --- a/src/libcharon/sa/task_manager.h +++ b/src/libcharon/sa/task_manager.h @@ -150,6 +150,15 @@ struct task_manager_t { u_int32_t spi); /** + * Queue CHILD_SA delete tasks. + * + * @param protocol CHILD_SA protocol, AH|ESP + * @param spi CHILD_SA SPI to rekey + */ + void (*queue_child_delete)(task_manager_t *this, protocol_id_t protocol, + u_int32_t spi); + + /** * Queue liveness checking tasks. */ void (*queue_dpd)(task_manager_t *this); |