aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Source/charon/config/sa_config.c80
-rw-r--r--Source/charon/config/sa_config.h46
2 files changed, 37 insertions, 89 deletions
diff --git a/Source/charon/config/sa_config.c b/Source/charon/config/sa_config.c
index 75d871040..cb553ff33 100644
--- a/Source/charon/config/sa_config.c
+++ b/Source/charon/config/sa_config.c
@@ -62,11 +62,6 @@ struct private_sa_config_t {
* list for traffic selectors
*/
linked_list_t *ts;
-
- /**
- * compare two traffic_selectors for equality
- */
- bool (*traffic_selector_equals) (private_sa_config_t *this, traffic_selector_t *first, traffic_selector_t *second);
/**
* compare two proposals for equality
@@ -101,19 +96,19 @@ static auth_method_t get_auth_method(private_sa_config_t *this)
/**
* implements sa_config_t.get_traffic_selectors
*/
-static size_t get_traffic_selectors(private_sa_config_t *this, traffic_selector_t **traffic_selectors)
+static size_t get_traffic_selectors(private_sa_config_t *this, traffic_selector_t ***traffic_selectors)
{
iterator_t *iterator;
traffic_selector_t *current_ts;
int counter = 0;
- *traffic_selectors = allocator_alloc(sizeof(traffic_selector_t) * this->ts->get_count(this->ts));
+ *traffic_selectors = allocator_alloc(sizeof(traffic_selector_t*) * this->ts->get_count(this->ts));
/* copy all ts from the list in an array */
iterator = this->ts->create_iterator(this->ts, TRUE);
while (iterator->has_next(iterator))
{
iterator->current(iterator, (void**)&current_ts);
- memcpy((*traffic_selectors) + counter, current_ts, sizeof(traffic_selector_t));
+ *((*traffic_selectors) + counter) = current_ts->clone(current_ts);
counter++;
}
iterator->destroy(iterator);
@@ -123,12 +118,12 @@ static size_t get_traffic_selectors(private_sa_config_t *this, traffic_selector_
/**
* implements sa_config_t.select_traffic_selectors
*/
-static size_t select_traffic_selectors(private_sa_config_t *this, traffic_selector_t *supplied, size_t count, traffic_selector_t **selected)
+static size_t select_traffic_selectors(private_sa_config_t *this, traffic_selector_t **supplied, size_t count, traffic_selector_t ***selected)
{
iterator_t *iterator;
traffic_selector_t *current_ts;
int i, counter = 0;
- *selected = allocator_alloc(sizeof(traffic_selector_t) * this->ts->get_count(this->ts));
+ *selected = allocator_alloc(sizeof(traffic_selector_t*) * this->ts->get_count(this->ts));
/* iterate over all stored proposals */
iterator = this->ts->create_iterator(this->ts, TRUE);
@@ -137,10 +132,13 @@ static size_t select_traffic_selectors(private_sa_config_t *this, traffic_select
iterator->current(iterator, (void**)&current_ts);
for (i = 0; i < count; i++)
{
- /* copy if a supplied one is equal to ours */
- if (this->traffic_selector_equals(this, &(supplied[i]), current_ts))
+ traffic_selector_t *new_ts;
+ /* compare it */
+ new_ts = current_ts->get_subset(current_ts, supplied[i]);
+ /* match ? */
+ if (new_ts)
{
- memcpy((*selected) + counter, current_ts, sizeof(traffic_selector_t));
+ *((*selected) + counter) = new_ts;
counter++;
}
}
@@ -155,7 +153,7 @@ static size_t select_traffic_selectors(private_sa_config_t *this, traffic_select
/**
* implements sa_config_t.get_proposals
*/
-static size_t get_proposals(private_sa_config_t *this, child_proposal_t **proposals)
+static size_t get_proposals(private_sa_config_t *this, u_int8_t ah_spi[4], u_int8_t esp_spi[4], child_proposal_t **proposals)
{
iterator_t *iterator;
child_proposal_t *current_proposal;
@@ -166,8 +164,11 @@ static size_t get_proposals(private_sa_config_t *this, child_proposal_t **propos
iterator = this->proposals->create_iterator(this->proposals, TRUE);
while (iterator->has_next(iterator))
{
+ child_proposal_t *new_proposal = (*proposals) + counter;
iterator->current(iterator, (void**)&current_proposal);
- memcpy((*proposals) + counter, current_proposal, sizeof(child_proposal_t));
+ *new_proposal = *current_proposal;
+ memcpy(new_proposal->ah.spi, ah_spi, 4);
+ memcpy(new_proposal->ah.spi, esp_spi, 4);
counter++;
}
iterator->destroy(iterator);
@@ -177,10 +178,10 @@ static size_t get_proposals(private_sa_config_t *this, child_proposal_t **propos
/**
* implements sa_config_t.select_proposal
*/
-static child_proposal_t *select_proposal(private_sa_config_t *this, child_proposal_t *supplied, size_t count)
+static child_proposal_t *select_proposal(private_sa_config_t *this, u_int8_t ah_spi[4], u_int8_t esp_spi[4], child_proposal_t *supplied, size_t count)
{
iterator_t *iterator;
- child_proposal_t *current_proposal, *selected_proposal = NULL;
+ child_proposal_t *current_proposal, *selected_proposal;
int i;
/* iterate over all stored proposals */
@@ -194,32 +195,18 @@ static child_proposal_t *select_proposal(private_sa_config_t *this, child_propos
if (this->proposal_equals(this, &(supplied[i]), current_proposal))
{
selected_proposal = allocator_alloc(sizeof(child_proposal_t));
- memcpy(selected_proposal, current_proposal, sizeof(child_proposal_t));
- break;
+ *selected_proposal = *current_proposal;
+ memcpy(selected_proposal->ah.spi, ah_spi, 4);
+ memcpy(selected_proposal->ah.spi, esp_spi, 4);
+ iterator->destroy(iterator);
+ return selected_proposal;
}
}
}
iterator->destroy(iterator);
-
- return selected_proposal;
+ return NULL;
}
-/**
- * implements private_sa_config_t.traffic_selector_equals
- */
-static bool traffic_selector_equals(private_sa_config_t *this, traffic_selector_t *first, traffic_selector_t *second)
-{
- if (first->protocol == second->protocol)
- {
- if (first->begin->equals(first->begin, second->begin) &&
- first->end->equals(first->end, second->end))
- {
- return TRUE;
-
- }
- }
- return FALSE;
-}
/**
* implements private_sa_config_t.proposal_equals
@@ -261,9 +248,7 @@ static bool proposal_equals(private_sa_config_t *this, child_proposal_t *first,
static void add_traffic_selector(private_sa_config_t *this, traffic_selector_t *traffic_selector)
{
/* clone ts, and add*/
- traffic_selector_t *new_ts = allocator_alloc_thing(traffic_selector_t);
- *new_ts = *traffic_selector;
- this->ts->insert_last(this->ts, (void*)new_ts);
+ this->ts->insert_last(this->ts, (void*)traffic_selector);
}
/**
@@ -298,7 +283,7 @@ static status_t destroy(private_sa_config_t *this)
while(this->ts->get_count(this->ts) > 0)
{
this->ts->remove_last(this->ts, (void**)&traffic_selector);
- allocator_free(traffic_selector);
+ traffic_selector->destroy(traffic_selector);
}
this->ts->destroy(this->ts);
@@ -318,13 +303,13 @@ sa_config_t *sa_config_create(id_type_t my_id_type, char *my_id, id_type_t other
private_sa_config_t *this = allocator_alloc_thing(private_sa_config_t);
/* public functions */
- this->public.get_my_id = (identification_t(*)(sa_config_t*))get_my_id;
- this->public.get_other_id = (identification_t(*)(sa_config_t*))get_other_id;
+ this->public.get_my_id = (identification_t*(*)(sa_config_t*))get_my_id;
+ this->public.get_other_id = (identification_t*(*)(sa_config_t*))get_other_id;
this->public.get_auth_method = (auth_method_t(*)(sa_config_t*))get_auth_method;
- this->public.get_traffic_selectors = (size_t(*)(sa_config_t*,traffic_selector_t**))get_traffic_selectors;
- this->public.select_traffic_selectors = (size_t(*)(sa_config_t*,traffic_selector_t*,size_t,traffic_selector_t**))select_traffic_selectors;
- this->public.get_proposals = (size_t(*)(sa_config_t*,child_proposal_t**))get_proposals;
- this->public.select_proposal = (child_proposal_t*(*)(sa_config_t*,child_proposal_t*,size_t))select_proposal;
+ this->public.get_traffic_selectors = (size_t(*)(sa_config_t*,traffic_selector_t***))get_traffic_selectors;
+ this->public.select_traffic_selectors = (size_t(*)(sa_config_t*,traffic_selector_t**,size_t,traffic_selector_t***))select_traffic_selectors;
+ this->public.get_proposals = (size_t(*)(sa_config_t*,u_int8_t[4],u_int8_t[4],child_proposal_t**))get_proposals;
+ this->public.select_proposal = (child_proposal_t*(*)(sa_config_t*,u_int8_t[4],u_int8_t[4],child_proposal_t*,size_t))select_proposal;
this->public.add_traffic_selector = (void(*)(sa_config_t*,traffic_selector_t*))add_traffic_selector;
this->public.add_proposal = (void(*)(sa_config_t*,child_proposal_t*))add_proposal;
this->public.destroy = (void(*)(sa_config_t*))destroy;
@@ -347,7 +332,6 @@ sa_config_t *sa_config_create(id_type_t my_id_type, char *my_id, id_type_t other
/* init private members*/
this->proposal_equals = proposal_equals;
- this->traffic_selector_equals = traffic_selector_equals;
this->proposals = linked_list_create();
this->ts = linked_list_create();
diff --git a/Source/charon/config/sa_config.h b/Source/charon/config/sa_config.h
index 060d3fcae..412e7e611 100644
--- a/Source/charon/config/sa_config.h
+++ b/Source/charon/config/sa_config.h
@@ -31,6 +31,7 @@
#include <transforms/crypters/crypter.h>
#include <transforms/signers/signer.h>
#include <transforms/diffie_hellman.h>
+#include <config/traffic_selector.h>
typedef struct child_proposal_t child_proposal_t;
@@ -73,43 +74,6 @@ struct child_proposal_t {
};
-typedef struct traffic_selector_t traffic_selector_t;
-
-/**
- * @brief Storage structure for a traffic selection.
- *
- * Specifies a protocol and a valid IP and port range.
- *
- * @ingroup config
- */
-struct traffic_selector_t {
- /**
- * Protocol for which this ts applies (TCP/UDP/ICMP)
- */
- u_int8_t protocol;
-
- union {
- struct {
-
-
- } ipv4;
- struct {
- /* ipv6 support */
- } ipv6;
-
- };
-
- /**
- * Start address and port for allowed range
- */
- host_t *begin;
- /**
- * End address and port for allowed range
- */
- host_t *end;
-};
-
-
typedef struct sa_config_t sa_config_t;
/**
@@ -130,7 +94,7 @@ struct sa_config_t {
* @param this calling object
* @return own id
*/
- identification_t (*get_my_id) (sa_config_t *this);
+ identification_t *(*get_my_id) (sa_config_t *this);
/**
* @brief Get id of communication partner..
@@ -138,7 +102,7 @@ struct sa_config_t {
* @param this calling object
* @return other id
*/
- identification_t (*get_other_id) (sa_config_t *this);
+ identification_t *(*get_other_id) (sa_config_t *this);
/**
* @brief Get authentication method to use for IKE_AUTH.
@@ -157,7 +121,7 @@ struct sa_config_t {
* @param[out]traffic_selectors pointer where traffic selectors will be allocated
* @return number of returned traffic selectors
*/
- size_t (*get_traffic_selectors) (sa_config_t *this, traffic_selector_t **traffic_selectors);
+ size_t (*get_traffic_selectors) (sa_config_t *this, traffic_selector_t ***traffic_selectors);
/**
* @brief Select traffic selectors from a supplied list.
@@ -170,7 +134,7 @@ struct sa_config_t {
* @param[out]traffic_selectors pointer where selected traffic selectors will be allocated
* @return number of selected traffic selectors
*/
- size_t (*select_traffic_selectors) (sa_config_t *this, traffic_selector_t *supplied, size_t count, traffic_selector_t **selected);
+ size_t (*select_traffic_selectors) (sa_config_t *this, traffic_selector_t **supplied, size_t count, traffic_selector_t ***selected);
/**
* @brief Get the list of proposals for this config.