- status = this->proposals->create_iterator(this->proposals, &proposal_iterator, FALSE);
- if (status != SUCCESS)
- {
- this->logger->log(this->logger, ERROR, "Fatal error: Could not create iterator on list for proposals");
- return status;
- }
-
- sa_payload = sa_payload_create();
- if (sa_payload == NULL)
- {
- this->logger->log(this->logger, ERROR, "Fatal error: Could not create SA payload object");
- return OUT_OF_RES;
- }
-
- 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;
- }
-
- }
-
- proposal_iterator->destroy(proposal_iterator);