#include "pEp_internal.h" #include #include PEP_STATUS init_transport_system(PEP_SESSION session) { assert(session); pEpSession *_session = (pEpSession *) session; PEP_transport_t* transports = _session->transports; assert(PEP_trans__count == 1); memset(transports, 0, sizeof(PEP_transport_t) * PEP_trans__count); transports[0].id = PEP_trans_auto; return PEP_STATUS_OK; } void release_transport_system(PEP_SESSION session) { assert(session); // nothing yet } identity_list *new_identity_list(const pEp_identity *ident) { identity_list *id_list = calloc(1, sizeof(identity_list)); assert(id_list); if (id_list == NULL) return NULL; if (ident) { id_list->ident = identity_dup(ident); assert(id_list->ident); if (id_list->ident == NULL) { free(id_list); return NULL; } } return id_list; } identity_list *identity_list_dup(const identity_list *src) { assert(src); identity_list *id_list = new_identity_list(src->ident); assert(id_list); if (id_list == NULL) return NULL; if (src->next) { id_list->next = identity_list_dup(src->next); if (id_list->next == NULL) { free_identity_list(id_list); return NULL; } } return id_list; } void free_identity_list(identity_list *id_list) { if (id_list) { free_identity_list(id_list->next); free_identity(id_list->ident); free(id_list); } } identity_list *identity_list_add(identity_list *id_list, const pEp_identity *ident) { assert(id_list); assert(ident); if (id_list->ident == NULL) { id_list->ident = identity_dup(ident); assert(id_list->ident); if (id_list->ident == NULL) return NULL; else return id_list; } else if (id_list->next == NULL) { id_list->next = new_identity_list(ident); assert(id_list->next); return id_list->next; } else { return identity_list_add(id_list->next, ident); } } message *new_message( msg_direction dir, const pEp_identity *from, const identity_list *to, const char *shortmsg ) { message *msg = calloc(1, sizeof(message)); assert(msg); if (msg == NULL) return NULL; if (msg->shortmsg) { msg->shortmsg = strdup(shortmsg); assert(msg->shortmsg); if (msg->shortmsg == NULL) { free(msg); return NULL; } msg->shortmsg_size = strlen(msg->shortmsg); } msg->dir = dir; msg->from = identity_dup(from); assert(msg->from); if (msg->from == NULL) { free_message(msg); return NULL; } msg->to = identity_list_dup(to); assert(msg->to); if (msg->to == NULL) { free_message(msg); return NULL; } return msg; } void free_message(message *msg) { free(msg->id); free(msg->shortmsg); free(msg->longmsg); free(msg->longmsg_formatted); free(msg->rawmsg); free_identity_list(msg->to); free_identity_list(msg->cc); free_identity_list(msg->bcc); free(msg->refering_id); free_message_ref_list(msg->refered_by); free(msg); } message_ref_list *new_message_ref_list(message *msg) { message_ref_list *msg_list = calloc(1, sizeof(message_ref_list)); assert(msg_list); if (msg_list == NULL) return NULL; msg_list->msg_ref = msg; return msg_list; } void free_message_ref_list(message_ref_list *msg_list) { if (msg_list) { free_message_ref_list(msg_list->next); free(msg_list); } } message_ref_list *message_ref_list_add(message_ref_list *msg_list, message *msg) { assert(msg_list); assert(msg); if (msg_list->msg_ref == NULL) { msg_list->msg_ref = msg; return msg_list; } else if (msg_list->next == NULL) { msg_list->next = new_message_ref_list(msg); assert(msg_list->next); return msg_list->next; } else { return message_ref_list_add(msg_list->next, msg); } }