aboutsummaryrefslogtreecommitdiffstats
path: root/Source/charon/config
diff options
context:
space:
mode:
Diffstat (limited to 'Source/charon/config')
-rw-r--r--Source/charon/config/Makefile.config4
-rw-r--r--Source/charon/config/configuration_manager.c85
-rw-r--r--Source/charon/config/init_config.c167
-rw-r--r--Source/charon/config/init_config.h120
-rw-r--r--Source/charon/config/proposal.c (renamed from Source/charon/config/child_proposal.c)78
-rw-r--r--Source/charon/config/proposal.h (renamed from Source/charon/config/child_proposal.h)42
-rw-r--r--Source/charon/config/sa_config.c12
-rw-r--r--Source/charon/config/sa_config.h6
8 files changed, 241 insertions, 273 deletions
diff --git a/Source/charon/config/Makefile.config b/Source/charon/config/Makefile.config
index 7ca46d14f..7189d404b 100644
--- a/Source/charon/config/Makefile.config
+++ b/Source/charon/config/Makefile.config
@@ -31,6 +31,6 @@ OBJS+= $(BUILD_DIR)traffic_selector.o
$(BUILD_DIR)traffic_selector.o : $(CONFIG_DIR)traffic_selector.c $(CONFIG_DIR)traffic_selector.h
$(CC) $(CFLAGS) -c -o $@ $<
-OBJS+= $(BUILD_DIR)child_proposal.o
-$(BUILD_DIR)child_proposal.o : $(CONFIG_DIR)child_proposal.c $(CONFIG_DIR)child_proposal.h
+OBJS+= $(BUILD_DIR)proposal.o
+$(BUILD_DIR)proposal.o : $(CONFIG_DIR)proposal.c $(CONFIG_DIR)proposal.h
$(CC) $(CFLAGS) -c -o $@ $<
diff --git a/Source/charon/config/configuration_manager.c b/Source/charon/config/configuration_manager.c
index ed5c33d26..adbd0ddee 100644
--- a/Source/charon/config/configuration_manager.c
+++ b/Source/charon/config/configuration_manager.c
@@ -275,27 +275,32 @@ u_int8_t private_key_2[];
static void load_default_config (private_configuration_manager_t *this)
{
init_config_t *init_config_a, *init_config_b;
- ike_proposal_t proposals;
- child_proposal_t *child_proposal;
+ proposal_t *proposal;
sa_config_t *sa_config_a, *sa_config_b;
traffic_selector_t *ts;
init_config_a = init_config_create("0.0.0.0","192.168.0.3",IKEV2_UDP_PORT,IKEV2_UDP_PORT);
init_config_b = init_config_create("0.0.0.0","192.168.0.2",IKEV2_UDP_PORT,IKEV2_UDP_PORT);
- ts = traffic_selector_create_from_string(1, TS_IPV4_ADDR_RANGE, "0.0.0.0", 0, "255.255.255.255", 65535);
-
- proposals.encryption_algorithm = ENCR_AES_CBC;
- proposals.encryption_algorithm_key_length = 16;
- proposals.integrity_algorithm = AUTH_HMAC_MD5_96;
- proposals.integrity_algorithm_key_length = 16;
- proposals.pseudo_random_function = PRF_HMAC_MD5;
- proposals.pseudo_random_function_key_length = 16;
- proposals.diffie_hellman_group = MODP_1024_BIT;
-
- init_config_a->add_proposal(init_config_a,1,proposals);
- init_config_b->add_proposal(init_config_b,1,proposals);
-
+ /* IKE proposals for alice */
+ proposal = proposal_create(1);
+ proposal->add_algorithm(proposal, IKE, ENCRYPTION_ALGORITHM, ENCR_AES_CBC, 16);
+ POS;
+ proposal->add_algorithm(proposal, IKE, INTEGRITY_ALGORITHM, AUTH_HMAC_MD5_96, 16);
+ POS;
+ proposal->add_algorithm(proposal, IKE, PSEUDO_RANDOM_FUNCTION, PRF_HMAC_MD5, 16);
+ proposal->add_algorithm(proposal, IKE, DIFFIE_HELLMAN_GROUP, MODP_1024_BIT, 0);
+ proposal->add_algorithm(proposal, IKE, DIFFIE_HELLMAN_GROUP, MODP_2048_BIT, 0);
+ init_config_a->add_proposal(init_config_a, proposal);
+
+ /* IKE proposals for bob */
+ proposal = proposal_create(1);
+ proposal->add_algorithm(proposal, IKE, ENCRYPTION_ALGORITHM, ENCR_AES_CBC, 16);
+ proposal->add_algorithm(proposal, IKE, INTEGRITY_ALGORITHM, AUTH_HMAC_MD5_96, 16);
+ proposal->add_algorithm(proposal, IKE, PSEUDO_RANDOM_FUNCTION, PRF_HMAC_MD5, 16);
+ proposal->add_algorithm(proposal, IKE, DIFFIE_HELLMAN_GROUP, MODP_2048_BIT, 0);
+ init_config_b->add_proposal(init_config_b, proposal);
+
sa_config_a = sa_config_create(ID_IPV4_ADDR, "192.168.0.2",
ID_IPV4_ADDR, "192.168.0.3",
RSA_DIGITAL_SIGNATURE,
@@ -305,46 +310,46 @@ static void load_default_config (private_configuration_manager_t *this)
ID_IPV4_ADDR, "192.168.0.2",
RSA_DIGITAL_SIGNATURE,
30000);
-
+
+ /* traffic selectors */
+ ts = traffic_selector_create_from_string(1, TS_IPV4_ADDR_RANGE, "0.0.0.0", 0, "255.255.255.255", 65535);
sa_config_a->add_traffic_selector_initiator(sa_config_a,ts);
sa_config_a->add_traffic_selector_responder(sa_config_a,ts);
-
sa_config_b->add_traffic_selector_initiator(sa_config_b,ts);
sa_config_b->add_traffic_selector_responder(sa_config_b,ts);
-
ts->destroy(ts);
/* child proposal for alice */
- child_proposal = child_proposal_create(1);
+ proposal = proposal_create(1);
- child_proposal->add_algorithm(child_proposal, AH, INTEGRITY_ALGORITHM, AUTH_HMAC_SHA1_96, 20);
- child_proposal->add_algorithm(child_proposal, AH, INTEGRITY_ALGORITHM, AUTH_HMAC_MD5_96, 20);
- child_proposal->add_algorithm(child_proposal, AH, DIFFIE_HELLMAN_GROUP, MODP_1024_BIT, 0);
- child_proposal->add_algorithm(child_proposal, AH, DIFFIE_HELLMAN_GROUP, MODP_2048_BIT, 0);
- child_proposal->add_algorithm(child_proposal, AH, EXTENDED_SEQUENCE_NUMBERS, NO_EXT_SEQ_NUMBERS, 0);
+ proposal->add_algorithm(proposal, AH, INTEGRITY_ALGORITHM, AUTH_HMAC_SHA1_96, 20);
+ proposal->add_algorithm(proposal, AH, INTEGRITY_ALGORITHM, AUTH_HMAC_MD5_96, 20);
+ proposal->add_algorithm(proposal, AH, DIFFIE_HELLMAN_GROUP, MODP_1024_BIT, 0);
+ proposal->add_algorithm(proposal, AH, DIFFIE_HELLMAN_GROUP, MODP_2048_BIT, 0);
+ proposal->add_algorithm(proposal, AH, EXTENDED_SEQUENCE_NUMBERS, NO_EXT_SEQ_NUMBERS, 0);
- child_proposal->add_algorithm(child_proposal, ESP, ENCRYPTION_ALGORITHM, ENCR_AES_CBC, 16);
- child_proposal->add_algorithm(child_proposal, ESP, ENCRYPTION_ALGORITHM, ENCR_3DES, 32);
- child_proposal->add_algorithm(child_proposal, ESP, INTEGRITY_ALGORITHM, AUTH_HMAC_MD5_96, 20);
- child_proposal->add_algorithm(child_proposal, ESP, INTEGRITY_ALGORITHM, AUTH_HMAC_SHA1_96, 20);
- child_proposal->add_algorithm(child_proposal, ESP, DIFFIE_HELLMAN_GROUP, MODP_1024_BIT, 0);
- child_proposal->add_algorithm(child_proposal, ESP, EXTENDED_SEQUENCE_NUMBERS, NO_EXT_SEQ_NUMBERS, 0);
+ proposal->add_algorithm(proposal, ESP, ENCRYPTION_ALGORITHM, ENCR_AES_CBC, 16);
+ proposal->add_algorithm(proposal, ESP, ENCRYPTION_ALGORITHM, ENCR_3DES, 32);
+ proposal->add_algorithm(proposal, ESP, INTEGRITY_ALGORITHM, AUTH_HMAC_MD5_96, 20);
+ proposal->add_algorithm(proposal, ESP, INTEGRITY_ALGORITHM, AUTH_HMAC_SHA1_96, 20);
+ proposal->add_algorithm(proposal, ESP, DIFFIE_HELLMAN_GROUP, MODP_1024_BIT, 0);
+ proposal->add_algorithm(proposal, ESP, EXTENDED_SEQUENCE_NUMBERS, NO_EXT_SEQ_NUMBERS, 0);
- sa_config_a->add_proposal(sa_config_a, child_proposal);
+ sa_config_a->add_proposal(sa_config_a, proposal);
/* child proposal for bob */
- child_proposal = child_proposal_create(1);
+ proposal = proposal_create(1);
- child_proposal->add_algorithm(child_proposal, AH, INTEGRITY_ALGORITHM, AUTH_HMAC_SHA1_96, 20);
- child_proposal->add_algorithm(child_proposal, AH, DIFFIE_HELLMAN_GROUP, MODP_1024_BIT, 0);
- child_proposal->add_algorithm(child_proposal, AH, EXTENDED_SEQUENCE_NUMBERS, NO_EXT_SEQ_NUMBERS, 0);
+ proposal->add_algorithm(proposal, AH, INTEGRITY_ALGORITHM, AUTH_HMAC_SHA1_96, 20);
+ proposal->add_algorithm(proposal, AH, DIFFIE_HELLMAN_GROUP, MODP_1024_BIT, 0);
+ proposal->add_algorithm(proposal, AH, EXTENDED_SEQUENCE_NUMBERS, NO_EXT_SEQ_NUMBERS, 0);
- child_proposal->add_algorithm(child_proposal, ESP, ENCRYPTION_ALGORITHM, ENCR_AES_CBC, 16);
- child_proposal->add_algorithm(child_proposal, ESP, INTEGRITY_ALGORITHM, AUTH_HMAC_MD5_96, 20);
- child_proposal->add_algorithm(child_proposal, ESP, DIFFIE_HELLMAN_GROUP, MODP_1024_BIT, 0);
- child_proposal->add_algorithm(child_proposal, ESP, EXTENDED_SEQUENCE_NUMBERS, NO_EXT_SEQ_NUMBERS, 0);
+ proposal->add_algorithm(proposal, ESP, ENCRYPTION_ALGORITHM, ENCR_AES_CBC, 16);
+ proposal->add_algorithm(proposal, ESP, INTEGRITY_ALGORITHM, AUTH_HMAC_MD5_96, 20);
+ proposal->add_algorithm(proposal, ESP, DIFFIE_HELLMAN_GROUP, MODP_1024_BIT, 0);
+ proposal->add_algorithm(proposal, ESP, EXTENDED_SEQUENCE_NUMBERS, NO_EXT_SEQ_NUMBERS, 0);
- sa_config_b->add_proposal(sa_config_b, child_proposal);
+ sa_config_b->add_proposal(sa_config_b, proposal);
diff --git a/Source/charon/config/init_config.c b/Source/charon/config/init_config.c
index 27f669b9d..92871dd3b 100644
--- a/Source/charon/config/init_config.c
+++ b/Source/charon/config/init_config.c
@@ -87,108 +87,111 @@ static host_t * get_other_host_clone (private_init_config_t *this)
}
/**
- * Implementation of init_config_t.get_dh_group_number.
+ * Implementation of init_config_t.get_proposals.
*/
-static diffie_hellman_group_t get_dh_group_number (private_init_config_t *this,size_t priority)
+static linked_list_t* get_proposals (private_init_config_t *this)
{
- ike_proposal_t *ike_proposal;
-
- if ((this->proposals->get_count(this->proposals) == 0) || (this->proposals->get_count(this->proposals) < priority))
- {
- return MODP_UNDEFINED;
- }
-
- this->proposals->get_at_position(this->proposals,(priority -1),(void **) &ike_proposal);
-
- return (ike_proposal->diffie_hellman_group);
+ return this->proposals;
}
-
+
/**
- * Implementation of init_config_t.get_proposals.
+ * Implementation of init_config_t.select_proposal.
*/
-static size_t get_proposals (private_init_config_t *this,ike_proposal_t **proposals)
+static proposal_t *select_proposal(private_init_config_t *this, linked_list_t *proposals)
{
- iterator_t *iterator;
- ike_proposal_t *current_proposal;
- int i = 0;
- ike_proposal_t *proposal_array;
+ iterator_t *stored_iter, *supplied_iter;
+ proposal_t *stored, *supplied, *selected;
- proposal_array = allocator_alloc(this->proposals->get_count(this->proposals) * sizeof(ike_proposal_t));
-
- iterator = this->proposals->create_iterator(this->proposals,TRUE);
+ stored_iter = this->proposals->create_iterator(this->proposals, TRUE);
+ supplied_iter = proposals->create_iterator(proposals, TRUE);
- while (iterator->has_next(iterator))
+ /* compare all stored proposals with all supplied. Stored ones are preferred. */
+ while (stored_iter->has_next(stored_iter))
{
- iterator->current(iterator,(void **) &current_proposal);
- proposal_array[i] = (*current_proposal);
- i++;
+ supplied_iter->reset(supplied_iter);
+ stored_iter->current(stored_iter, (void**)&stored);
+
+ while (supplied_iter->has_next(supplied_iter))
+ {
+ supplied_iter->current(supplied_iter, (void**)&supplied);
+ selected = stored->select(stored, supplied);
+ if (selected)
+ {
+ /* they match, return */
+ stored_iter->destroy(stored_iter);
+ supplied_iter->destroy(supplied_iter);
+ return selected;
+ }
+ }
}
- iterator->destroy(iterator);
- *proposals = proposal_array;
- return this->proposals->get_count(this->proposals);
-}
+ /* no proposal match :-(, will result in a NO_PROPOSAL_CHOSEN... */
+ stored_iter->destroy(stored_iter);
+ supplied_iter->destroy(supplied_iter);
+ return NULL;
+}
+
/**
- * Implementation of init_config_t.select_proposal.
+ * Implementation of init_config_t.add_proposal.
*/
-static status_t select_proposal (private_init_config_t *this, ike_proposal_t *proposals, size_t proposal_count, ike_proposal_t *selected_proposal)
+static void add_proposal (private_init_config_t *this, proposal_t *proposal)
{
- iterator_t * my_iterator;
- int i;
- ike_proposal_t *my_current_proposal;
-
- my_iterator = this->proposals->create_iterator(this->proposals,TRUE);
+ this->proposals->insert_last(this->proposals, proposal);
+}
+/**
+ * Implementation of init_config_t.get_dh_group.
+ */
+static diffie_hellman_group_t get_dh_group(private_init_config_t *this)
+{
+ iterator_t *iterator;
+ proposal_t *proposal;
+ algorithm_t *algo;
- for (i = 0; i < proposal_count; i++)
+ iterator = this->proposals->create_iterator(this->proposals, TRUE);
+ while (iterator->has_next(iterator))
{
- my_iterator->reset(my_iterator);
- while (my_iterator->has_next(my_iterator))
+ iterator->current(iterator, (void**)&proposal);
+ proposal->get_algorithm(proposal, IKE, DIFFIE_HELLMAN_GROUP, &algo);
+ if (algo)
{
- my_iterator->current(my_iterator,(void **) &my_current_proposal);
-
- /* memcmp doesn't work here */
- if ((proposals[i].encryption_algorithm == my_current_proposal->encryption_algorithm) &&
- (proposals[i].encryption_algorithm_key_length == my_current_proposal->encryption_algorithm_key_length) &&
- (proposals[i].integrity_algorithm == my_current_proposal->integrity_algorithm) &&
- (proposals[i].integrity_algorithm_key_length == my_current_proposal->integrity_algorithm_key_length) &&
- (proposals[i].pseudo_random_function == my_current_proposal->pseudo_random_function) &&
- (proposals[i].pseudo_random_function_key_length == my_current_proposal->pseudo_random_function_key_length) &&
- (proposals[i].diffie_hellman_group == my_current_proposal->diffie_hellman_group))
- {
- /* found a matching proposal */
- *selected_proposal = *my_current_proposal;
- my_iterator->destroy(my_iterator);
- return SUCCESS;
- }
-
- }
+ iterator->destroy(iterator);
+ return algo->algorithm;
+ }
}
-
- my_iterator->destroy(my_iterator);
- return NOT_FOUND;
+ iterator->destroy(iterator);
+ return MODP_UNDEFINED;
}
/**
- * Implementation of init_config_t.destroy.
+ * Implementation of init_config_t.check_dh_group.
*/
-static void add_proposal (private_init_config_t *this,size_t priority, ike_proposal_t proposal)
+static bool check_dh_group(private_init_config_t *this, diffie_hellman_group_t dh_group)
{
- ike_proposal_t * new_proposal = allocator_alloc(sizeof(ike_proposal_t));
- status_t status;
-
- *new_proposal = proposal;
-
+ iterator_t *prop_iter, *alg_iter;
+ proposal_t *proposal;
+ algorithm_t *algo;
- if (priority > this->proposals->get_count(this->proposals))
+ prop_iter = this->proposals->create_iterator(this->proposals, TRUE);
+ while (prop_iter->has_next(prop_iter))
{
- this->proposals->insert_last(this->proposals,new_proposal);
- return;
+ prop_iter->current(prop_iter, (void**)&proposal);
+ alg_iter = proposal->create_algorithm_iterator(proposal, IKE, DIFFIE_HELLMAN_GROUP);
+ while (alg_iter->has_next(alg_iter))
+ {
+ alg_iter->current(alg_iter, (void**)&algo);
+ if (algo->algorithm == dh_group)
+ {
+ prop_iter->destroy(prop_iter);
+ alg_iter->destroy(alg_iter);
+ return TRUE;
+ }
+ }
}
-
- status = this->proposals->insert_at_position(this->proposals,(priority - 1),new_proposal);
-
+ prop_iter->destroy(prop_iter);
+ alg_iter->destroy(alg_iter);
+ return FALSE;
}
/**
@@ -196,12 +199,11 @@ static void add_proposal (private_init_config_t *this,size_t priority, ike_propo
*/
static void destroy (private_init_config_t *this)
{
- ike_proposal_t *proposal;
+ proposal_t *proposal;
- while (this->proposals->get_count(this->proposals) > 0)
+ while (this->proposals->remove_last(this->proposals, (void**)&proposal) == SUCCESS)
{
- this->proposals->remove_first(this->proposals,(void **) &proposal);
- allocator_free(proposal);
+ proposal->destroy(proposal);
}
this->proposals->destroy(this->proposals);
@@ -222,10 +224,11 @@ init_config_t * init_config_create(char * my_ip, char *other_ip, u_int16_t my_po
this->public.get_other_host = (host_t*(*)(init_config_t*))get_other_host;
this->public.get_my_host_clone = (host_t*(*)(init_config_t*))get_my_host_clone;
this->public.get_other_host_clone = (host_t*(*)(init_config_t*))get_other_host_clone;
- this->public.get_dh_group_number = (diffie_hellman_group_t (*)(init_config_t*,size_t))get_dh_group_number;
- this->public.get_proposals = (size_t(*)(init_config_t*,ike_proposal_t**))get_proposals;
- this->public.select_proposal = (status_t(*)(init_config_t*,ike_proposal_t*,size_t,ike_proposal_t*))select_proposal;
- this->public.add_proposal = (void(*)(init_config_t*, size_t, ike_proposal_t)) add_proposal;
+ this->public.get_proposals = (linked_list_t*(*)(init_config_t*))get_proposals;
+ this->public.select_proposal = (proposal_t*(*)(init_config_t*,linked_list_t*))select_proposal;
+ this->public.add_proposal = (void(*)(init_config_t*, proposal_t*)) add_proposal;
+ this->public.get_dh_group = (diffie_hellman_group_t(*)(init_config_t*)) get_dh_group;
+ this->public.check_dh_group = (bool(*)(init_config_t*,diffie_hellman_group_t)) check_dh_group;
this->public.destroy = (void(*)(init_config_t*))destroy;
/* private variables */
diff --git a/Source/charon/config/init_config.h b/Source/charon/config/init_config.h
index 14ffeeee8..f63df61cf 100644
--- a/Source/charon/config/init_config.h
+++ b/Source/charon/config/init_config.h
@@ -25,60 +25,14 @@
#include <types.h>
#include <network/host.h>
-#include <utils/iterator.h>
+#include <utils/linked_list.h>
+#include <config/proposal.h>
#include <transforms/crypters/crypter.h>
#include <transforms/prfs/prf.h>
#include <transforms/signers/signer.h>
#include <transforms/diffie_hellman.h>
-typedef struct ike_proposal_t ike_proposal_t;
-
-/**
- * @brief Represents a Proposal used in IKE_SA_INIT phase.
- *
- * @todo Currently the amount of tranforms with same type in a IKE proposal is limited to 1.
- * Support of more transforms with same type has to be added.
- *
- * @ingroup config
- */
-struct ike_proposal_t {
- /**
- * Encryption algorithm.
- */
- encryption_algorithm_t encryption_algorithm;
-
- /**
- * Key length of encryption algorithm in bytes.
- */
- u_int16_t encryption_algorithm_key_length;
-
- /**
- * Integrity algorithm.
- */
- integrity_algorithm_t integrity_algorithm;
-
- /**
- * Key length of integrity algorithm.
- */
- u_int16_t integrity_algorithm_key_length;
-
- /**
- * Pseudo random function (prf).
- */
- pseudo_random_function_t pseudo_random_function;
-
- /**
- * Key length of prf.
- */
- u_int16_t pseudo_random_function_key_length;
-
- /**
- * Diffie hellman group.
- */
- diffie_hellman_group_t diffie_hellman_group;
-};
-
typedef struct init_config_t init_config_t;
@@ -100,7 +54,7 @@ struct init_config_t {
* @param this calling object
* @return host information as host_t object
*/
- host_t * (*get_my_host) (init_config_t *this);
+ host_t *(*get_my_host) (init_config_t *this);
/**
* @brief Get other host information as host_t object.
@@ -110,7 +64,7 @@ struct init_config_t {
* @param this calling object
* @return host information as host_t object
*/
- host_t * (*get_other_host) (init_config_t *this);
+ host_t *(*get_other_host) (init_config_t *this);
/**
* @brief Get my host information as host_t object.
@@ -120,7 +74,7 @@ struct init_config_t {
* @param this calling object
* @return host information as host_t object
*/
- host_t * (*get_my_host_clone) (init_config_t *this);
+ host_t *(*get_my_host_clone) (init_config_t *this);
/**
* @brief Get other host information as host_t object.
@@ -130,54 +84,60 @@ struct init_config_t {
* @param this calling object
* @return host information as host_t object
*/
- host_t * (*get_other_host_clone) (init_config_t *this);
+ host_t *(*get_other_host_clone) (init_config_t *this);
/**
- * @brief Get the diffie hellman group to use as initiator with given priority.
+ * @brief Returns a list of all supported proposals.
*
- * @param this calling object
- * @param priority priority of dh group number (starting at 1)
- * @return diffie hellman group number for given priority or
- * MODP_UNDEFINED for not supported priorities
- */
- diffie_hellman_group_t (*get_dh_group_number) (init_config_t *this,size_t priority);
-
- /**
- * @brief Returns a list of all supported ike_proposals of type ike_proposal_t *.
- *
- * Returned array of ike_proposal_t has to get destroyed by the caller.
+ * Returned list is still owned by init_config and MUST NOT
+ * modified or destroyed.
*
* @param this calling object
- * @param proposals first proposal in a array
- * @return number of proposals in array
+ * @return list containing all the proposals
*/
- size_t (*get_proposals) (init_config_t *this,ike_proposal_t **proposals);
+ linked_list_t *(*get_proposals) (init_config_t *this);
/**
- * @brief Adds a proposal with given priority to the current stored proposals.
+ * @brief Adds a proposal to the list..
*
- * If allready a proposal with given priority is stored the other one is
- * moved one priority back. If priority is higher then all other stored
- * proposals, it is inserted as last one.
+ * The first added proposal has the highest priority, the last
+ * added the lowest.
*
* @param this calling object
* @param priority priority of adding proposal
* @param proposal proposal to add
*/
- void (*add_proposal) (init_config_t *this,size_t priority, ike_proposal_t proposal);
+ void (*add_proposal) (init_config_t *this, proposal_t *proposal);
/**
* @brief Select a proposed from suggested proposals.
*
+ * Returned proposal must be destroyed after usage.
+ *
+ * @param this calling object
+ * @param proposals list of proposals to select from
+ * @return selected proposal, or NULL if none matches.
+ */
+ proposal_t *(*select_proposal) (init_config_t *this, linked_list_t *proposals);
+
+ /**
+ * @brief Get the DH group to use for connection initialization.
+ *
+ * @param this calling object
+ * @return dh group to use for initialization
+ */
+ diffie_hellman_group_t (*get_dh_group) (init_config_t *this);
+
+ /**
+ * @brief Check if a suggested dh group is acceptable.
+ *
+ * If we guess a wrong DH group for IKE_SA_INIT, the other
+ * peer will send us a offer. But is this acceptable for us?
+ *
* @param this calling object
- * @param suggested_proposals first proposal in a array
- * @param proposal_count number of suggested proposals in array
- * @param selected_proposal the ike_proposal_t pointing to is set
- * @return
- * - SUCCESS if a proposal was selected
- * - NOT_FOUND if none of suggested proposals is supported
+ * @return dh group to use for initialization
*/
- status_t (*select_proposal) (init_config_t *this, ike_proposal_t *proposals, size_t proposal_count, ike_proposal_t *selected_proposal);
+ bool (*check_dh_group) (init_config_t *this, diffie_hellman_group_t dh_group);
/**
* @brief Destroys a init_config_t object.
@@ -194,6 +154,6 @@ struct init_config_t {
*
* @ingroup config
*/
-init_config_t * init_config_create(char * my_ip, char *other_ip, u_int16_t my_port, u_int16_t other_port);
+init_config_t * init_config_create(char *my_ip, char *other_ip, u_int16_t my_port, u_int16_t other_port);
#endif //_INIT_CONFIG_H_
diff --git a/Source/charon/config/child_proposal.c b/Source/charon/config/proposal.c
index 729102ebf..528cf9808 100644
--- a/Source/charon/config/child_proposal.c
+++ b/Source/charon/config/proposal.c
@@ -1,7 +1,7 @@
/**
- * @file child_proposal.c
+ * @file proposal.c
*
- * @brief Implementation of child_proposal_t.
+ * @brief Implementation of proposal_t.
*
*/
@@ -20,7 +20,7 @@
* for more details.
*/
-#include "child_proposal.h"
+#include "proposal.h"
#include <utils/linked_list.h>
#include <utils/allocator.h>
@@ -105,17 +105,17 @@ struct protocol_proposal_t {
};
-typedef struct private_child_proposal_t private_child_proposal_t;
+typedef struct private_proposal_t private_proposal_t;
/**
- * Private data of an child_proposal_t object
+ * Private data of an proposal_t object
*/
-struct private_child_proposal_t {
+struct private_proposal_t {
/**
* Public part
*/
- child_proposal_t public;
+ proposal_t public;
/**
* number of this proposal, as used in the payload
@@ -131,7 +131,7 @@ struct private_child_proposal_t {
/**
* Look up a protocol_proposal, or create one if necessary...
*/
-static protocol_proposal_t *get_protocol_proposal(private_child_proposal_t *this, protocol_id_t proto, bool create)
+static protocol_proposal_t *get_protocol_proposal(private_proposal_t *this, protocol_id_t proto, bool create)
{
protocol_proposal_t *proto_proposal = NULL, *current_proto_proposal;;
iterator_t *iterator;
@@ -187,9 +187,9 @@ static void add_algo(linked_list_t *list, u_int8_t algo, size_t key_size)
}
/**
- * Implements child_proposal_t.add_algorithm
+ * Implements proposal_t.add_algorithm
*/
-static void add_algorithm(private_child_proposal_t *this, protocol_id_t proto, transform_type_t type, u_int16_t algo, size_t key_size)
+static void add_algorithm(private_proposal_t *this, protocol_id_t proto, transform_type_t type, u_int16_t algo, size_t key_size)
{
protocol_proposal_t *proto_proposal = get_protocol_proposal(this, proto, TRUE);
@@ -216,9 +216,9 @@ static void add_algorithm(private_child_proposal_t *this, protocol_id_t proto, t
}
/**
- * Implements child_proposal_t.get_algorithm.
+ * Implements proposal_t.get_algorithm.
*/
-static bool get_algorithm(private_child_proposal_t *this, protocol_id_t proto, transform_type_t type, algorithm_t** algo)
+static bool get_algorithm(private_proposal_t *this, protocol_id_t proto, transform_type_t type, algorithm_t** algo)
{
linked_list_t * list;
protocol_proposal_t *proto_proposal = get_protocol_proposal(this, proto, FALSE);
@@ -255,9 +255,9 @@ static bool get_algorithm(private_child_proposal_t *this, protocol_id_t proto, t
}
/**
- * Implements child_proposal_t.create_algorithm_iterator.
+ * Implements proposal_t.create_algorithm_iterator.
*/
-static iterator_t *create_algorithm_iterator(private_child_proposal_t *this, protocol_id_t proto, transform_type_t type)
+static iterator_t *create_algorithm_iterator(private_proposal_t *this, protocol_id_t proto, transform_type_t type)
{
protocol_proposal_t *proto_proposal = get_protocol_proposal(this, proto, FALSE);
if (proto_proposal == NULL)
@@ -328,11 +328,11 @@ static bool select_algo(linked_list_t *first, linked_list_t *second, bool *add,
}
/**
- * Implements child_proposal_t.select.
+ * Implements proposal_t.select.
*/
-static child_proposal_t *select_proposal(private_child_proposal_t *this, private_child_proposal_t *other)
+static proposal_t *select_proposal(private_proposal_t *this, private_proposal_t *other)
{
- child_proposal_t *selected;
+ proposal_t *selected;
u_int16_t algo;
size_t key_size;
iterator_t *iterator;
@@ -353,7 +353,7 @@ static child_proposal_t *select_proposal(private_child_proposal_t *this, private
return NULL;
}
- selected = child_proposal_create(this->number);
+ selected = proposal_create(this->number);
/* iterate over supplied proposals */
iterator = other->protocol_proposals->create_iterator(other->protocol_proposals, TRUE);
@@ -448,17 +448,17 @@ static child_proposal_t *select_proposal(private_child_proposal_t *this, private
}
/**
- * Implements child_proposal_t.get_number.
+ * Implements proposal_t.get_number.
*/
-static u_int8_t get_number(private_child_proposal_t *this)
+static u_int8_t get_number(private_proposal_t *this)
{
return this->number;
}
/**
- * Implements child_proposal_t.get_protocols.
+ * Implements proposal_t.get_protocols.
*/
-static void get_protocols(private_child_proposal_t *this, protocol_id_t ids[2])
+static void get_protocols(private_proposal_t *this, protocol_id_t ids[2])
{
iterator_t *iterator = this->protocol_proposals->create_iterator(this->protocol_proposals, TRUE);
u_int i = 0;
@@ -480,9 +480,9 @@ static void get_protocols(private_child_proposal_t *this, protocol_id_t ids[2])
}
/**
- * Implements child_proposal_t.set_spi.
+ * Implements proposal_t.set_spi.
*/
-static void set_spi(private_child_proposal_t *this, protocol_id_t proto, u_int64_t spi)
+static void set_spi(private_proposal_t *this, protocol_id_t proto, u_int64_t spi)
{
protocol_proposal_t *proto_proposal = get_protocol_proposal(this, proto, FALSE);
if (proto_proposal)
@@ -500,9 +500,9 @@ static void set_spi(private_child_proposal_t *this, protocol_id_t proto, u_int64
}
/**
- * Implements child_proposal_t.get_spi.
+ * Implements proposal_t.get_spi.
*/
-static u_int64_t get_spi(private_child_proposal_t *this, protocol_id_t proto)
+static u_int64_t get_spi(private_proposal_t *this, protocol_id_t proto)
{
protocol_proposal_t *proto_proposal = get_protocol_proposal(this, proto, FALSE);
if (proto_proposal)
@@ -535,9 +535,9 @@ static void free_algo_list(linked_list_t *list)
}
/**
- * Implements child_proposal_t.destroy.
+ * Implements proposal_t.destroy.
*/
-static void destroy(private_child_proposal_t *this)
+static void destroy(private_proposal_t *this)
{
while(this->protocol_proposals->get_count(this->protocol_proposals) > 0)
{
@@ -561,19 +561,19 @@ static void destroy(private_child_proposal_t *this)
/*
* Describtion in header-file
*/
-child_proposal_t *child_proposal_create(u_int8_t number)
+proposal_t *proposal_create(u_int8_t number)
{
- private_child_proposal_t *this = allocator_alloc_thing(private_child_proposal_t);
+ private_proposal_t *this = allocator_alloc_thing(private_proposal_t);
- this->public.add_algorithm = (void (*)(child_proposal_t*,protocol_id_t,transform_type_t,u_int16_t,size_t))add_algorithm;
- this->public.create_algorithm_iterator = (iterator_t* (*)(child_proposal_t*,protocol_id_t,transform_type_t))create_algorithm_iterator;
- this->public.get_algorithm = (bool (*)(child_proposal_t*,protocol_id_t,transform_type_t,algorithm_t**))get_algorithm;
- this->public.select = (child_proposal_t* (*)(child_proposal_t*,child_proposal_t*))select_proposal;
- this->public.get_number = (u_int8_t (*)(child_proposal_t*))get_number;
- this->public.get_protocols = (void(*)(child_proposal_t *this, protocol_id_t ids[2]))get_protocols;
- this->public.set_spi = (void(*)(child_proposal_t*,protocol_id_t,u_int64_t spi))set_spi;
- this->public.get_spi = (u_int64_t(*)(child_proposal_t*,protocol_id_t))get_spi;
- this->public.destroy = (void(*)(child_proposal_t*))destroy;
+ this->public.add_algorithm = (void (*)(proposal_t*,protocol_id_t,transform_type_t,u_int16_t,size_t))add_algorithm;
+ this->public.create_algorithm_iterator = (iterator_t* (*)(proposal_t*,protocol_id_t,transform_type_t))create_algorithm_iterator;
+ this->public.get_algorithm = (bool (*)(proposal_t*,protocol_id_t,transform_type_t,algorithm_t**))get_algorithm;
+ this->public.select = (proposal_t* (*)(proposal_t*,proposal_t*))select_proposal;
+ this->public.get_number = (u_int8_t (*)(proposal_t*))get_number;
+ this->public.get_protocols = (void(*)(proposal_t *this, protocol_id_t ids[2]))get_protocols;
+ this->public.set_spi = (void(*)(proposal_t*,protocol_id_t,u_int64_t spi))set_spi;
+ this->public.get_spi = (u_int64_t(*)(proposal_t*,protocol_id_t))get_spi;
+ this->public.destroy = (void(*)(proposal_t*))destroy;
/* init private members*/
this->number = number;
diff --git a/Source/charon/config/child_proposal.h b/Source/charon/config/proposal.h
index 69bd7f395..53d417bb1 100644
--- a/Source/charon/config/child_proposal.h
+++ b/Source/charon/config/proposal.h
@@ -1,7 +1,7 @@
/**
- * @file child_proposal.h
+ * @file proposal.h
*
- * @brief Interface of child_proposal_t.
+ * @brief Interface of proposal_t.
*
*/
@@ -20,8 +20,8 @@
* for more details.
*/
-#ifndef _CHILD_PROPOSAL_H_
-#define _CHILD_PROPOSAL_H_
+#ifndef _PROPOSAL_H_
+#define _PROPOSAL_H_
#include <types.h>
#include <utils/identification.h>
@@ -117,22 +117,22 @@ struct algorithm_t {
u_int16_t key_size;
};
-typedef struct child_proposal_t child_proposal_t;
+typedef struct proposal_t proposal_t;
/**
* @brief Stores a proposal for a child SA.
*
- * A child_proposal may contain more than one algorithm
+ * A proposal may contain more than one algorithm
* of the same kind. ONE of them can be selected.
*
* @warning This class is NOT thread-save!
*
* @b Constructors:
- * - child_proposal_create()
+ * - proposal_create()
*
* @ingroup config
*/
-struct child_proposal_t {
+struct proposal_t {
/**
* @brief Add an algorithm to the proposal.
@@ -154,7 +154,7 @@ struct child_proposal_t {
* @param alg identifier for algorithm
* @param key_size key size to use
*/
- void (*add_algorithm) (child_proposal_t *this, protocol_id_t proto, transform_type_t type, u_int16_t alg, size_t key_size);
+ void (*add_algorithm) (proposal_t *this, protocol_id_t proto, transform_type_t type, u_int16_t alg, size_t key_size);
/**
* @brief Get an iterator over algorithms for a specifc protocol/algo type.
@@ -164,13 +164,13 @@ struct child_proposal_t {
* @param type kind of algorithm
* @return iterator over algorithms
*/
- iterator_t *(*create_algorithm_iterator) (child_proposal_t *this, protocol_id_t proto, transform_type_t type);
+ iterator_t *(*create_algorithm_iterator) (proposal_t *this, protocol_id_t proto, transform_type_t type);
/**
* @brief Get the algorithm for a type to use.
*
* If there are multiple algorithms, only the first is returned.
- * Result is still owned by child_proposal, do not modify!
+ * Result is still owned by proposal, do not modify!
*
* @param this calling object
* @param proto desired protocol
@@ -178,7 +178,7 @@ struct child_proposal_t {
* @param[out] algo pointer which receives algorithm and key size
* @return TRUE if algorithm of this kind available
*/
- bool (*get_algorithm) (child_proposal_t *this, protocol_id_t proto, transform_type_t type, algorithm_t** algo);
+ bool (*get_algorithm) (proposal_t *this, protocol_id_t proto, transform_type_t type, algorithm_t** algo);
/**
* @brief Compare two proposal, and select a matching subset.
@@ -193,7 +193,7 @@ struct child_proposal_t {
* - selected proposal, if possible
* - NULL, if proposals don't match
*/
- child_proposal_t *(*select) (child_proposal_t *this, child_proposal_t *other);
+ proposal_t *(*select) (proposal_t *this, proposal_t *other);
/**
* @brief Get the number set on construction.
@@ -201,7 +201,7 @@ struct child_proposal_t {
* @param this calling object
* @return number
*/
- u_int8_t (*get_number) (child_proposal_t *this);
+ u_int8_t (*get_number) (proposal_t *this);
/**
* @brief Get the protocol ids in the proposals.
@@ -212,7 +212,7 @@ struct child_proposal_t {
* @param this calling object
* @param ids array of protocol ids,
*/
- void (*get_protocols) (child_proposal_t *this, protocol_id_t ids[2]);
+ void (*get_protocols) (proposal_t *this, protocol_id_t ids[2]);
/**
* @brief Get the spi for a specific protocol.
@@ -221,7 +221,7 @@ struct child_proposal_t {
* @param proto AH/ESP
* @return spi for proto
*/
- u_int64_t (*get_spi) (child_proposal_t *this, protocol_id_t proto);
+ u_int64_t (*get_spi) (proposal_t *this, protocol_id_t proto);
/**
* @brief Set the spi for a specific protocol.
@@ -230,24 +230,24 @@ struct child_proposal_t {
* @param proto AH/ESP
* @param spi spi to set for proto
*/
- void (*set_spi) (child_proposal_t *this, protocol_id_t proto, u_int64_t spi);
+ void (*set_spi) (proposal_t *this, protocol_id_t proto, u_int64_t spi);
/**
* @brief Destroys the proposal object.
*
* @param this calling object
*/
- void (*destroy) (child_proposal_t *this);
+ void (*destroy) (proposal_t *this);
};
/**
* @brief Create a child proposal for AH and/or ESP.
*
* @param number number of the proposal, as in the payload
- * @return child_proposal_t object
+ * @return proposal_t object
*
* @ingroup config
*/
-child_proposal_t *child_proposal_create(u_int8_t number);
+proposal_t *proposal_create(u_int8_t number);
-#endif //_CHILD_PROPOSAL_H_
+#endif //_PROPOSAL_H_
diff --git a/Source/charon/config/sa_config.c b/Source/charon/config/sa_config.c
index ca29b0294..6e7f8ee03 100644
--- a/Source/charon/config/sa_config.c
+++ b/Source/charon/config/sa_config.c
@@ -216,10 +216,10 @@ static linked_list_t *get_proposals(private_sa_config_t *this)
/**
* Implementation of sa_config_t.select_proposal
*/
-static child_proposal_t *select_proposal(private_sa_config_t *this, linked_list_t *proposals)
+static proposal_t *select_proposal(private_sa_config_t *this, linked_list_t *proposals)
{
iterator_t *stored_iter, *supplied_iter;
- child_proposal_t *stored, *supplied, *selected;
+ proposal_t *stored, *supplied, *selected;
stored_iter = this->proposals->create_iterator(this->proposals, TRUE);
supplied_iter = proposals->create_iterator(proposals, TRUE);
@@ -272,7 +272,7 @@ static void add_traffic_selector_responder(private_sa_config_t *this, traffic_se
/**
* Implementation of sa_config_t.add_proposal
*/
-static void add_proposal(private_sa_config_t *this, child_proposal_t *proposal)
+static void add_proposal(private_sa_config_t *this, proposal_t *proposal)
{
this->proposals->insert_last(this->proposals, (void*)proposal);
}
@@ -282,7 +282,7 @@ static void add_proposal(private_sa_config_t *this, child_proposal_t *proposal)
*/
static status_t destroy(private_sa_config_t *this)
{
- child_proposal_t *proposal;
+ proposal_t *proposal;
traffic_selector_t *traffic_selector;
@@ -332,10 +332,10 @@ sa_config_t *sa_config_create(id_type_t my_id_type, char *my_id, id_type_t other
this->public.get_traffic_selectors_responder = (size_t(*)(sa_config_t*,traffic_selector_t**[]))get_traffic_selectors_responder;
this->public.select_traffic_selectors_responder = (size_t(*)(sa_config_t*,traffic_selector_t*[],size_t,traffic_selector_t**[]))select_traffic_selectors_responder;
this->public.get_proposals = (linked_list_t*(*)(sa_config_t*))get_proposals;
- this->public.select_proposal = (child_proposal_t*(*)(sa_config_t*,linked_list_t*))select_proposal;
+ this->public.select_proposal = (proposal_t*(*)(sa_config_t*,linked_list_t*))select_proposal;
this->public.add_traffic_selector_initiator = (void(*)(sa_config_t*,traffic_selector_t*))add_traffic_selector_initiator;
this->public.add_traffic_selector_responder = (void(*)(sa_config_t*,traffic_selector_t*))add_traffic_selector_responder;
- this->public.add_proposal = (void(*)(sa_config_t*,child_proposal_t*))add_proposal;
+ this->public.add_proposal = (void(*)(sa_config_t*,proposal_t*))add_proposal;
this->public.destroy = (void(*)(sa_config_t*))destroy;
/* apply init values */
diff --git a/Source/charon/config/sa_config.h b/Source/charon/config/sa_config.h
index fd1952864..4fd7305f6 100644
--- a/Source/charon/config/sa_config.h
+++ b/Source/charon/config/sa_config.h
@@ -32,7 +32,7 @@
#include <transforms/signers/signer.h>
#include <transforms/diffie_hellman.h>
#include <config/traffic_selector.h>
-#include <config/child_proposal.h>
+#include <config/proposal.h>
@@ -174,7 +174,7 @@ struct sa_config_t {
* @param proposals list from from wich proposals are selected
* @return selected proposal, or NULL if nothing matches
*/
- child_proposal_t *(*select_proposal) (sa_config_t *this, linked_list_t *proposals);
+ proposal_t *(*select_proposal) (sa_config_t *this, linked_list_t *proposals);
/**
* @brief Add a traffic selector to the list for initiator.
@@ -211,7 +211,7 @@ struct sa_config_t {
* @param this calling object
* @param proposal proposal to add
*/
- void (*add_proposal) (sa_config_t *this, child_proposal_t *proposal);
+ void (*add_proposal) (sa_config_t *this, proposal_t *proposal);
/**
* @brief Destroys the config object