diff options
author | Jan Hutter <jhutter@hsr.ch> | 2005-11-29 15:23:04 +0000 |
---|---|---|
committer | Jan Hutter <jhutter@hsr.ch> | 2005-11-29 15:23:04 +0000 |
commit | 7da522ba73ed0a42445c1fb48efa18a85338b600 (patch) | |
tree | 3080e0997aecf127647e419605a24dfd69a2891c /Source/charon/encoding/parser.c | |
parent | 346af6f3de4735b2c7c8b6abf824bd0258c4be6c (diff) | |
download | strongswan-7da522ba73ed0a42445c1fb48efa18a85338b600.tar.bz2 strongswan-7da522ba73ed0a42445c1fb48efa18a85338b600.tar.xz |
- implemented and tested ts_payload_t
Diffstat (limited to 'Source/charon/encoding/parser.c')
-rw-r--r-- | Source/charon/encoding/parser.c | 32 |
1 files changed, 32 insertions, 0 deletions
diff --git a/Source/charon/encoding/parser.c b/Source/charon/encoding/parser.c index b69819873..076157ce2 100644 --- a/Source/charon/encoding/parser.c +++ b/Source/charon/encoding/parser.c @@ -43,6 +43,7 @@ #include <encoding/payloads/notify_payload.h> #include <encoding/payloads/encryption_payload.h> #include <encoding/payloads/auth_payload.h> +#include <encoding/payloads/ts_payload.h> typedef struct private_parser_t private_parser_t; @@ -574,6 +575,7 @@ static status_t parse_payload(private_parser_t *this, payload_type_t payload_typ payload_t *pld; void *output; size_t rule_count, payload_length, spi_size, attribute_length; + u_int16_t ts_type; bool attribute_format; int rule_number; encoding_rule_t *rule; @@ -855,6 +857,36 @@ static status_t parse_payload(private_parser_t *this, payload_type_t payload_typ } break; } + case TS_TYPE: + { + if (this->parse_uint8(this, rule_number, output + rule->offset) != SUCCESS) + { + pld->destroy(pld); + return PARSE_ERROR; + } + ts_type = *(u_int8_t*)(output + rule->offset); + break; + } + case ADDRESS: + { + size_t address_length = (ts_type == TS_IPV4_ADDR_RANGE) ? 4 : 16; + if (this->parse_chunk(this, rule_number, output + rule->offset,address_length) != SUCCESS) + { + pld->destroy(pld); + return PARSE_ERROR; + } + break; + } + case TRAFFIC_SELECTORS: + { + size_t traffic_selectors_length = payload_length - TS_PAYLOAD_HEADER_LENGTH; + if (this->parse_list(this, rule_number, output + rule->offset, TRAFFIC_SELECTOR_SUBSTRUCTURE, traffic_selectors_length) != SUCCESS) + { + pld->destroy(pld); + return PARSE_ERROR; + } + break; + } default: { this->logger->log(this->logger, ERROR, " no rule to parse rule %d %s (%d)", rule_number, mapping_find(encoding_type_m, rule->type), rule->type); |