From dab60d6411ad97299cd9271232ecbc929e38315c Mon Sep 17 00:00:00 2001 From: Martin Willi Date: Mon, 19 Dec 2011 14:35:14 +0100 Subject: [PATCH] Moved IKE_SA rekey task creation to protocol specific task manager --- src/libcharon/sa/ike_sa.c | 6 +----- src/libcharon/sa/ikev1/task_manager_v1.c | 7 +++++++ src/libcharon/sa/ikev2/task_manager_v2.c | 7 +++++++ src/libcharon/sa/task_manager.h | 5 +++++ 4 files changed, 20 insertions(+), 5 deletions(-) diff --git a/src/libcharon/sa/ike_sa.c b/src/libcharon/sa/ike_sa.c index 474703056..7e2fccdb3 100644 --- a/src/libcharon/sa/ike_sa.c +++ b/src/libcharon/sa/ike_sa.c @@ -1325,11 +1325,7 @@ METHOD(ike_sa_t, delete_, status_t, METHOD(ike_sa_t, rekey, status_t, private_ike_sa_t *this) { - ike_rekey_t *ike_rekey; - - ike_rekey = ike_rekey_create(&this->public, TRUE); - - this->task_manager->queue_task(this->task_manager, &ike_rekey->task); + this->task_manager->queue_ike_rekey(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 012890afa..f135d0262 100644 --- a/src/libcharon/sa/ikev1/task_manager_v1.c +++ b/src/libcharon/sa/ikev1/task_manager_v1.c @@ -1023,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_rekey, void, + private_task_manager_t *this) +{ + /* TODO-IKEv1: IKE_SA rekeying */ +} + METHOD(task_manager_t, queue_ike_delete, void, private_task_manager_t *this) { @@ -1132,6 +1138,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_rekey = _queue_ike_rekey, .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 5aa96cc4e..fd9572d92 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_rekey, void, + private_task_manager_t *this) +{ + queue_task(this, (task_t*)ike_rekey_create(this->ike_sa, TRUE)); +} + METHOD(task_manager_t, queue_ike_delete, void, private_task_manager_t *this) { @@ -1357,6 +1363,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_rekey = _queue_ike_rekey, .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 eeccb1aab..6ea48fa1c 100644 --- a/src/libcharon/sa/task_manager.h +++ b/src/libcharon/sa/task_manager.h @@ -129,6 +129,11 @@ struct task_manager_t { */ void (*queue_ike)(task_manager_t *this); + /** + * Queue IKE_SA rekey tasks. + */ + void (*queue_ike_rekey)(task_manager_t *this); + /** * Queue IKE_SA delete tasks. */