 
 In chat apps, a conversation is composed of all the messages in a peer-to-peer chat, chat group, or chatroom. The Agora Chat SDK supports managing messages by conversations, including retrieving and managing unread messages, deleting the historical messages on the local device, and searching historical messages.
This page introduces how to use the Agora Chat SDK to implement these functionalities.
SQLCipher is used to encrypt the database that stores local messages. The Agora Chat SDK uses ChatManager to manage local messages. Followings are the core methods:
getAllConversations: Loads the conversation list on the local device.deleteConversations: Deletes the specified conversation.AgoraChatConversation.unreadMessagesCount: Retrieves the count of unread messages in the specified conversation.deleteConversation: Deletes the conversation from the server.AgoraChatConversation.loadMessagesStartFromId: Searches for messages from the local database.AgoraChatConversation.insertMessage: Inserts messages in the specified conversation.Before proceeding, ensure that you meet the following requirements:
This section shows how to implement managing messages.
Call getAllConversations to retrieve all the conversations on the local device:
NSArray *conversations = [[AgoraChatClient sharedClient].chatManager getAllConversations];Refer to the following code sample to retrieve the messages in the specified conversation:
// Retrieves the conversation ID
AgoraConversation *conversation = [[AgoraChatClient sharedClient].chatManager getConversation:conversationId type:type createIfNotExist:YES];
// Only one message is loaded during SDK initialization. Call loadMessagesStartFromId to retrieve more messages.
NSArray<AgoraChatMessage *> *messages = [conversation loadMessagesStartFromId:startMsgId count:count searchDirection:MessageSearchDirectionUp];Refer to the following code example to retrieve the count of unread messages:
// Retrieves the ID of the specified conversation.
AgoraConversation *conversation = [[AgoraChatClient sharedClient].chatManager getConversation:conversationId type:type createIfNotExist:YES];
// Retrieves the count of unread messages.
NSInteger unreadCount = conversation.unreadMessagesCount;Refer to the following code example to retrieve the count of all unread messages:
NSArray *conversations = [[AgoraChatClient sharedClient].chatManager getAllConversations];
NSInteger unreadCount = 0;
for (AgoraConversation *conversation in conversations) {
  unreadCount += conversation.unreadMessagesCount;
}Refer to the following code example to mark the specified messages as read:
AgoraConversation *conversation = [[AgoraChatClient sharedClient].chatManager getConversation:conversationId type:type createIfNotExist:YES];
// Marks all messages of the specified conversation as read.
[conversation markAllMessagesAsRead:nil];
// Marks the specified message as read.
[onversation markMessageAsReadWithId:messageId error:nil];You can delete conversations on both the local device and the server.
To delete them on the local device, call deleteConversation and removeMessage:
// Deletes the specified conversation. To keep the historical messages, set isDeleteMessages as NO.
[[AgoraChatClient sharedClient].chatManager deleteConversation:conversationId isDeleteMessages:YES completion:nil];
// Deletes the specified conversation.
NSArray *conversations = @{@"conversationID1",@"conversationID2"};
[[AgoraChatClient sharedClient].chatManager deleteConversations:conversations isDeleteMessages:YES completion:nil];
// Deletes the specified message of the current conversation.
AgoraConversation *conversation = [[AgoraChatClient sharedClient].chatManager getConversation:conversationId type:type createIfNotExist:YES];
[conversation deleteMessageWithId:.messageId error:nil];Call loadMessagesWithKeyword to search for messages by keywords, timestamp, and message sender:
NSArray<AgoraChatMessage *> *messages = [conversation loadMessagesWithKeyword:keyword timestamp:0 count:50 fromUser:nil searchDirection:MessageSearchDirectionDown];Call importMessages to import multiple messages to the specified conversation. This applies to scenarios where chat users want to formard messages from another conversation.
[[AgoraChatClient sharedClient].chatManager importMessages:messages completion:nil];If you want to insert a message to the current conversation without actually sending the message, construct the message body and call insertMessage. This can be used to send notification messages such as "XXX recalls a message", "XXX joins the chat group", and "Typing ...".
// Inserts a message to the specified conversation.
AgoraConversation *conversation = [[AgoraChatClient sharedClient].chatManager getConversation:conversationId type:type createIfNotExist:YES];
[conversation insertMessage:message error:nil];After implementing managing messages, you can refer to the following documents to add more messaging functionalities to your app: