Flutter -Client von Mqchat, einem Protokoll, das für Chat -Zwecke über MQTT erstellt wurde.
Der Broker sollte zuerst die HIVEMQ-Chat-Erweiterung installieren.
Verwenden Sie MQTT als Chat -Protokoll, um eine moderne Chat -Anwendung zu erstellen, die alle erforderlichen Funktionen unterstützt. Dies ist ein Flutter -Client von MQchat.
Installieren Sie das Paket flutter-mqchat :
flutter pub add flutter-mqchat
Ein vollständiges und reichhaltiges Beispiel finden Sie im Ordner /example .
Benutzeranmeldung mit einem vorhandenen Konto:
bool connected = await ChatApp . instance () ! .clientHandler. connect (
host : "broker.url.com" ,
username : "[email protected]" ,
password : "user_pass" );Nach einer erfolgreichen Anmeldung erhält der MQTT -Client Aktualisierungen. Die ersten Aktualisierungen, die empfangen werden müssen, sind Profildetails, Räume, die Benutzer Mitglied haben, laufende Einladungen und Nachrichten (wenn die Nachrichtenarchivierung vom Broker unterstützt wird).
ChatApp . instance () ! .archiveHandler. getUser (). listen ((user) {
//insert/update user to database
});Immer wenn der angemeldete Benutzer zu einem Raum hinzugefügt wird (oder sich die Raumdetails geändert haben), werden die Raumdetails zum Konversationen -Stream hinzugefügt.
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()
}
});Wir verwenden dies, um die Einladungen anzuhören, die der Benutzer gesendet hat. Es könnte sein:
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: Erzählen Sie den Benutzern mehr über das Paket: Wo können Sie weitere Informationen finden, wie Sie zum Paket beitragen, wie Sie Probleme einreichen, welche Antwort sie von den Paketautoren erwarten können, und vieles mehr.