/* silcmime.h Author: Pekka Riikonen Copyright (C) 2005 - 2006 Pekka Riikonen The contents of this file are subject to one of the Licenses specified in the COPYING file; You may not use this file except in compliance with the License. The software distributed under the License is distributed on an "AS IS" basis, in the hope that it will be useful, but WITHOUT WARRANTY OF ANY KIND, either expressed or implied. See the COPYING file for more information. */ /****h* silcutil/SILC MIME Interface * * DESCRIPTION * * Simple implementation of MIME. Supports creation and parsing of simple * MIME messages, multipart MIME messages, including nested multiparts, and * MIME fragmentation and defragmentation. * * SILC Mime API is not thread-safe. If the same MIME context must be * used in multithreaded environment concurrency control must be employed. * ***/ #ifndef SILCMIME_H #define SILCMIME_H /****s* silcutil/SILCMIMEAPI/SilcMime * * NAME * * typedef struct SilcMimeStruct *SilcMime; * * DESCRIPTION * * This context is the actual MIME message and is allocated * by silc_mime_alloc and given as argument to all silc_mime_* * functions. It is freed by the silc_mime_free function. * ***/ typedef struct SilcMimeStruct *SilcMime; /****s* silcutil/SILCMIMEAPI/SilcMimeAssembler * * NAME * * typedef struct SilcMimeAssemblerStruct *SilcMimeAssembler; * * DESCRIPTION * * This context is a SILC MIME Assembler that is used to assemble partial * MIME messages (fgraments) into complete MIME messages. It is allocated * by silc_mime_assembler_alloc and freed by silc_mime_assembler_free. * ***/ typedef struct SilcMimeAssemblerStruct *SilcMimeAssembler; /****f* silcutil/SILCMIMEAPI/silc_mime_alloc * * SYNOPSIS * * SilcMime silc_mime_alloc(void) * * DESCRIPTION * * Allocates SILC Mime message context. * ***/ SilcMime silc_mime_alloc(void); /****f* silcutil/SILCMIMEAPI/silc_mime_free * * SYNOPSIS * * void silc_mime_alloc(SilcMime mime) * * DESCRIPTION * * Frees `mime' context. * ***/ void silc_mime_free(SilcMime mime); /****f* silcutil/SILCMIMEAPI/silc_mime_assembler_alloc * * SYNOPSIS * * SilcMimeAssembler silc_mime_assembler_alloc(void); * * DESCRIPTION * * Allocates MIME fragment assembler. * ***/ SilcMimeAssembler silc_mime_assembler_alloc(void); /****f* silcutil/SILCMIMEAPI/silc_mime_assembler_free * * SYNOPSIS * * void silc_mime_assembler_free(SilcMimeAssembler assembler) * * DESCRIPTION * * Frees `assembler' context. * ***/ void silc_mime_assembler_free(SilcMimeAssembler assembler); /****f* silcutil/SILCMIMEAPI/silc_mime_decode * * SYNOPSIS * * SilcMime silc_mime_decode(SilcMime mime, const unsigned char *data, * SilcUInt32 data_len); * * DESCRIPTION * * Decodes a MIME message and returns the parsed message into newly * allocated SilcMime context and returns it. If `mime' is non-NULL * then the MIME message will be encoded into the pre-allocated `mime' * context and same context is returned. If it is NULL then newly * allocated SilcMime context is returned. On error NULL is returned. * * EXAMPLE * * // Parse MIME message and get its content type * mime = silc_mime_decode(NULL, data, data_len); * type = silc_mime_get_field(mime, "Content-Type"); * ... * * // Assemble received MIME fragment * mime = silc_mime_decode(NULL, data, data_len); * if (silc_mime_is_partial(mime) == TRUE) * silc_mime_assmeble(assembler, mime); * ***/ SilcMime silc_mime_decode(SilcMime mime, const unsigned char *data, SilcUInt32 data_len); /****f* silcutil/SILCMIMEAPI/silc_mime_encode * * SYNOPSIS * * unsigned char *silc_mime_encode(SilcMime mime, SilcUInt32 *encoded_len); * * DESCRIPTION * * Encodes the `mime' context into a raw MIME message (may be human * readable). The caller must free the returned buffer. If the `mime' * is multipart MIME message all parts will be automatically encoded * as well. * * If you want to create fragmented MIME message use the function * silc_mime_encode_partial. * ***/ unsigned char *silc_mime_encode(SilcMime mime, SilcUInt32 *encoded_len); /****f* silcutil/SILCMIMEAPI/silc_mime_assemble * * SYNOPSIS * * SilcMime silc_mime_assemble(SilcMimeAssembler assembler, * SilcMime partial); * * DESCRIPTION * * Processes and attempts to assemble the received MIME fragment `partial'. * To check if a received MIME message is a fragment use the * silc_mime_is_partial function. Returns NULL if all fragments has not * yet been received, or the newly allocated completed MIME message if * all fragments were received. The caller must free the returned * SilcMime context. The caller must not free the `partial'. * * EXAMPLE * * // Assemble received MIME fragment * mime = silc_mime_decode(data, data_len); * if (silc_mime_is_partial(mime) == TRUE) { * complete = silc_mime_assmeble(assembler, mime); * if (complete == NULL) * return; * ... * } * ***/ SilcMime silc_mime_assemble(SilcMimeAssembler assembler, SilcMime partial); /****f* silcutil/SILCMIMEAPI/silc_mime_encode_partial * * SYNOPSIS * * SilcDList silc_mime_encode_partial(SilcMime mime, int max_size); * * DESCRIPTION * * Same as silc_mime_encode except fragments the MIME message `mime' * if it is larger than `max_size' in bytes. Returns the MIME fragments * in SilcDList where each entry is SilcBuffer context. The caller must * free the returned list and all SilcBuffer entries in it by calling * silc_mime_partial_free function. * * To assemble the fragments into a complete MIME message the * silc_mime_assemble can be used. * ***/ SilcDList silc_mime_encode_partial(SilcMime mime, int max_size); /****f* silcutil/SILCMIMEAPI/silc_mime_partial_free * * SYNOPSIS * * void silc_mime_partial_free(SilcDList partials); * * DESCRIPTION * * This function must be called to free the list returned by the * silc_mime_encode_partial function. * ***/ void silc_mime_partial_free(SilcDList partials); /****f* silcutil/SILCMIMEAPI/silc_mime_add_field * * SYNOPSIS * * void silc_mime_add_field(SilcMime mime, * const char *field, const char *value); * * DESCRIPTION * * Adds a field indicated by `field' to MIME message `mime'. The field * value is `value'. * * EXAMPLE * * silc_mime_add_field(mime, "MIME-Version", "1.0"); * silc_mime_add_field(mime, "Content-Type", "image/jpeg"); * silc_mime_add_field(mime, "Content-Transfer-Encoding", "binary"); * ***/ void silc_mime_add_field(SilcMime mime, const char *field, const char *value); /****f* silcutil/SILCMIMEAPI/silc_mime_get_field * * SYNOPSIS * * const char *silc_mime_get_field(SilcMime mime, const char *field); * * DESCRIPTION * * Returns the `field' value or NULL if such field does not exist in the * MIME message `mime'. * ***/ const char *silc_mime_get_field(SilcMime mime, const char *field); /****f* silcutil/SILCMIMEAPI/silc_mime_add_data * * SYNOPSIS * * void silc_mime_add_data(SilcMime mime, const unsigned char *data, * SilcUInt32 data_len); * * DESCRIPTION * * Adds the actual MIME data to the `mime' message. * ***/ void silc_mime_add_data(SilcMime mime, const unsigned char *data, SilcUInt32 data_len); /****f* silcutil/SILCMIMEAPI/silc_mime_get_data * * SYNOPSIS * * const unsigned char * * silc_mime_get_data(SilcMime mime, SilcUInt32 *data_len); * * DESCRIPTION * * Returns the MIME data from the `mime' message. * ***/ const unsigned char *silc_mime_get_data(SilcMime mime, SilcUInt32 *data_len); /****f* silcutil/SILCMIMEAPI/silc_mime_steal_data * * SYNOPSIS * * unsigned char * * silc_mime_steal_data(SilcMime mime, SilcUInt32 *data_len); * * DESCRIPTION * * Returns the MIME data from the `mime' message. The data will be * removed from the `mime' and the caller is responsible of freeing the * returned pointer. * ***/ unsigned char *silc_mime_steal_data(SilcMime mime, SilcUInt32 *data_len); /****f* silcutil/SILCMIMEAPI/silc_mime_is_partial * * SYNOPSIS * * SilcBool silc_mime_is_partial(SilcMime mime); * * DESCRIPTION * * Returns TRUE if the MIME message `mime' is a partial MIME fragment. * ***/ SilcBool silc_mime_is_partial(SilcMime mime); /****f* silcutil/SILCMIMEAPI/silc_mime_set_multipart * * SYNOPSIS * * void silc_mime_set_multipart(SilcMime mime, const char *type, * const char *boundary); * * DESCRIPTION * * Sets the `mime' to be a multipart MIME message. The `type' specifies * the multipart type, usually "mixed", but can be something else too. * The `boundary' specifies the multipart boundary. * ***/ void silc_mime_set_multipart(SilcMime mime, const char *type, const char *boundary); /****f* silcutil/SILCMIMEAPI/silc_mime_add_multipart * * SYNOPSIS * * SilcBool silc_mime_add_multipart(SilcMime mime, SilcMime part); * * DESCRIPTION * * Adds a multipart `part` to MIME message `mime'. The `part' will be * freed automatically when silc_mime_free is called for `mime'. Returns * TRUE if `part' was added to `mime' and FALSE if `mime' is not marked * as multipart MIME message. * * NOTES * * The silc_mime_set_multipart must be called for `mime' before parts * can be added to it. Otherwise FALSE will be returned. * * EXAMPLE * * part = silc_mime_alloc(); * silc_mime_add_field(part, "Content-Type", "image/jpeg"); * silc_mime_add_data(part, data, data_len); * * silc_mime_set_multipart(mime, "mixed", "boundary1"); * silc_mime_add_multipart(mime, part); * ***/ SilcBool silc_mime_add_multipart(SilcMime mime, SilcMime part); /****f* silcutil/SILCMIMEAPI/silc_mime_is_multipart * * SYNOPSIS * * SilcBool silc_mime_is_multipart(SilcMime mime); * * DESCRIPTION * * Returns TRUE if the MIME message `mime' is a multipart MIME message. * Its parts can be get by calling silc_mime_get_multiparts. * ***/ SilcBool silc_mime_is_multipart(SilcMime mime); /****f* silcutil/SILCMIMEAPI/silc_mime_get_multiparts * * SYNOPSIS * * SilcDList silc_mime_get_multiparts(SilcMime mime, const char **type); * * DESCRIPTION * * Returns list of the parts from the MIME message `mime'. Each entry * in the list is SilcMime context. The caller must not free the returned * list or the SilcMime contexts in the list. Returns NULL if no parts * exists in the MIME message. Returns the multipart type (like "mixed") * into `type' pointer. * ***/ SilcDList silc_mime_get_multiparts(SilcMime mime, const char **type); #include "silcmime_i.h" #endif /* SILCMIME_H */