/* * Copyright (c) 2010-2019 Belledonne Communications SARL. * * This file is part of Liblinphone. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . */ #ifndef _L_C_CHAT_MESSAGE_H_ #define _L_C_CHAT_MESSAGE_H_ #include "linphone/api/c-chat-message-cbs.h" #include "linphone/api/c-types.h" // ============================================================================= typedef enum _LinphoneChatMessageDir{ LinphoneChatMessageIncoming, LinphoneChatMessageOutgoing } LinphoneChatMessageDir; // ============================================================================= #ifdef __cplusplus extern "C" { #endif // ifdef __cplusplus /** * @addtogroup chatmessage * @{ */ /** * Acquire a reference to the chat message. * @param[in] msg #LinphoneChatMessage object. * @return The same chat message. */ LINPHONE_PUBLIC LinphoneChatMessage *linphone_chat_message_ref (LinphoneChatMessage *msg); /** * Release reference to the chat message. * @param[in] msg #LinphoneChatMessage object. */ LINPHONE_PUBLIC void linphone_chat_message_unref (LinphoneChatMessage *msg); /** * Retrieve the user pointer associated with the chat message. * @param[in] msg #LinphoneChatMessage object. * @return The user pointer associated with the chat message. */ LINPHONE_PUBLIC void *linphone_chat_message_get_user_data (const LinphoneChatMessage *msg); /** * Assign a user pointer to the chat message. * @param[in] msg #LinphoneChatMessage object. * @param[in] ud The user pointer to associate with the chat message. */ LINPHONE_PUBLIC void linphone_chat_message_set_user_data (LinphoneChatMessage *msg, void *ud); // ============================================================================= /** * Returns back pointer to #LinphoneCore object. **/ LINPHONE_PUBLIC LinphoneCore *linphone_chat_message_get_core (const LinphoneChatMessage *msg); LINPHONE_PUBLIC const char *linphone_chat_message_get_external_body_url (const LinphoneChatMessage *msg); LINPHONE_PUBLIC void linphone_chat_message_set_external_body_url (LinphoneChatMessage *msg, const char *external_body_url); /** * Get the time the message was sent. * @param[in] msg #LinphoneChatMessage object. */ LINPHONE_PUBLIC time_t linphone_chat_message_get_time (const LinphoneChatMessage *msg); /** * Returns TRUE if the message has been sent, returns FALSE if the message has been received. * @param[in] msg #LinphoneChatMessage object. */ LINPHONE_PUBLIC bool_t linphone_chat_message_is_outgoing (const LinphoneChatMessage *msg); /** * Get origin of the message * @param[in] msg #LinphoneChatMessage object. * @return #LinphoneAddress */ LINPHONE_PUBLIC const LinphoneAddress *linphone_chat_message_get_from_address (const LinphoneChatMessage *msg); /** * Get destination of the message * @param[in] msg #LinphoneChatMessage object. * @return #LinphoneAddress */ LINPHONE_PUBLIC const LinphoneAddress *linphone_chat_message_get_to_address (const LinphoneChatMessage *msg); /** * Get the content type of a chat message. * @param[in] msg #LinphoneChatMessage object. * @return The content type of the chat message */ LINPHONE_PUBLIC const char *linphone_chat_message_get_content_type (const LinphoneChatMessage *msg); /** * Set the content type of a chat message. * This content type must match a content that is text representable, such as text/plain, text/html or image/svg+xml. * @param[in] msg #LinphoneChatMessage object. * @param[in] content_type The new content type of the chat message */ LINPHONE_PUBLIC void linphone_chat_message_set_content_type (LinphoneChatMessage *msg, const char *content_type); /** * Get text part of this message * @param[in] msg #LinphoneChatMessage object. * @return text or NULL if no text. * @deprecated use getTextContent() instead */ LINPHONE_PUBLIC const char *linphone_chat_message_get_text (const LinphoneChatMessage* msg); /** * Get the message identifier. * It is used to identify a message so that it can be notified as delivered and/or displayed. * @param[in] msg #LinphoneChatMessage object. * @return The message identifier. */ LINPHONE_PUBLIC const char *linphone_chat_message_get_message_id (const LinphoneChatMessage *msg); /** * Linphone message has an app-specific field that can store a text. The application might want * to use it for keeping data over restarts, like thumbnail image path. * @param[in] msg #LinphoneChatMessage object. * @return the application-specific data or NULL if none has been stored. */ LINPHONE_PUBLIC const char *linphone_chat_message_get_appdata (const LinphoneChatMessage *msg); /** * Linphone message has an app-specific field that can store a text. The application might want * to use it for keeping data over restarts, like thumbnail image path. * * Invoking this function will attempt to update the message storage to reflect the changeif it is * enabled. * * @param[in] msg #LinphoneChatMessage object. * @param data the data to store into the message */ LINPHONE_PUBLIC void linphone_chat_message_set_appdata (LinphoneChatMessage *msg, const char *data); /** * Returns the chatroom this message belongs to. * @param[in] msg #LinphoneChatMessage object. */ LINPHONE_PUBLIC LinphoneChatRoom *linphone_chat_message_get_chat_room (const LinphoneChatMessage *msg); /** * Get the path to the file to read from or write to during the file transfer. * @param[in] msg #LinphoneChatMessage object * @return The path to the file to use for the file transfer. * @deprecated use linphone_content_get_file_path() instead. */ LINPHONE_PUBLIC const char *linphone_chat_message_get_file_transfer_filepath (const LinphoneChatMessage *msg); // ============================================================================= /** * Get if a chat message is to be stored. * @param[in] msg #LinphoneChatMessage object. * @return Whether or not the message is to be stored */ LINPHONE_PUBLIC bool_t linphone_chat_message_get_to_be_stored (const LinphoneChatMessage *msg); /** * Set if a chat message is to be stored. * This content type must match a content that is text representable, such as text/plain, text/html or image/svg+xml. * @param[in] msg #LinphoneChatMessage object. * @param[in] to_be_stored Whether or not the chat message is to be stored */ LINPHONE_PUBLIC void linphone_chat_message_set_to_be_stored (LinphoneChatMessage *msg, bool_t to_be_stored); LINPHONE_PUBLIC unsigned int linphone_chat_message_store (LinphoneChatMessage *msg); /** * Get the state of the message * @param[in] msg #LinphoneChatMessage object. * @return #LinphoneChatMessageState */ LINPHONE_PUBLIC LinphoneChatMessageState linphone_chat_message_get_state (const LinphoneChatMessage *msg); /** * Get if the message was encrypted when transfered * @param[in] msg #LinphoneChatMessage object. * @return whether the message was encrypted when transfered or not */ LINPHONE_PUBLIC bool_t linphone_chat_message_is_secured (const LinphoneChatMessage *msg); /** * Linphone message can carry external body as defined by rfc2017 * @param[in] msg #LinphoneChatMessage object. * @return external body url or NULL if not present. */ LINPHONE_PUBLIC const char *linphone_chat_message_get_external_body_url (const LinphoneChatMessage *msg); /** * Linphone message can carry external body as defined by rfc2017 * * @param[in] msg #LinphoneChatMessage object. * @param url ex: access-type=URL; URL="http://www.foo.com/file" */ LINPHONE_PUBLIC void linphone_chat_message_set_external_body_url (LinphoneChatMessage *msg,const char *url); /** * Get the file_transfer_information (used by call backs to recover informations during a rcs file transfer) * * @param[in] msg #LinphoneChatMessage object. * @return a pointer to the #LinphoneContent structure or NULL if not present. */ LINPHONE_PUBLIC LinphoneContent *linphone_chat_message_get_file_transfer_information (const LinphoneChatMessage *msg); /** * Return whether or not a chat message is a file transfer. * @param[in] msg #LinphoneChatMessage object * @return Whether or not the message is a file transfer */ LINPHONE_PUBLIC bool_t linphone_chat_message_is_file_transfer (const LinphoneChatMessage *msg); /** * Return whether or not a chat message is a text. * @param[in] msg #LinphoneChatMessage object. * @return Whether or not the message is a text */ LINPHONE_PUBLIC bool_t linphone_chat_message_is_text (const LinphoneChatMessage *msg); /** * Start the download of the file from remote server * * @param[in] msg #LinphoneChatMessage object. * @param status_cb #LinphoneChatMessageStateChangeCb status callback invoked when file is downloaded or could not be downloaded * @param ud user data * @deprecated Use linphone_chat_message_download_file() instead. * @donotwrap */ LINPHONE_PUBLIC LINPHONE_DEPRECATED void linphone_chat_message_start_file_download ( LinphoneChatMessage *msg, LinphoneChatMessageStateChangedCb status_cb, void *ud ); /** * Start the download of the file referenced in a #LinphoneChatMessage from remote server. * @param[in] msg #LinphoneChatMessage object. * @deprecated Use linphone_chat_message_download_content() instead */ LINPHONE_PUBLIC bool_t linphone_chat_message_download_file (LinphoneChatMessage *msg); /** * Start the download of the #LinphoneContent referenced in the #LinphoneChatMessage from remote server. * @param[in] msg #LinphoneChatMessage object. * @param[in] c_content #LinphoneContent object to download. */ LINPHONE_PUBLIC bool_t linphone_chat_message_download_content(LinphoneChatMessage *msg, LinphoneContent *c_content); /** * Cancel an ongoing file transfer attached to this message.(upload or download) * @param[in] msg #LinphoneChatMessage object. */ LINPHONE_PUBLIC void linphone_chat_message_cancel_file_transfer (LinphoneChatMessage *msg); /** * Send a chat message. * @param[in] msg #LinphoneChatMessage object. */ LINPHONE_PUBLIC void linphone_chat_message_send (LinphoneChatMessage *msg); /** * Resend a chat message if it is in the 'not delivered' state for whatever reason. * @param[in] msg #LinphoneChatMessage object. * @deprecated Use linphone_chat_message_send instead. * @donotwrap */ LINPHONE_PUBLIC LINPHONE_DEPRECATED void linphone_chat_message_resend (LinphoneChatMessage *msg); LINPHONE_PUBLIC const LinphoneAddress *linphone_chat_message_get_peer_address (const LinphoneChatMessage *msg); /** * Returns the origin address of a message if it was a outgoing message, or the destination address if it was an incoming message. * @param[in] msg #LinphoneChatMessage object. * @return #LinphoneAddress */ LINPHONE_PUBLIC const LinphoneAddress *linphone_chat_message_get_local_address (const LinphoneChatMessage *msg); /** * Add custom headers to the message. * @param[in] msg #LinphoneChatMessage object. * @param header_name name of the header * @param header_value header value */ LINPHONE_PUBLIC void linphone_chat_message_add_custom_header ( LinphoneChatMessage *msg, const char *header_name, const char *header_value ); /** * Retrieve a custom header value given its name. * @param[in] msg #LinphoneChatMessage object. * @param header_name header name searched */ LINPHONE_PUBLIC const char * linphone_chat_message_get_custom_header (const LinphoneChatMessage *msg, const char *header_name); /** * Removes a custom header from the message. * @param[in] msg #LinphoneChatMessage object. * @param header_name name of the header to remove */ LINPHONE_PUBLIC void linphone_chat_message_remove_custom_header (LinphoneChatMessage *msg, const char *header_name); /** * Returns TRUE if the message has been read, otherwise returns FALSE. * @param[in] msg #LinphoneChatMessage object. */ LINPHONE_PUBLIC bool_t linphone_chat_message_is_read (const LinphoneChatMessage *msg); LINPHONE_PUBLIC LinphoneReason linphone_chat_message_get_reason (const LinphoneChatMessage *msg); /** * Get full details about delivery error of a chat message. * @param[in] msg #LinphoneChatMessage object. * @return a #LinphoneErrorInfo describing the details. */ LINPHONE_PUBLIC const LinphoneErrorInfo *linphone_chat_message_get_error_info (const LinphoneChatMessage *msg); /** * Set the path to the file to read from or write to during the file transfer. * @param[in] msg #LinphoneChatMessage object. * @param[in] filepath The path to the file to use for the file transfer. * @deprecated use linphone_content_set_file_path() instead. */ LINPHONE_PUBLIC void linphone_chat_message_set_file_transfer_filepath (LinphoneChatMessage *msg, const char *filepath); /** * Returns true if the chat message is a forward message. * @param[in] msg #LinphoneChatMessage object. * @return true if it is a forward message, false otherwise */ LINPHONE_PUBLIC bool_t linphone_chat_message_is_forward (LinphoneChatMessage *msg); /** * Gets the forward info if available as a string * @param[in] msg #LinphoneChatMessage object. * @return the original sender of the message if it has been forwarded, null otherwise */ LINPHONE_PUBLIC const char *linphone_chat_message_get_forward_info (const LinphoneChatMessage *msg); /** * Returns true if the chat message is an ephemeral message. * An ephemeral message will automatically disappear from the recipient's screen after the message has been viewed. * @param[in] msg #LinphoneChatMessage object. * @return true if it is an ephemeral message, false otherwise */ LINPHONE_PUBLIC bool_t linphone_chat_message_is_ephemeral(const LinphoneChatMessage *msg); /** * Returns lifetime of an ephemeral message. * The lifetime is the duration after which the ephemeral message will disappear once viewed. * @param[in] msg #LinphoneChatMessage object. * @return the lifetime of an ephemeral message, by default 86400s. */ LINPHONE_PUBLIC long linphone_chat_message_get_ephemeral_lifetime (const LinphoneChatMessage *msg); /** * Returns the real time at which an ephemeral message expires and will be deleted. * @param[in] msg #LinphoneChatMessage object. * @return the time at which an ephemeral message expires. 0 means the message has not been read. */ LINPHONE_PUBLIC time_t linphone_chat_message_get_ephemeral_expire_time (const LinphoneChatMessage *msg); /** * Fulfill a chat message char by char. Message linked to a Real Time Text Call send char in realtime following RFC 4103/T.140 * To commit a message, use #linphone_chat_room_send_message * @param[in] msg #LinphoneChatMessage object. * @param[in] character T.140 char * @return 0 if succeed. */ LINPHONE_PUBLIC LinphoneStatus linphone_chat_message_put_char (LinphoneChatMessage *msg, uint32_t character); /** * Get the #LinphoneChatMessageCbs object associated with the LinphoneChatMessage. * @param[in] msg #LinphoneChatMessage object. * @return The #LinphoneChatMessageCbs object associated with the LinphoneChatMessage. * @deprecated */ LINPHONE_PUBLIC LinphoneChatMessageCbs *linphone_chat_message_get_callbacks (const LinphoneChatMessage *msg); /** * Add a listener in order to be notified of #LinphoneChatMessage events. * @param[in] msg #LinphoneChatMessage object to monitor. * @param[in] cbs A #LinphoneChatMessageCbs object holding the callbacks you need. */ LINPHONE_PUBLIC void linphone_chat_message_add_callbacks(LinphoneChatMessage *msg, LinphoneChatMessageCbs *cbs); /** * Remove a listener from a #LinphoneChatMessage * @param[in] msg #LinphoneChatMessage object * @param[in] cbs #LinphoneChatMessageCbs object to remove. */ LINPHONE_PUBLIC void linphone_chat_message_remove_callbacks(LinphoneChatMessage *msg, LinphoneChatMessageCbs *cbs); /** * Gets the current LinphoneChatMessageCbs. * This is meant only to be called from a callback to be able to get the user_data associated with the #LinphoneChatMessageCbs that is calling the callback. * @param[in] msg #LinphoneChatMessage object * @return The #LinphoneChatMessageCbs that has called the last callback */ LINPHONE_PUBLIC LinphoneChatMessageCbs *linphone_chat_message_get_current_callbacks(const LinphoneChatMessage *msg); /** * Adds a file content to the ChatMessage. * @param[in] msg #LinphoneChatMessage object. * @param[in] c_content #LinphoneContent object to add. */ LINPHONE_PUBLIC void linphone_chat_message_add_file_content (LinphoneChatMessage *msg, LinphoneContent *c_content); /** * Adds a text content to the ChatMessage. * @param[in] msg #LinphoneChatMessage object. * @param[in] text The text to add to the message. */ LINPHONE_PUBLIC void linphone_chat_message_add_text_content (LinphoneChatMessage *msg, const char *text); /** * Removes a content from the ChatMessage. * @param[in] msg #LinphoneChatMessage object. * @param[in] content the #LinphoneContent object to remove. */ LINPHONE_PUBLIC void linphone_chat_message_remove_content (LinphoneChatMessage *msg, LinphoneContent *content); /** * Returns the list of contents in the message. * @param[in] msg #LinphoneChatMessage object. * @return \bctbx_list{LinphoneContent} the list of #LinphoneContent. */ LINPHONE_PUBLIC const bctbx_list_t *linphone_chat_message_get_contents(const LinphoneChatMessage *msg); /** * Returns true if the chat message has a text content * @param[in] msg #LinphoneChatMessage object. * @return true if it has one, false otherwise */ LINPHONE_PUBLIC bool_t linphone_chat_message_has_text_content (const LinphoneChatMessage *msg); /** * Gets the text content if available as a string * @param[in] msg #LinphoneChatMessage object. * @return the #LinphoneContent buffer if available, null otherwise */ LINPHONE_PUBLIC const char *linphone_chat_message_get_text_content (const LinphoneChatMessage *msg); /** * Gets whether or not a file is currently being downloaded or uploaded * @param[in] msg #LinphoneChatMessage object. * @return true if download or upload is in progress, false otherwise */ LINPHONE_PUBLIC bool_t linphone_chat_message_is_file_transfer_in_progress (const LinphoneChatMessage *msg); /** * Gets the list of participants for which the imdn state has reached the specified state and the time at which they did. * @param[in] msg #LinphoneChatMessage object. * @param[in] state The LinphoneChatMessageState the imdn have reached (only use LinphoneChatMessageStateDelivered, * LinphoneChatMessageStateDeliveredToUser, LinphoneChatMessageStateDisplayed and LinphoneChatMessageStateNotDelivered) * @return \bctbx_list{LinphoneParticipantImdnState} \onTheFlyList */ LINPHONE_PUBLIC bctbx_list_t *linphone_chat_message_get_participants_by_imdn_state ( const LinphoneChatMessage *msg, LinphoneChatMessageState state ); /** * Gets the callId accociated with the message * @param[in] msg #LinphoneChatMessage object. * @return the call Id */ LINPHONE_PUBLIC const char *linphone_chat_message_get_call_id(const LinphoneChatMessage *msg); /** * @} */ #ifdef __cplusplus } #endif // ifdef __cplusplus #endif // ifndef _L_C_CHAT_MESSAGE_H_