Flutter Client of MQChat, протокола, построенного над MQTT для чата.
Брокер должен сначала установить Hivemq Chat-Extension.
Используйте MQTT в качестве протокола чата, чтобы создать современное приложение чата, которое поддерживает все необходимые функции. Это трепетание клиента MQChat.
Установите пакет flutter-mqchat :
flutter pub add flutter-mqchat
Полный и богатый пример можно найти в папке /example .
Вход пользователя с использованием существующей учетной записи:
bool connected = await ChatApp . instance () ! .clientHandler. connect (
host : "broker.url.com" ,
username : "[email protected]" ,
password : "user_pass" );После успешного входа клиент MQTT будет получать обновления. Первые обновления, которые будут получены, - это данные профиля, комнаты, которые являются пользователями, постоянными приглашениями и сообщениями (если брокер поддерживается архивированием сообщений).
ChatApp . instance () ! .archiveHandler. getUser (). listen ((user) {
//insert/update user to database
});Всякий раз, когда зарегистрированный пользователь добавляется в комнату (или детали комнаты, изменившиеся), детали комнаты будут добавлены в поток разговоров.
ChatApp . instance () ! .archiveHandler. getAllConversations (). listen ((rooms) {
//insert/update rooms on the Database
}); ChatApp . instance () ! .messageReader. getChatMessages (). listen ((message) {
var dbMessage = message. toDbMessage ();
// insert the message to the database
// send chatmarker if the message is not mine
}); ChatApp . instance () !
.messageReader
. getChatMarkerMessages ()
. listen ((markerMessage) {
String messageId = markerMessage.referenceId;
if (markerMessage.status == ChatMarker .displayed) {
//update the database record
} else if (markerMessage.status == ChatMarker .delivered) {
//update the database record
}
}); ChatApp . instance () !
.invitationHandler
. newInvitationsStream ()
. listen ((invitation) {
if (invitation.type == MessageType . EventInvitationRequest ) {
//new invitation request
//insert invitation record to the database, notify the user
}
if (invitation.type == MessageType . EventInvitationResponseAccept || invitation.type == MessageType . EventInvitationResponseReject ) {
//responded to invitation, update the local record and wait the server to sync the new contact (if accepted).
//Do not insert a room, the user will receive a new room details triggered by getAllConversations()
}
});Мы используем это, чтобы выслушать приглашения, которые отправил пользователь. Это может быть:
ChatApp . instance () !
.invitationHandler
. invitationUpdatesStream ()
. listen ((invitation) {
if (invitation.invitationMessageType == InvitationMessageType . INFO ) {
//update the invitation record to be confirmed
}
else if (invitation.invitationMessageType == InvitationMessageType . ERROR ) {
//notify the user, and delete the record in inserted
}
}); ChatMessage newMessage = ChatMessage (
id : "generated_random_id" ,
type : MessageType . ChatText ,
text : "Hello there" ,
roomId : "[room_id]" ,
fromId : "[my_id]" , //optional
sendTime : DateTime . now ().millisecondsSinceEpoch,
fromName : "[my_name]" ); ChatApp . instance () !
.messageSender
. sendChatMessage (newMessage, "[room_id]" ); ChatMessage replyToMessage = ...; //the message to reply to
ChatApp . instance () !
.messageSender
. replyToMessage (replyToMessage, newMessage, widget.contactChat.roomId); ChatApp . instance () ! .messageSender. sendFileChatMessage (
type : MessageType . ChatImage , //for example
fileLocalPath : path,
room : "[room_id]" ); ChatApp . instance () !
.eventsSender
. sendIsTyping ( true , "[room_id]" ); ChatApp . instance () ! .messageReader. getTypingMessages (). listen ((event) {
//using event.roomId and event.isTyping and event.fromId, update the ui state
}); ChatApp . instance () !
.eventsSender
. sendInvitation ( "[invitee_username]" , "[invitation_random_id]" );TODO: Расскажите пользователям больше о пакете: где найти больше информации, как внести свой вклад в пакет, как подать проблемы, какой ответ они могут ожидать от авторов пакета и многое другое.