1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144
|
Chat room and messaging
=======================
There are different types of chat rooms. Basic chat rooms are simple chat rooms between two participants, they do not require a conference server and are considered as one-to-one chat rooms.
Group chat rooms allow more than one peer user and require a conference server.
Group chat rooms can also be considered as one-to-one if they have only one peer participant at the time of their creation and if the parameter "enable_one_to_one_chat_room" is set to true, otherwise a basic chat room will be created instead.
Secured chat rooms are group chat rooms where LIME X3DH end-to-end encryption is enabled, they can be either group chat rooms or one-to-one chat rooms but not basic chat rooms.
Chat rooms parameters
---------------------
Chat rooms creation and behavior can be controlled with the use of :cpp:type:`LinphoneChatRoomParams`.
.. code-block:: c
LinphoneChatRoomParams *params = linphone_core_create_default_chat_room_params(linphoneCore);
Default parameters will create an un-encrypted basic chat room (See next section).
You can change parameters prior to chat room creation. Possible types are :cpp:enumerator:`LinphoneChatRoomBackendBasic` and :cpp:enumerator:`LinphoneChatRoomBackendFlexisipChat`
.. code-block:: c
//Change chat room type
linphone_chat_room_params_set_backend(params, LinphoneChatRoomBackendBasic);
linphone_chat_room_params_set_backend(params, LinphoneChatRoomBackendFlexisipChat);
//Enable encryption
linphone_chat_room_params_enable_encryption(params, TRUE);
//Enable group chat (valid only with LinphoneChatRoomFlexisipChat)
linphone_chat_room_params_enable_group(params, TRUE);
//Enable real time text (valid only with LinphoneChatRoomBasic)
linphone_chat_room_params_enable_rtt(params, TRUE);
//Check that parameters are valid
assert(linphone_chat_room_params_is_valid(params));
.. _chat-room-creation:
Chat room creation
------------------
Chat rooms can be created with :cpp:func:`linphone_core_create_chat_room <linphone_core_create_chat_room>`.
The full list of parameters includes a :cpp:type:`LinphoneChatRoomParams` object, a subject, a local sip address to use and a list of participants.
Convenience methods are provided to ease chat room creation by passing only minimum required parameters.
Non-provided parameters will be created and default values will be used.
Functions accepting a list of participants with a size greater than 1 will create a group chat room (unless LinphoneChatRoomBackendBasic is used in parameters, in which case the chat room creation will fail).
* :cpp:func:`linphone_core_create_chat_room_2 <linphone_core_create_chat_room_2>`
* :cpp:func:`linphone_core_create_chat_room_3 <linphone_core_create_chat_room_3>`
* :cpp:func:`linphone_core_create_chat_room_4 <linphone_core_create_chat_room_4>`
* :cpp:func:`linphone_core_create_chat_room_5 <linphone_core_create_chat_room_5>`
NULL will be returned if the chat room creation failed.
Basic chat rooms
----------------
See :ref:`chat-room-creation` for creating basic chat rooms.
.. code-block:: c
LinphoneChatRoomParams *params = linphone_core_create_default_chat_room_params(linphoneCore);
LinphoneChatRoom* chat_room = linphone_core_create_chat_room_2(linphoneCore, params, "Subject", "sip:joe@sip.linphone.org");
//Or more simply:
LinphoneChatRoom* chat_room = linphone_core_create_chat_room_5(linphoneCore, "sip:joe@sip.linphone.org");
Once created, messages are sent using :cpp:func:`linphone_chat_room_send_message`.
.. code-block:: c
linphone_chat_room_send_message(chatRoom, "Hello world");
Incoming message are received through callbacks which can be set after the chat room is instantiated (**LinphoneChatRoomStateInstantiated**).
.. code-block:: c
<example>
.. seealso:: A more complete tutorial can be found at :ref:`"Chatroom and messaging" <chatroom_code_sample>` source code.
Group chat rooms
----------------
See :ref:`chat-room-creation` for creating group chat rooms.
A "fallback" mecanism exists when creating a group chat room with only one peer which does not support group chat. A basic chat room will be created instead. This mecanism is disabled by default and not accessible through normal creation functions. If you want to enable it, use :cpp:func:`linphone_core_create_client_group_chat_room` with `TRUE` as third argument to create the chat room.
Participants can be invited to the chat room using :cpp:func:`linphone_chat_room_add_participant <linphone_chat_room_add_participant>` or :cpp:func:`linphone_chat_room_add_participants <linphone_chat_room_add_participants>`. Participants can be removed using :cpp:func:`linphone_chat_room_remove_participant <linphone_chat_room_remove_participant>`.
.. code-block:: c
LinphoneChatRoomParams *params; //Create parameters
LinphoneChatRoom *chatRoom = linphone_core_create_chat_room(linphoneCore, params, "Subject", participantsAddressList);
linphone_chat_room_remove_participant(chatRoom, laureParticipant); // remove Laure from chat room
The list of participants of a chat room can be obtained with :cpp:func:`linphone_chat_room_get_participants <linphone_chat_room_get_participants>`. Note that Marie is not considered as a participant in Marie's chat rooms, one's own participant can be obtained with :cpp:func:`linphone_chat_room_get_me <linphone_chat_room_get_me>`.
.. code-block:: c
linphone_chat_room_get_participants(chatRoom);
linphone_chat_room_get_me();
Simple text chat message can be created with :cpp:func:`linphone_chat_room_create_message <linphone_chat_room_create_message>` and sent with :cpp:func:`linphone_chat_message_send <linphone_chat_message_send>`.
.. code-block:: c
LinphoneChatMessage *message = linphone_chat_room_create_message(marieChatRoom, "Hey!");
linphone_chat_message_send(message);
linphone_chat_message_unref(message);
More elaborate chat messages can be built using :cpp:func:`linphone_chat_room_create_empty_message <linphone_chat_room_create_empty_message>` to create an empty message, which can be filled with different contents using :cpp:func:`linphone_chat_message_add_text_content <linphone_chat_message_add_text_content>` and/or :cpp:func:`linphone_chat_message_add_file_content <linphone_chat_message_add_file_content>`.
.. code-block:: c
LinphoneChatMessage *message = linphone_chat_room_create_empty_message(chatRoom);
linphone_chat_message_add_text_content(message, content);
Concerning admins, events, history and instant message disposition notifications, more information can be found around the following functions: :cpp:func:`linphone_chat_room_set_participant_admin_status <linphone_chat_room_set_participant_admin_status>`, :cpp:func:`linphone_chat_room_get_history_events <linphone_chat_room_get_history_events>`, :cpp:func:`linphone_chat_room_get_history_range <linphone_chat_room_get_history_range>`, :cpp:func:`linphone_chat_room_mark_as_read <linphone_chat_room_mark_as_read>`.
Secured chat rooms
------------------
LIME X3DH end-to-end encryption for instant messages are enabled in secured chat rooms, also known as encrypted chat rooms.
Secured chat rooms and regular chat rooms can coexist, even if they have exactly the same participants.
.. code-block:: c
LinphoneChatRoomParams *params; //Create parameters
linphone_chat_room_params_enable_encryption(params, TRUE); //Enable encryption
LinphoneChatRoom *securedChatRoom = linphone_core_create_chat_room_2(linphoneCore, params, "Secured Conversation", participants);
Encrypted chat rooms only allow encrypted messages and files to transit (except for error IMDNs in case a message was incorrectly decrypted). Encrypted chat rooms have a concept of security level based on LIME X3DH trust level of each participant device in the conference. The current security level of a chat room can be obtained with :cpp:func:`linphone_chat_room_get_security_level <linphone_chat_room_get_security_level>`.
.. code-block:: c
LinphoneChatRoomSecurityLevel securityLevel = linphone_chat_room_get_security_level(securedChatRoom);
.. seealso:: <point to basic LIME X3DH test and LIME helloworld test>.
.. warning:: LIME X3DH encryption activation at linphone core level requires a server. Make sure the configuration entry `lime/x3dh_server_url` is defined or call :cpp:func:`linphone_core_set_lime_x3dh_server_url()` after core initialisation.
|