#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>
}
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;
{
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;
}
/**
/* TODO-IKEv1: agressive mode */
return FAILED;
case QUICK_MODE:
+ if (this->ike_sa->get_state(this->ike_sa) != IKE_ESTABLISHED)
+ {
+ DBG1(DBG_IKE, "received quick mode request for "
+ "unestablished IKE_SA, ignored");
+ return FAILED;
+ }
task = (task_t *)quick_mode_create(this->ike_sa, NULL,
NULL, NULL);
this->passive_tasks->insert_last(this->passive_tasks, task);
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: