floo::BMXConversation
Conversation
#include <bmx_conversation.h>
Inherits from BMXBaseObject
Public Types
Name | |
---|---|
enum class | Type { Single, Group, System} Conversation type |
enum class | Direction { Up, Down} Message search direction |
Public Functions
Name | |
---|---|
virtual | ~BMXConversation() Destructor |
virtual int64_t | conversationId() =0 Conversation Id |
virtual Type | type() =0 Conversation type |
virtual BMXMessagePtr | lastMsg() =0 Latest message |
virtual int32_t | unreadNumber() =0 Number of unread messages |
virtual int32_t | messageCount() =0 Total number of messages in conversation |
virtual bool | isMuteNotification() =0 Whether the user is alerted to the message, without which the conversation total number of unread messages does not count this conversation. |
virtual const JSON & | extension() =0 Extension information |
virtual BMXErrorCode | setExtension(const std::string & ext) =0 Set the Extension information |
virtual const std::string & | editMessage() =0 Edit message |
virtual BMXErrorCode | setEditMessage(const std::string & editMessage) =0 Set the Edit Message |
virtual BMXErrorCode | setMessagePlayedStatus(BMXMessagePtr msg, bool status) =0 Set message playback state (valid only for voice/video messages) |
virtual BMXErrorCode | setMessageReadStatus(BMXMessagePtr msg, bool status) =0 Set message unread state, update unread message-number |
virtual BMXErrorCode | setAllMessagesRead() =0 Set all messages to read, update number of unread messages |
virtual BMXErrorCode | updateMessageExtension(BMXMessagePtr msg) =0 Update the extend field info of a database-stored message |
virtual BMXErrorCode | insertMessage(BMXMessagePtr msg) =0 Insert a message |
virtual BMXMessagePtr | loadMessage(int64_t msgId) =0 Read a message |
virtual BMXErrorCode | removeAllMessages() =0 Delete all messages in sesstion |
virtual BMXErrorCode | loadMessages(int64_t refMsgId, size_t size, BMXMessageList & result, Direction =Direction::Up) =0 Load message, starting with latest if not specified |
virtual BMXErrorCode | searchMessagesByKeyWords(const std::string & keywords, int64_t refTime, size_t size, BMXMessageList & result, Direction =Direction::Up) =0 Search for messages, starting with latest if not specified |
virtual BMXErrorCode | searchMessages(const std::string & keywords, int64_t refTime, size_t size, BMXMessageList & result, Direction =Direction::Up) =0 Deprecated. |
virtual BMXErrorCode | searchMessagesByType(BMXMessage::ContentType type, int64_t refTime, size_t size, BMXMessageList & result, Direction =Direction::Up) =0 Search for messages by type, starting with latest if not specified |
virtual BMXErrorCode | searchMessages(BMXMessage::ContentType type, int64_t refTime, size_t size, BMXMessageList & result, Direction =Direction::Up) =0 Deprecated. |
virtual BMXErrorCode | refreshConversation() =0 Read the total message-number from current conversation of the database, forces to update the total message-number and unread message-number. |
Protected Functions
Name | |
---|---|
BMXConversation() |
Public Types Documentation
enum Type
Enumerator | Value | Description |
---|---|---|
Single | Single chat | |
Group | Group chat | |
System | System notification |
Conversation type
enum Direction
Enumerator | Value | Description |
---|---|---|
Up | Fetch older message | |
Down | Fetch newer message |
Message search direction
Public Functions Documentation
function ~BMXConversation
inline virtual ~BMXConversation()
Destructor
Example:
function conversationId
virtual int64_t conversationId() =0
Conversation Id
Return: int64_t
Example:
function type
virtual Type type() =0
Conversation type
Return: Type
Example:
function lastMsg
virtual BMXMessagePtr lastMsg() =0
Latest message
Return: BMXMessagePtr
Example:
if (left->lastMsg() && right->lastMsg()) {
return left->lastMsg()->serverTimestamp() > right->lastMsg()->serverTimestamp();
} else if (left->lastMsg()) {
function unreadNumber
virtual int32_t unreadNumber() =0
Number of unread messages
Return: int32_t
Example:
function messageCount
virtual int32_t messageCount() =0
Total number of messages in conversation
Return: int32_t
Example:
function isMuteNotification
virtual bool isMuteNotification() =0
Whether the user is alerted to the message, without which the conversation total number of unread messages does not count this conversation.
Return: bool
Example:
function extension
virtual const JSON & extension() =0
Extension information
Return: JSON(std::string)
Example:
function setExtension
virtual BMXErrorCode setExtension(
const std::string & ext
) =0
Set the Extension information
Parameters:
- ext Conversation extension message
Return: BMXErrorCode
Example:
function editMessage
virtual const std::string & editMessage() =0
Edit message
Return: std::string
Example:
function setEditMessage
virtual BMXErrorCode setEditMessage(
const std::string & editMessage
) =0
Set the Edit Message
Parameters:
- editMessage Text message being edited by conversation
Return: BMXErrorCode
Example:
function setMessagePlayedStatus
virtual BMXErrorCode setMessagePlayedStatus(
BMXMessagePtr msg,
bool status
) =0
Set message playback state (valid only for voice/video messages)
Parameters:
- msg Message for which playback state needs to be set
- status Whether the message has been played
Return: BMXErrorCode
Example:
function setMessageReadStatus
virtual BMXErrorCode setMessageReadStatus(
BMXMessagePtr msg,
bool status
) =0
Set message unread state, update unread message-number
Parameters:
- msg Message for which the read state needs to be set
- status Whether the message is set to read
Return: BMXErrorCode
Example:
function setAllMessagesRead
virtual BMXErrorCode setAllMessagesRead() =0
Set all messages to read, update number of unread messages
Return: BMXErrorCode
Example:
function updateMessageExtension
virtual BMXErrorCode updateMessageExtension(
BMXMessagePtr msg
) =0
Update the extend field info of a database-stored message
Parameters:
- msg The message that needs to change the extension information when the msg section has updated its extension field
Return: BMXErrorCode
Example:
function insertMessage
virtual BMXErrorCode insertMessage(
BMXMessagePtr msg
) =0
Insert a message
Parameters:
- msg Inserted message
Return: BMXErrorCode
Example:
function loadMessage
virtual BMXMessagePtr loadMessage(
int64_t msgId
) =0
Read a message
Parameters:
- msgId Message id of the message to read
Return: BMXMessagePtr
Example:
function removeAllMessages
virtual BMXErrorCode removeAllMessages() =0
Delete all messages in sesstion
Return: BMXErrorCode
Example:
function loadMessages
virtual BMXErrorCode loadMessages(
int64_t refMsgId,
size_t size,
BMXMessageList & result,
Direction =Direction::Up
) =0
Load message, starting with latest if not specified
Parameters:
- refMsgId Start id of the message to load
- size Maximum number of searched messages
- result List of loaded messages returned by database
- Direction Message loading direction, default to load earlier messages
Return: BMXErrorCode
Example:
function searchMessagesByKeyWords
virtual BMXErrorCode searchMessagesByKeyWords(
const std::string & keywords,
int64_t refTime,
size_t size,
BMXMessageList & result,
Direction =Direction::Up
) =0
Search for messages, starting with latest if not specified
Parameters:
- keywords Keyword for search message
- refTime Start time of message search
- size Maximum number of searched messages
- result List of searched message results
- Direction Message search direction, default (Direction::Up)means search from earlier messages.
Return: BMXErrorCode
Example:
function searchMessages
virtual BMXErrorCode searchMessages(
const std::string & keywords,
int64_t refTime,
size_t size,
BMXMessageList & result,
Direction =Direction::Up
) =0
Deprecated.
Parameters:
- keywords Keyword for search message
- refTime Start time of message search
- size Maximum number of searched messages
- result List of searched message results
- Direction Message search direction, default (Direction::Up)means search from earlier messages.
Return: BMXErrorCode
use searchMessagesByKeyWords instead.
Search for messages, starting with latest if not specified
Example:
function searchMessagesByType
virtual BMXErrorCode searchMessagesByType(
BMXMessage::ContentType type,
int64_t refTime,
size_t size,
BMXMessageList & result,
Direction =Direction::Up
) =0
Search for messages by type, starting with latest if not specified
Parameters:
- type Type of search message
- refTime Start time of message search
- size Maximum number of searched messages
- result List of searched message results
- Direction Message search direction, default (Direction::Up)means search from earlier messages.
Return: BMXErrorCode
Example:
function searchMessages
virtual BMXErrorCode searchMessages(
BMXMessage::ContentType type,
int64_t refTime,
size_t size,
BMXMessageList & result,
Direction =Direction::Up
) =0
Deprecated.
Parameters:
- type Type of search message
- refTime Start time of message search
- size Maximum number of searched messages
- result List of searched message results
- Direction Message search direction, default (Direction::Up)means search from earlier messages.
Return: BMXErrorCode
use searchMessagesByType instead.
Search for messages by type, starting with latest if not specified
Example:
function refreshConversation
virtual BMXErrorCode refreshConversation() =0
Read the total message-number from current conversation of the database, forces to update the total message-number and unread message-number.
Return: BMXErrorCode
Protected Functions Documentation
Example:
function BMXConversation
inline BMXConversation()
Example:
Updated on 2022-01-26 at 17:20:40 +0800