- while (proposal_iterator->has_next(proposal_iterator))
- {
- proposal_substructure_t *current_proposal;
- proposal_substructure_t *current_proposal_clone;
- status = proposal_iterator->current(proposal_iterator,(void **) ¤t_proposal);
- if (status != SUCCESS)
- {
- this->logger->log(this->logger, ERROR, "Could not get current proposal needed to copy");
- proposal_iterator->destroy(proposal_iterator);
- sa_payload->destroy(sa_payload);
- return status;
- }
- status = current_proposal->clone(current_proposal,¤t_proposal_clone);
- if (status != SUCCESS)
- {
- this->logger->log(this->logger, ERROR, "Could not clone current proposal");
- proposal_iterator->destroy(proposal_iterator);
- sa_payload->destroy(sa_payload);
- return status;
- }
-
- status = sa_payload->add_proposal_substructure(sa_payload,current_proposal_clone);
- if (status != SUCCESS)
- {
- this->logger->log(this->logger, ERROR, "Could not add cloned proposal to SA payload");
- proposal_iterator->destroy(proposal_iterator);
- sa_payload->destroy(sa_payload);
- return status;
- }