xmpp: Use ResourcePart for sender of room events

xmppftw created

Change summary

xmpp/ChangeLog                         |  2 ++
xmpp/src/event.rs                      | 10 +++++-----
xmpp/src/message/receive/chat.rs       |  2 +-
xmpp/src/message/receive/group_chat.rs |  4 ++--
4 files changed, 10 insertions(+), 8 deletions(-)

Detailed changes

xmpp/ChangeLog 🔗

@@ -8,6 +8,8 @@ XXXX-YY-ZZ [ RELEASER <admin@localhost> ]
       - builder::ClientBuilder::set_default_nick no longer takes a &str, but
         any type that implements AsRef<jid::ResourceRef>, such as produced
         by ResourcePart::new (!485)
+      - Event::RoomMessage, Event::RoomPrivateMessage, and Event::RoomSubject now
+        use ResourcePart as sender nickname (!485)
     * Added:
       - Agent::send_room_message takes RoomMessageSettings argument (!483)
     * Fixes:

xmpp/src/event.rs 🔗

@@ -4,12 +4,12 @@
 // License, v. 2.0. If a copy of the MPL was not distributed with this
 // file, You can obtain one at http://mozilla.org/MPL/2.0/.
 
-use tokio_xmpp::jid::BareJid;
 #[cfg(feature = "avatars")]
 use tokio_xmpp::jid::Jid;
+use tokio_xmpp::jid::{BareJid, ResourcePart};
 use tokio_xmpp::parsers::{message::Body, roster::Item as RosterItem};
 
-use crate::{delay::StanzaTimeInfo, Error, Id, RoomNick};
+use crate::{delay::StanzaTimeInfo, Error, Id};
 
 #[derive(Debug)]
 pub enum Event {
@@ -28,15 +28,15 @@ pub enum Event {
     ChatMessage(Id, BareJid, Body, StanzaTimeInfo),
     RoomJoined(BareJid),
     RoomLeft(BareJid),
-    RoomMessage(Id, BareJid, RoomNick, Body, StanzaTimeInfo),
+    RoomMessage(Id, BareJid, ResourcePart, Body, StanzaTimeInfo),
     /// The subject of a room was received.
     /// - The BareJid is the room's address.
     /// - The RoomNick is the nickname of the room member who set the subject.
     /// - The String is the new subject.
-    RoomSubject(BareJid, Option<RoomNick>, String, StanzaTimeInfo),
+    RoomSubject(BareJid, Option<ResourcePart>, String, StanzaTimeInfo),
     /// A private message received from a room, containing the message ID, the room's BareJid,
     /// the sender's nickname, and the message body.
-    RoomPrivateMessage(Id, BareJid, RoomNick, Body, StanzaTimeInfo),
+    RoomPrivateMessage(Id, BareJid, ResourcePart, Body, StanzaTimeInfo),
     ServiceMessage(Id, BareJid, Body, StanzaTimeInfo),
     HttpUploadedFile(String),
 }

xmpp/src/message/receive/chat.rs 🔗

@@ -38,7 +38,7 @@ pub async fn handle_message_chat(
                     Ok(full) => Event::RoomPrivateMessage(
                         message.id.clone(),
                         full.to_bare(),
-                        full.resource().to_string(),
+                        full.resource().into(),
                         body.clone(),
                         time_info.clone(),
                     ),

xmpp/src/message/receive/group_chat.rs 🔗

@@ -20,7 +20,7 @@ pub async fn handle_message_group_chat(
     if let Some((_lang, subject)) = message.get_best_subject(langs.clone()) {
         events.push(Event::RoomSubject(
             from.to_bare(),
-            from.resource().map(|x| x.to_string()),
+            from.resource().map(Into::into),
             subject.0.clone(),
             time_info.clone(),
         ));
@@ -31,7 +31,7 @@ pub async fn handle_message_group_chat(
             Ok(full) => Event::RoomMessage(
                 message.id.clone(),
                 from.to_bare(),
-                full.resource().to_string(),
+                full.resource().into(),
                 body.clone(),
                 time_info,
             ),