diff options
author | Martin Willi <martin@strongswan.org> | 2005-11-30 09:11:48 +0000 |
---|---|---|
committer | Martin Willi <martin@strongswan.org> | 2005-11-30 09:11:48 +0000 |
commit | ee29afd42b721e84fb4de942fb8d7e784da28b49 (patch) | |
tree | ecff9f4b215286a126c2bbdd6f3a91c526911a0e /Source/charon/encoding/message.c | |
parent | 63bfd6cc7cd6e58b250c10029bde3d5790a68c04 (diff) | |
download | strongswan-ee29afd42b721e84fb4de942fb8d7e784da28b49.tar.bz2 strongswan-ee29afd42b721e84fb4de942fb8d7e784da28b49.tar.xz |
- fixed encryption bug
Diffstat (limited to 'Source/charon/encoding/message.c')
-rw-r--r-- | Source/charon/encoding/message.c | 20 |
1 files changed, 8 insertions, 12 deletions
diff --git a/Source/charon/encoding/message.c b/Source/charon/encoding/message.c index 36ff4df1d..804603135 100644 --- a/Source/charon/encoding/message.c +++ b/Source/charon/encoding/message.c @@ -438,22 +438,17 @@ static void add_payload(private_message_t *this, payload_t *payload) if (this->payloads->get_count(this->payloads) > 0) { this->payloads->get_last(this->payloads,(void **) &last_payload); - } - - this->payloads->insert_last(this->payloads, payload); - - if (this->payloads->get_count(this->payloads) == 1) - { - this->first_payload = payload->get_type(payload); + last_payload->set_next_type(last_payload, payload->get_type(payload)); } else { - last_payload->set_next_type(last_payload,payload->get_type(payload)); + this->first_payload = payload->get_type(payload); } - + payload->set_next_type(payload, NO_PAYLOAD); + this->payloads->insert_last(this->payloads, (void*)payload); + this->logger->log(this->logger, CONTROL|MORE, "added payload of type %s to message", mapping_find(payload_type_m, payload->get_type(payload))); - } /** @@ -660,7 +655,8 @@ static status_t parse_body(private_message_t *this, crypter_t *crypter, signer_t status_t status = SUCCESS; payload_type_t current_payload_type = this->first_payload; - this->logger->log(this->logger, CONTROL, "parsing body of message"); + this->logger->log(this->logger, CONTROL, "parsing body of message, first payload %s", + mapping_find(payload_type_m, current_payload_type)); while ((current_payload_type != NO_PAYLOAD)) { @@ -953,7 +949,7 @@ static status_t encrypt_payloads (private_message_t *this,crypter_t *crypter, si { encryption_payload->set_transforms(encryption_payload,crypter,signer); status = encryption_payload->encrypt(encryption_payload); - this->payloads->insert_last(this->payloads,encryption_payload); + this->public.add_payload(&(this->public), (payload_t*)encryption_payload); } all_payloads->destroy(all_payloads); |