aboutsummaryrefslogtreecommitdiffstats
path: root/Source/charon/encoding/message.c
diff options
context:
space:
mode:
Diffstat (limited to 'Source/charon/encoding/message.c')
-rw-r--r--Source/charon/encoding/message.c20
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);