aboutsummaryrefslogtreecommitdiffstats
path: root/Source/charon/ike_sa.c
diff options
context:
space:
mode:
Diffstat (limited to 'Source/charon/ike_sa.c')
-rw-r--r--Source/charon/ike_sa.c196
1 files changed, 151 insertions, 45 deletions
diff --git a/Source/charon/ike_sa.c b/Source/charon/ike_sa.c
index 5e5ca2249..9a133814b 100644
--- a/Source/charon/ike_sa.c
+++ b/Source/charon/ike_sa.c
@@ -25,10 +25,12 @@
#include "types.h"
#include "globals.h"
+#include "definitions.h"
#include "utils/allocator.h"
#include "utils/linked_list.h"
#include "utils/logger_manager.h"
#include "utils/randomizer.h"
+#include "transforms/diffie_hellman.h"
#include "payloads/sa_payload.h"
#include "payloads/nonce_payload.h"
#include "payloads/ke_payload.h"
@@ -72,6 +74,18 @@ enum ike_sa_state_e {
IKE_SA_INITIALIZED = 5
};
+/**
+ * string mappings for ike_sa_state
+ */
+mapping_t ike_sa_state_m[] = {
+ {NO_STATE, "NO_STATE"},
+ {IKE_SA_INIT_REQUESTED, "IKE_SA_INIT_REQUESTED"},
+ {IKE_SA_INIT_RESPONDED, "IKE_SA_INIT_RESPONDED"},
+ {IKE_AUTH_REQUESTED, "IKE_AUTH_REQUESTED"},
+ {IKE_SA_INITIALIZED, "IKE_SA_INITIALIZED"},
+ {MAPPING_END, NULL}
+};
+
/**
* Private data of an message_t object
@@ -88,6 +102,9 @@ struct private_ike_sa_s {
status_t (*build_sa_payload) (private_ike_sa_t *this, sa_payload_t **payload);
status_t (*build_nonce_payload) (private_ike_sa_t *this, nonce_payload_t **payload);
status_t (*build_ke_payload) (private_ike_sa_t *this, ke_payload_t **payload);
+
+ status_t (*transto_ike_sa_init_responded) (private_ike_sa_t *this, message_t *message);
+ status_t (*transto_ike_auth_requested) (private_ike_sa_t *this, message_t *message);
/* Private values */
/**
@@ -103,7 +120,7 @@ struct private_ike_sa_s {
/**
* Current state of the IKE_SA
*/
- ike_sa_state_t current_state;
+ ike_sa_state_t state;
/**
* is this IKE_SA the original initiator of this IKE_SA
@@ -125,6 +142,8 @@ struct private_ike_sa_s {
host_t *host;
} other;
+ diffie_hellman_t *diffie_hellman;
+
/**
* a logger for this IKE_SA
*/
@@ -135,54 +154,136 @@ struct private_ike_sa_s {
* @brief implements function process_message of private_ike_sa_t
*/
static status_t process_message (private_ike_sa_t *this, message_t *message)
+{
+ this->logger->log(this->logger, CONTROL|MORE, "Process message of exchange type %s",
+ mapping_find(exchange_type_m,message->get_exchange_type(message)));
+
+ switch (message->get_exchange_type(message))
+ {
+ case IKE_SA_INIT:
+ {
+ if (message->get_request(message)) {
+ if (this->state == NO_STATE)
+ {
+ /* state transission NO_STATE => IKE_SA_INIT_RESPONDED */
+ return this->transto_ike_sa_init_responded(this, message);
+ }
+ }
+ else
+ {
+ if (this->state == IKE_SA_INIT_REQUESTED)
+ {
+ /* state transission IKE_SA_INIT_REQUESTED => IKE_AUTH_REQUESTED*/
+ return this->transto_ike_auth_requested(this, message);
+ }
+ }
+ break;
+ }
+ case IKE_AUTH:
+ {
+ /* break; */
+ }
+ case CREATE_CHILD_SA:
+ {
+ /* break; */
+ }
+ case INFORMATIONAL:
+ {
+ /* break; */
+ }
+ default:
+ {
+ this->logger->log(this->logger, ERROR, "processing %s-message not supported.",
+ mapping_find(exchange_type_m,message->get_exchange_type(message)));
+ return NOT_SUPPORTED;
+ }
+ }
+ this->logger->log(this->logger, ERROR, "received %s-message in state %s, rejected.",
+ mapping_find(exchange_type_m, message->get_exchange_type(message)),
+ mapping_find(ike_sa_state_m, this->state));
+ return INVALID_STATE;
+}
+
+
+static status_t transto_ike_sa_init_responded(private_ike_sa_t *this, message_t *message)
{
status_t status;
- /* @TODO Add Message Processing here */
+ linked_list_iterator_t *payloads;
- this->logger->log(this->logger, CONTROL|MORE, "Process message of exchange type %s",mapping_find(exchange_type_m,message->get_exchange_type(message)));
-
- /* parse body */
status = message->parse_body(message);
- switch (status)
+ if (status != SUCCESS)
{
- case SUCCESS:
- {
- break;
- }
- default:
- {
- this->logger->log(this->logger, ERROR, "Error of type %s while parsing message body",mapping_find(status_m,status));
- switch (this->current_state)
- {
- case NO_STATE:
- {
- job_t *delete_job;
- /* create delete job for this ike_sa */
- delete_job = (job_t *) delete_ike_sa_job_create(this->ike_sa_id);
- if (delete_job == NULL)
- {
- this->logger->log(this->logger, ERROR, "Job to delete IKE SA could not be created");
- }
-
- status = global_job_queue->add(global_job_queue,delete_job);
- if (status != SUCCESS)
- {
- this->logger->log(this->logger, ERROR, "%s Job to delete IKE SA could not be added to job queue",mapping_find(status_m,status));
- delete_job->destroy_all(delete_job);
- }
-
- }
- default:
- {
- break;
- }
- }
-
- return FAILED;
- }
+ return status;
+ }
+
+ status = message->get_payload_iterator(message, &payloads);
+ if (status != SUCCESS)
+ {
+ return status;
}
-
- return status;
+ while (payloads->has_next(payloads))
+ {
+ payload_t *payload;
+ payloads->current(payloads, (void**)payload);
+ switch (payload->get_type(payload))
+ {
+ case SECURITY_ASSOCIATION:
+ {
+ sa_payload_t *sa_payload;
+ linked_list_iterator_t *proposals;
+
+ sa_payload = (sa_payload_t*)payload;
+ status = sa_payload->create_proposal_substructure_iterator(sa_payload, &proposals, TRUE);
+ if (status != SUCCESS)
+ {
+ payloads->destroy(payloads);
+ return status;
+ }
+ //global_configuration_manager->select_prop
+
+ break;
+ }
+ case KEY_EXCHANGE:
+ {
+ break;
+ }
+ case NONCE:
+ {
+ break;
+ }
+ default:
+ {
+
+ }
+
+ }
+
+ }
+
+
+
+
+
+ /*
+ job_t *delete_job;
+ delete_job = (job_t *) delete_ike_sa_job_create(this->ike_sa_id);
+ if (delete_job == NULL)
+ {
+ this->logger->log(this->logger, ERROR, "Job to delete IKE SA could not be created");
+ }
+
+ status = global_job_queue->add(global_job_queue,delete_job);
+ if (status != SUCCESS)
+ {
+ this->logger->log(this->logger, ERROR, "%s Job to delete IKE SA could not be added to job queue",mapping_find(status_m,status));
+ delete_job->destroy_all(delete_job);
+ }*/
+ return SUCCESS;
+}
+
+static status_t transto_ike_auth_requested(private_ike_sa_t *this, message_t *message)
+{
+ return SUCCESS;
}
/**
@@ -271,7 +372,7 @@ static status_t initialize_connection(private_ike_sa_t *this, char *name)
message->destroy(message);
- this->current_state = IKE_SA_INIT_REQUESTED;
+ this->state = IKE_SA_INIT_REQUESTED;
return SUCCESS;
}
@@ -425,6 +526,10 @@ ike_sa_t * ike_sa_create(ike_sa_id_t *ike_sa_id)
this->build_sa_payload = build_sa_payload;
this->build_ke_payload = build_ke_payload;
this->build_nonce_payload = build_nonce_payload;
+
+
+ this->transto_ike_sa_init_responded = transto_ike_sa_init_responded;
+ this->transto_ike_auth_requested = transto_ike_auth_requested;
@@ -468,10 +573,11 @@ ike_sa_t * ike_sa_create(ike_sa_id_t *ike_sa_id)
this->me.host = NULL;
this->other.host = NULL;
+ this->diffie_hellman = NULL;
/* at creation time, IKE_SA isn't in a specific state */
- this->current_state = NO_STATE;
+ this->state = NO_STATE;
return (&this->public);
}