diff options
author | Jan Hutter <jhutter@hsr.ch> | 2005-12-05 13:43:43 +0000 |
---|---|---|
committer | Jan Hutter <jhutter@hsr.ch> | 2005-12-05 13:43:43 +0000 |
commit | 9bdd74eae7fb432163fafb21e7fc6c4fb4df2247 (patch) | |
tree | d6d519545417fe9e0a8968698bc8a2a325473205 /Source/charon/encoding/parser.c | |
parent | 510c342634f45ff8b5699280869030771531c73c (diff) | |
download | strongswan-9bdd74eae7fb432163fafb21e7fc6c4fb4df2247.tar.bz2 strongswan-9bdd74eae7fb432163fafb21e7fc6c4fb4df2247.tar.xz |
DELETE payload implemented and tested
Diffstat (limited to 'Source/charon/encoding/parser.c')
-rw-r--r-- | Source/charon/encoding/parser.c | 11 |
1 files changed, 11 insertions, 0 deletions
diff --git a/Source/charon/encoding/parser.c b/Source/charon/encoding/parser.c index e57bee3f1..b0aefee84 100644 --- a/Source/charon/encoding/parser.c +++ b/Source/charon/encoding/parser.c @@ -46,6 +46,7 @@ #include <encoding/payloads/cert_payload.h> #include <encoding/payloads/certreq_payload.h> #include <encoding/payloads/ts_payload.h> +#include <encoding/payloads/delete_payload.h> typedef struct private_parser_t private_parser_t; @@ -849,6 +850,16 @@ static status_t parse_payload(private_parser_t *this, payload_type_t payload_typ } break; } + case SPIS: + { + size_t data_length = payload_length - DELETE_PAYLOAD_HEADER_LENGTH; + if (this->parse_chunk(this, rule_number, output + rule->offset, data_length) != SUCCESS) + { + pld->destroy(pld); + return PARSE_ERROR; + } + break; + } case KEY_EXCHANGE_DATA: { size_t keydata_length = payload_length - KE_PAYLOAD_HEADER_LENGTH; |