V2TIMMessageSearchParam
(Android/iOS & Mac/Windows). When searching for messages, the SDK will execute different search logics based on this object's settings.V2TIMMessageSearchParam
are as follows:Parameter | Meaning | Description |
keywordList | Keyword list | It can contain up to five keywords. When the message sender and the message type are not specified, the keyword list must be set; in other cases, it can be left empty. |
keywordListMatchType | Match type of the keyword list | You can set it to search with "OR" logic or "AND" logic. The values are V2TIM_KEYWORD_LIST_MATCH_TYPE_OR and V2TIM_KEYWORD_LIST_MATCH_TYPE_AND , respectively. By default, it uses "OR" logic. |
senderUserIDList | Search for messages sent by a specified userID | Up to five are supported. |
messageTypeList | Set of the message types to be searched for | |
conversationID | Search "all conversations" or "a specified conversation" | If conversationID is empty, search all sessions; if conversationID is not empty, search the specified session. |
searchTimePosition | Start time for the search | The default is 0 (search from now). UTC Timestamp, in seconds. |
searchTimePeriod | A past period of time starting from the start time | The default is 0 (unlimited time range). 24 x 60 x 60 represents the past day, in seconds. |
searchCount | Number of search results | Number of searches, support up to 100. |
searchCursor | Search cursor | Starting position, fill in an empty character string for the first time, and fill in the searchCursor from the last V2TIMMessageSearchResult returned for subsequent pulls. |
V2TIMMessageSearchResult
(Android/iOS & Mac/Windows). The parameters are as described below:Parameter | Meaning | Description |
totalCount | Total number of the search result items | If a specific session is searched, the total number of messages that meet the search criteria will be returned; If all sessions are searched, the total number of sessions containing messages that meet the search criteria will be returned. |
messageSearchResultItems | Search results list | If a specific session is searched, the returned result list will only include results from that session; If all sessions are searched, messages that meet the search criteria will be grouped by session ID, and the grouping results will be returned paginated. |
searchCursor | Continue pulling the cursor | Cursor required for continuation while calling the search API |
messageSearchResultItems
is a list containing V2TIMMessageSearchResultItem
(Android/iOS & Mac/Windows) objects, with the parameters described as follows:Parameter | Meaning | Description |
conversationID | Session ID | - |
messageCount | Number of messages | The total number of messages matching the criteria found in the current session. |
messageList | List of messages that meet the search criteria | If a specific session is searched, messageList contains a list of all messages meeting the search criteria within this session.If all sessions are searched, the number of messages contained in messageList may have the following two possibilities:If the number of messages matched in a session is > 1, then messageList is empty, and you can display "{messageCount } relevant records" on the UI.If the number of messages matched in a session = 1, then messageList is the matched message, and you can display it on the UI and highlight the search keywords. |
searchCloudMessages
(Android/iOS and Mac/Windows) to search for messages.conversationID
in V2TIMMessageSearchParam
unset or set to empty.List<String> keywordList = new ArrayList<>();keywordList.add("abc");keywordList.add("123");V2TIMMessageSearchParam searchParam = new V2TIMMessageSearchParam();// Set the keyword for the searchsearchParam.setKeywordList(keywordList);// Search for 20 data entriessearchParam.setSearchCount(20);// Start searching from the latest sessionsearchParam.setSearchCursor("");// Start searching from the current timesearchParam.setSearchTimePosition(0);// Search for messages within 10 minutessearchParam.setSearchTimePeriod(600);V2TIMManager.getMessageManager().searchCloudMessages(searchParam,newV2TIMValueCallback<V2TIMMessageSearchResult>() {@Overridepublic void onSuccess(V2TIMMessageSearchResult v2TIMMessageSearchResult) {// Data found successfully}@Overridepublic void onError(int code, String desc) {// Failed to find the data}});
V2TIMMessageSearchParam *param = [[V2TIMMessageSearchParam alloc] init];// Set the keyword for the searchparam.keywordList = @[@"abc", @"123"];param.messageTypeList = nil;param.conversationID = nil;param.searchTimePosition = 0;param.searchTimePeriod = 0;// Search for 20 data entriesparam.searchCount = 20;// Start searching from the latest sessionparam.searchCursor = @"";[V2TIMManager.sharedInstance searchCloudMessages:paramsucc:^(V2TIMMessageSearchResult *searchResult) {// The search was successful, and the search results are returned in searchResult} fail:^(int code, NSString *desc) {// Failed to find the data}];
template <class T>class ValueCallback final : public V2TIMValueCallback<T> {public:using SuccessCallback = std::function<void(const T&)>;using ErrorCallback = std::function<void(int, const V2TIMString&)>;ValueCallback() = default;~ValueCallback() override = default;void SetCallback(SuccessCallback success_callback, ErrorCallback error_callback) {success_callback_ = std::move(success_callback);error_callback_ = std::move(error_callback);}void OnSuccess(const T& value) override {if (success_callback_) {success_callback_(value);}}void OnError(int error_code, const V2TIMString& error_message) override {if (error_callback_) {error_callback_(error_code, error_message);}}private:SuccessCallback success_callback_;ErrorCallback error_callback_;};V2TIMMessageSearchParam searchParam;// Set the keyword for the searchsearchParam.keywordList.PushBack("abc");searchParam.keywordList.PushBack("123");// Search for 20 data entriessearchParam.searchCount = 20;// Start searching from the latest sessionsearchParam.searchCursor = "";auto callback = new ValueCallback<V2TIMMessageSearchResult>{};callback->SetCallback([=](const V2TIMMessageSearchResult& messageSearchResult) {// Data found successfullydelete callback;},[=](int error_code, const V2TIMString& error_message) {// Failed to find the datadelete callback;});V2TIMManager::GetInstance()->GetMessageManager()->SearchCloudMessages(searchParam, callback);
searchCloudMessages
(Android/iOS and Mac/Windows) to search for messages.List<String> keywordList = new ArrayList<>();keywordList.add("abc");keywordList.add("123");V2TIMMessageSearchParam searchParam = new V2TIMMessageSearchParam();// Search for one-to-one messages with the 'user1' usersearchParam.setConversationID("c2c_user1");// Set the keyword for the searchsearchParam.setKeywordList(keywordList);// Search for 20 data entriessearchParam.setSearchCount(20);// Start searching from the latest sessionsearchParam.setSearchCursor("");// Start searching from the current timesearchParam.setSearchTimePosition(0);// Search for messages within 10 minutessearchParam.setSearchTimePeriod(600);V2TIMManager.getMessageManager().searchCloudMessages(searchParam,newV2TIMValueCallback<V2TIMMessageSearchResult>() {@Overridepublic void onSuccess(V2TIMMessageSearchResult v2TIMMessageSearchResult) {// Data found successfully}@Overridepublic void onError(int code, String desc) {// Failed to find the data}});
V2TIMMessageSearchParam *param = [[V2TIMMessageSearchParam alloc] init];// Set the keyword for the searchparam.keywordList = @[@"abc", @"123"];param.messageTypeList = nil;// Search for one-to-one messages with the 'user1' userparam.conversationID = @"c2c_user1";param.searchTimePosition = 0;param.searchTimePeriod = 0;// Search for 20 data entriesparam.searchCount = 20;// Start searching from the latest sessionparam.searchCursor = @"";[V2TIMManager.sharedInstance searchCloudMessages:paramsucc:^(V2TIMMessageSearchResult *searchResult) {// The search was successful, and the search results are returned in searchResult} fail:^(int code, NSString *desc) {// Failed to find the data}];
template <class T>class ValueCallback final : public V2TIMValueCallback<T> {public:using SuccessCallback = std::function<void(const T&)>;using ErrorCallback = std::function<void(int, const V2TIMString&)>;ValueCallback() = default;~ValueCallback() override = default;void SetCallback(SuccessCallback success_callback, ErrorCallback error_callback) {success_callback_ = std::move(success_callback);error_callback_ = std::move(error_callback);}void OnSuccess(const T& value) override {if (success_callback_) {success_callback_(value);}}void OnError(int error_code, const V2TIMString& error_message) override {if (error_callback_) {error_callback_(error_code, error_message);}}private:SuccessCallback success_callback_;ErrorCallback error_callback_;};V2TIMMessageSearchParam searchParam;// Search for one-to-one messages with the 'user1' usersearchParam.conversationID = "c2c_user1";// Set the keyword for the searchsearchParam.keywordList.PushBack("abc");searchParam.keywordList.PushBack("123");// Search for 20 data entriessearchParam.searchCount = 20;// Start searching from the latest sessionsearchParam.searchCursor = "";auto callback = new ValueCallback<V2TIMMessageSearchResult>{};callback->SetCallback([=](const V2TIMMessageSearchResult& messageSearchResult) {// Data found successfullydelete callback;},[=](int error_code, const V2TIMString& error_message) {// Failed to find the datadelete callback;});V2TIMManager::GetInstance()->GetMessageManager()->SearchCloudMessages(searchParam, callback);
Figure 1. Chat Record | Figure 2. More Chat Record | Figure 3. Messages in the specified session |
| | |
V2TIMMessageSearchParam
conversationID
set to null
, indicates searching messages from all sessions.searchCursor
set to "", indicates searching for the latest data.searchCount
set to 3, indicates returning the number of the most recent sessions, typically showing 3 entries on the UI.V2TIMMessageSearchResult
totalCount
indicates the number of all sessions to which the matched messages belong.messageSearchResultItems
list contains the last 3 sessions (as per the searchCount
parameter). messageCount
of V2TIMMessageSearchResultItem
indicates the total number of messages found in the current session;messageList
will be empty. You can display "4 related chat records" on the UI, where 4 represents the messageCount
.messageList
is the message that matches. You can display the message content on the UI and highlight the search keyword, for example, "test" in the Typical Use Cases for the Search image.List<String> keywordList = new ArrayList<>();keywordList.add("test");V2TIMMessageSearchParam v2TIMMessageSearchParam = new V2TIMMessageSearchParam();// Setting `conversationID` to `null` is to search for messages in all sessions and the results will be classified by sessionv2TIMMessageSearchParam.setConversationID(null);v2TIMMessageSearchParam.setKeywordList(keywordList);v2TIMMessageSearchParam.setSearchCursor("");v2TIMMessageSearchParam.setSearchCount(3);V2TIMManager.getMessageManager().searchCloudMessages(v2TIMMessageSearchParam, newV2TIMValueCallback<V2TIMMessageSearchResult>() {@Overridepublic void onSuccess(V2TIMMessageSearchResult v2TIMMessageSearchResult) {// Total number of matched sessions to which messages belongint totalCount = v2TIMMessageSearchResult.getTotalCount();// Last three messages classified by sessionList<V2TIMMessageSearchResultItem> resultItemList = v2TIMMessageSearchResult.getMessageSearchResultItems();for (V2TIMMessageSearchResultItem resultItem : resultItemList) {// Session IDString conversationID = resultItem.getConversationID();// Total number of messages matching the sessionint totalMessageCount = resultItem.getMessageCount();// Message list: If totalMessageCount > 1, this list is empty; if totalMessageCount = 1, this list Element (XML) is this messageList<V2TIMMessage> v2TIMMessageList = resultItem.getMessageList();}}@Overridepublic void onError(int code, String desc) {}});
V2TIMMessageSearchParam *param = [[V2TIMMessageSearchParam alloc] init];param.keywordList = @[@"test"];// Setting `conversationID` to `nil` is to search for messages in all sessions and the results will be classified by sessionparam.conversationID = nil;param.searchCursor = @"";param.searchCount = 3;[V2TIMManager.sharedInstance searchCloudMessages:param succ:^(V2TIMMessageSearchResult *searchResult) {// Total number of matched conversations to which messages belongNSInteger totalCount = searchResult.totalCount;// Last three messages classified by sessionNSArray<V2TIMMessageSearchResultItem *> *messageSearchResultItems = searchResult.messageSearchResultItems;for (V2TIMMessageSearchResultItem *searchItem in messageSearchResultItems) {// Conversation IDNSString *conversationID = searchItem.conversationID;// Total number of messages matching the sessionNSUInteger messageCount = searchItem.messageCount;// Message listNSArray<V2TIMMessage *> *messageList = searchItem.messageList ?: @[];}} fail:^(int code, NSString *desc) {// fail}];
template <class T>class ValueCallback final : public V2TIMValueCallback<T> {public:using SuccessCallback = std::function<void(const T&)>;using ErrorCallback = std::function<void(int, const V2TIMString&)>;ValueCallback() = default;~ValueCallback() override = default;void SetCallback(SuccessCallback success_callback, ErrorCallback error_callback) {success_callback_ = std::move(success_callback);error_callback_ = std::move(error_callback);}void OnSuccess(const T& value) override {if (success_callback_) {success_callback_(value);}}void OnError(int error_code, const V2TIMString& error_message) override {if (error_callback_) {error_callback_(error_code, error_message);}}private:SuccessCallback success_callback_;ErrorCallback error_callback_;};V2TIMMessageSearchParam searchParam;// Setting conversationID to null searches for messages in all sessions, and results will be classified by sessionsearchParam.conversationID = "";searchParam.keywordList.PushBack("test");searchParam.searchCursor = "";searchParam.searchCount = 3;auto callback = new ValueCallback<V2TIMMessageSearchResult>{};callback->SetCallback([=](const V2TIMMessageSearchResult& messageSearchResult) {// Total number of matched sessions to which messages belonguint32_t totalCount = messageSearchResult.totalCount;// Last three messages classified by sessionV2TIMMessageSearchResultItemVector messageSearchResultItems =messageSearchResult.messageSearchResultItems;for (size_t i = 0; i < messageSearchResultItems.Size(); ++i) {// Session IDV2TIMString conversationID = messageSearchResultItems[i].conversationID;// Total number of messages matching the sessionuint32_t messageCount = messageSearchResultItems[i].messageCount;// Message list: If messageCount > 1, this list is empty; if messageCount = 1, this list Element (XML) is this messageV2TIMMessageVector messageList = messageSearchResultItems[i].messageList;}delete callback;},[=](int error_code, const V2TIMString& error_message) {// Failed to find the datadelete callback;});V2TIMManager::GetInstance()->GetMessageManager()->SearchCloudMessages(searchParam, callback);
V2TIMMessageSearchParam
can be set as follows:searchCount
= 10, searchCursor
= "". Call searchCloudMessages
to obtain the message search results, parse and display them on the homepage, and obtain the total number of sessions totalCount
and the cursor for the next request searchCursor
from the result callback.searchCursor
from the previous request results.......// Logging the search cursorString searchCursor = "";......private void searchConversation(String cursor) {List<String> keywordList = new ArrayList<>();keywordList.add("test");V2TIMMessageSearchParam v2TIMMessageSearchParam = new V2TIMMessageSearchParam();v2TIMMessageSearchParam.setConversationID(null);v2TIMMessageSearchParam.setKeywordList(keywordList);v2TIMMessageSearchParam.setSearchCount(10);v2TIMMessageSearchParam.setSearchCursor(cursor);V2TIMManager.getMessageManager().searchCloudMessages(v2TIMMessageSearchParam, newV2TIMValueCallback<V2TIMMessageSearchResult>() {@Overridepublic void onSuccess(V2TIMMessageSearchResult v2TIMMessageSearchResult) {// Total number of matched sessions to which messages belongint totalCount = v2TIMMessageSearchResult.getTotalCount();// Cursor for the next pagesearchCursor = v2TIMMessageSearchResult.getSearchCursor();// Information of messages classified by sessionList<V2TIMMessageSearchResultItem> resultItemList = v2TIMMessageSearchResult.getMessageSearchResultItems();for (V2TIMMessageSearchResultItem resultItem : resultItemList) {// Session IDString conversationID = resultItem.getConversationID();// Total number of messages matching the sessionint totalMessageCount = resultItem.getMessageCount();// Message list: If totalMessageCount > 1, this list is empty; if totalMessageCount = 1, this list Element (XML) is this messageList<V2TIMMessage> v2TIMMessageList = resultItem.getMessageList();}}@Overridepublic void onError(int code, String desc) {}});}// Load the next pagepublic void loadMore() {searchConversation(searchCursor);}
......// Logging the search cursorNSString *searchCursor = @"";......- (void)searchConversation:(NSString *)cursor {V2TIMMessageSearchParam *param = [[V2TIMMessageSearchParam alloc] init];param.keywordList = @[@"test"];param.conversationID = nil;param.searchCursor = cursor;param.searchCount = 10;[V2TIMManager.sharedInstance searchCloudMessages:param succ:^(V2TIMMessageSearchResult *searchResult) {// Total number of matched sessions to which messages belongNSUInteger totalCount = searchResult.totalCount;// Cursor for the next pagesearchCursor = searchResult.searchCursor;// Information of messages classified by sessionNSArray<V2TIMMessageSearchResultItem *> *messageSearchResultItems = searchResult.messageSearchResultItems;for (V2TIMMessageSearchResultItem *searchItem in messageSearchResultItems) {// Session IDNSString *conversationID = searchItem.conversationID;// Total number of messages matching the sessionNSUInteger totalMessageCount = searchItem.messageCount;// Message list: If totalMessageCount > 1, this list is empty; if totalMessageCount = 1, this list Element (XML) is this messageNSArray<V2TIMMessage *> *messageList = searchItem.messageList ?: @[];}} fail:^(int code, NSString *desc) {// fail}];}// Load the next page- (void)loadMore {[self searchConversation:searchCursor];}
template <class T>class ValueCallback final : public V2TIMValueCallback<T> {public:using SuccessCallback = std::function<void(const T&)>;using ErrorCallback = std::function<void(int, const V2TIMString&)>;ValueCallback() = default;~ValueCallback() override = default;void SetCallback(SuccessCallback success_callback, ErrorCallback error_callback) {success_callback_ = std::move(success_callback);error_callback_ = std::move(error_callback);}void OnSuccess(const T& value) override {if (success_callback_) {success_callback_(value);}}void OnError(int error_code, const V2TIMString& error_message) override {if (error_callback_) {error_callback_(error_code, error_message);}}private:SuccessCallback success_callback_;ErrorCallback error_callback_;};// Logging the search cursorV2TIMString searchCursor = "";void SearchConversation(V2TIMString cursor) {V2TIMMessageSearchParam searchParam;searchParam.keywordList.PushBack("test");searchParam.searchCursor = cursor;searchParam.searchCount = 10;auto callback = new ValueCallback<V2TIMMessageSearchResult>{};callback->SetCallback([=](const V2TIMMessageSearchResult& messageSearchResult) {// Total number of matched sessions to which messages belonguint32_t totalCount = messageSearchResult.totalCount;// Cursor for the next pagesearchCursor = messageSearchResult.searchCursor;// Information of messages classified by sessionV2TIMMessageSearchResultItemVector messageSearchResultItems =messageSearchResult.messageSearchResultItems;for (size_t i = 0; i < messageSearchResultItems.Size(); ++i) {// Session IDV2TIMString conversationID = messageSearchResultItems[i].conversationID;// Total number of messages matching the sessionuint32_t messageCount = messageSearchResultItems[i].messageCount;// Message list: If messageCount > 1, this list is empty; if messageCount = 1, this list Element (XML) is this messageV2TIMMessageVector messageList = messageSearchResultItems[i].messageList;}delete callback;},[=](int error_code, const V2TIMString& error_message) {// Failed to find the datadelete callback;});V2TIMManager::GetInstance()->GetMessageManager()->SearchLocalMessages(searchParam, callback);}// Load the next pagevoid LoadMore() { SearchConversation(searchCursor); }
V2TIMMessageSearchParam
settings can be referred to as follows:V2TIMMessageSearchParam
's conversationID
as the session ID you are searching for.searchCount
= 10, searchCursor
= "". Call searchCloudMessages
to obtain the message search results, parse and display them on the homepage, and obtain the total number of sessions totalCount
and the cursor for the next page searchCursor
from the result callback.searchCursor
to the return value from the callback of the previous call.V2TIMMessageSearchResult
:totalCount
indicates the total number of messages matched in that session.messageSearchResultItems
list contains only the results for that session. In the list, messageCount
of V2TIMMessageSearchResultItem
is the number of messages on that page, and messageList
is the list of messages on that page.searchCursor
represents the starting cursor for the next page search.......// Record the search cursorString searchCursor = "";......private void searchMessage(String cursor) {List<String> keywordList = new ArrayList<>();keywordList.add("test");V2TIMMessageSearchParam v2TIMMessageSearchParam = new V2TIMMessageSearchParam();v2TIMMessageSearchParam.setConversationID(conversationID);v2TIMMessageSearchParam.setKeywordList(keywordList);v2TIMMessageSearchParam.setSearchCount(10);v2TIMMessageSearchParam.setSearcuCursor(cursor);V2TIMManager.getMessageManager().searchCloudMessages(v2TIMMessageSearchParam,newV2TIMValueCallback<V2TIMMessageSearchResult>() {@Overridepublic void onSuccess(V2TIMMessageSearchResult v2TIMMessageSearchResult) {// Total number of messages matching the sessionint totalMessageCount = v2TIMMessageSearchResult.getTotalCount();// Cursor for the next pagesearchCursor = v2TIMMessageSearchResult.getSearchCursor();// Number of messages on the current pageList<V2TIMMessageSearchResultItem> resultItemList = v2TIMMessageSearchResult.getMessageSearchResultItems();for (V2TIMMessageSearchResultItem resultItem : resultItemList) {// Session IDString conversationID = resultItem.getConversationID();// The number of messages on the current pageint totalMessageCount = resultItem.getMessageCount();// List of messages on the current pageList<V2TIMMessage> v2TIMMessageList = resultItem.getMessageList();}}@Overridepublic void onError(int code, String desc) {}});}// Load the next pagepublic void loadMore() {searchMessage(searchCursor);}
......// Record the search cursorNSString *searchCursor = @"";......- (void)searchMessage:(NSString *)cursor {V2TIMMessageSearchParam *param = [[V2TIMMessageSearchParam alloc] init];param.keywordList = @[@"test"];// conversationID is the session ID to searchparam.conversationID = conversationID;param.searchCursor = cursor;param.searchCount = 10;[V2TIMManager.sharedInstance searchCloudMessages:param succ:^(V2TIMMessageSearchResult *searchResult) {// Total number of messages matching the sessionNSUInteger totalMessageCount = searchResult.totalCount;// Cursor for the next pagesearchCursor = searchResult.searchCursor;// Messages on the current pageNSArray<V2TIMMessageSearchResultItem *> *messageSearchResultItems = searchResult.messageSearchResultItems;for (V2TIMMessageSearchResultItem *searchItem in messageSearchResultItems) {// Session IDNSString *conversationID = searchItem.conversationID;// The number of messages on the current pageNSUInteger totalMessageCount = searchItem.messageCount;// List of messages on the current pageNSArray<V2TIMMessage *> *messageList = searchItem.messageList ?: @[];}} fail:^(int code, NSString *desc) {// fail}];}// Load the next page- (void)loadMore {[self searchMessage:searchCursor];}
template <class T>class ValueCallback final : public V2TIMValueCallback<T> {public:using SuccessCallback = std::function<void(const T&)>;using ErrorCallback = std::function<void(int, const V2TIMString&)>;ValueCallback() = default;~ValueCallback() override = default;void SetCallback(SuccessCallback success_callback, ErrorCallback error_callback) {success_callback_ = std::move(success_callback);error_callback_ = std::move(error_callback);}void OnSuccess(const T& value) override {if (success_callback_) {success_callback_(value);}}void OnError(int error_code, const V2TIMString& error_message) override {if (error_callback_) {error_callback_(error_code, error_message);}}private:SuccessCallback success_callback_;ErrorCallback error_callback_;};// Record the search cursorV2TIMString searchCursor = "";void SearchConversation(V2TIMString cursor) {V2TIMMessageSearchParam searchParam;searchParam.conversationID = conversationID;searchParam.keywordList.PushBack("test");searchParam.searchCursor = cursor;searchParam.searchCount = 10;auto callback = new ValueCallback<V2TIMMessageSearchResult>{};callback->SetCallback([=](const V2TIMMessageSearchResult& messageSearchResult) {// The number of all messages matched by the sessionuint32_t totalCount = messageSearchResult.totalCount;// Cursor for the next pagesearchCursor = messageSearchResult.searchCursor;// Messages on the current pageV2TIMMessageSearchResultItemVector messageSearchResultItems =messageSearchResult.messageSearchResultItems;for (size_t i = 0; i < messageSearchResultItems.Size(); ++i) {// Session IDV2TIMString conversationID = messageSearchResultItems[i].conversationID;// Number of messages on the current pageuint32_t messageCount = messageSearchResultItems[i].messageCount;// List of messages on the current pageV2TIMMessageVector messageList = messageSearchResultItems[i].messageList;}delete callback;},[=](int error_code, const V2TIMString& error_message) {// Search faileddelete callback;});V2TIMManager::GetInstance()->GetMessageManager()->SearchCloudMessages(searchParam, callback);}// Load the next pagevoid LoadMore() { SearchConversation(SearchCursor); }
createCustomMessage(data)
(Android/iOS & Mac/Windows) API to create a custom message, the message cannot be found because the SDK saves it as a binary data stream.createCustomMessage(data, description, extension)
(Android/iOS & Mac/Windows) API to create and send custom messages, placing the searchable text in the description
parameter.description
parameter, your custom messages will also have offline push and the notification bar will display the content of that parameter. If you don't need offline push, you can control it with the disablePush
in the V2TIMOfflinePushInfo
parameter of the sendMessage
(Android/iOS & Mac/Windows) API.desc
in the V2TIMOfflinePushInfo
parameter to set the push content differently.fileName
parameter when calling createFileMessage
to create a file message, fileName
will be used as the content of the file message to be searched and matched with the search keyword. If fileName
is not set, the SDK will automatically extract the file name from filePath
as the search content. Both fileName
and filePath
information is saved to the local device and server, and can be searched after pulling relevant information on a new device.fileName
, and the interface usually displays a thumbnail or duration, making the specification of keywordList
ineffective for searches. If you wish to search for such messages, you can specify messageTypeList
as V2TIM_ELEM_TYPE_IMAGE
/V2TIM_ELEM_TYPE_SOUND
/V2TIM_ELEM_TYPE_VIDEO
for categorized searches, which will then retrieve all messages of the specified types.
Was this page helpful?