aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorMartin Willi <martin@revosec.ch>2011-12-09 16:19:37 +0100
committerMartin Willi <martin@revosec.ch>2012-03-20 17:31:16 +0100
commit156b8662a64a4e251470de1e42213bc66f8e772e (patch)
tree3cd8f4e7f4c329ac22e68a1d281a79a629808083 /src
parentb155084c42277a4a72f2b90997b6c5d32708aef3 (diff)
downloadstrongswan-156b8662a64a4e251470de1e42213bc66f8e772e.tar.bz2
strongswan-156b8662a64a4e251470de1e42213bc66f8e772e.tar.xz
Queue Mode Config tasks when required
Diffstat (limited to 'src')
-rwxr-xr-xsrc/libcharon/sa/task_manager_v1.c30
-rwxr-xr-xsrc/libcharon/sa/tasks/main_mode.c7
2 files changed, 27 insertions, 10 deletions
diff --git a/src/libcharon/sa/task_manager_v1.c b/src/libcharon/sa/task_manager_v1.c
index 7fda51eeb..e899b0687 100755
--- a/src/libcharon/sa/task_manager_v1.c
+++ b/src/libcharon/sa/task_manager_v1.c
@@ -23,6 +23,7 @@
#include <sa/tasks/main_mode.h>
#include <sa/tasks/quick_mode.h>
#include <sa/tasks/xauth.h>
+#include <sa/tasks/mode_config.h>
#include <sa/tasks/ike_delete.h>
#include <sa/tasks/ike_natd_v1.h>
#include <sa/tasks/ike_vendor_v1.h>
@@ -287,6 +288,12 @@ METHOD(task_manager_t, initiate, status_t,
}
break;
case IKE_ESTABLISHED:
+ if (activate_task(this, TASK_MODE_CONFIG))
+ {
+ exchange = TRANSACTION;
+ new_mid = TRUE;
+ break;
+ }
if (activate_task(this, TASK_QUICK_MODE))
{
exchange = QUICK_MODE;
@@ -400,15 +407,11 @@ METHOD(task_manager_t, initiate, status_t,
{
return retransmit(this, this->initiating.seqnr);
}
- else
- {
- charon->sender->send(charon->sender,
- this->initiating.packet->clone(this->initiating.packet));
-
- this->initiating.packet->destroy(this->initiating.packet);
- this->initiating.packet = NULL;
- return SUCCESS;
- }
+ charon->sender->send(charon->sender,
+ this->initiating.packet->clone(this->initiating.packet));
+ this->initiating.packet->destroy(this->initiating.packet);
+ this->initiating.packet = NULL;
+ return SUCCESS;
}
/**
@@ -654,7 +657,14 @@ static status_t process_request(private_task_manager_t *this,
enumerator->destroy(enumerator);
break;
case TRANSACTION:
- task = (task_t *)xauth_create(this->ike_sa, FALSE);
+ if (this->ike_sa->get_state(this->ike_sa) == IKE_ESTABLISHED)
+ {
+ task = (task_t *)mode_config_create(this->ike_sa, FALSE);
+ }
+ else
+ {
+ task = (task_t *)xauth_create(this->ike_sa, FALSE);
+ }
this->passive_tasks->insert_last(this->passive_tasks, task);
break;
default:
diff --git a/src/libcharon/sa/tasks/main_mode.c b/src/libcharon/sa/tasks/main_mode.c
index d31458b07..cea0631fe 100755
--- a/src/libcharon/sa/tasks/main_mode.c
+++ b/src/libcharon/sa/tasks/main_mode.c
@@ -29,6 +29,7 @@
#include <encoding/payloads/id_payload.h>
#include <encoding/payloads/hash_payload.h>
#include <sa/tasks/xauth.h>
+#include <sa/tasks/mode_config.h>
typedef struct private_main_mode_t private_main_mode_t;
@@ -824,6 +825,12 @@ METHOD(task_t, build_r, status_t,
return FAILED;
}
+ if (this->peer_cfg->get_virtual_ip(this->peer_cfg))
+ {
+ this->ike_sa->queue_task(this->ike_sa,
+ (task_t*)mode_config_create(this->ike_sa, TRUE));
+ }
+
switch (this->auth_method)
{
case AUTH_XAUTH_INIT_PSK: