diff options
Diffstat (limited to 'filamento/src/logic')
| -rw-r--r-- | filamento/src/logic/local_only.rs | 14 | ||||
| -rw-r--r-- | filamento/src/logic/mod.rs | 8 | ||||
| -rw-r--r-- | filamento/src/logic/offline.rs | 23 | ||||
| -rw-r--r-- | filamento/src/logic/online.rs | 101 | ||||
| -rw-r--r-- | filamento/src/logic/process_stanza.rs | 107 | 
5 files changed, 138 insertions, 115 deletions
| diff --git a/filamento/src/logic/local_only.rs b/filamento/src/logic/local_only.rs index f5705f4..7f3a2e6 100644 --- a/filamento/src/logic/local_only.rs +++ b/filamento/src/logic/local_only.rs @@ -1,4 +1,4 @@ -use jid::JID; +use jid::{BareJID, JID};  use uuid::Uuid;  use crate::{ @@ -39,14 +39,14 @@ pub async fn handle_get_chats_ordered_with_latest_messages_and_users<Fs: FileSto  pub async fn handle_get_chat<Fs: FileStore + Clone>(      logic: &ClientLogic<Fs>, -    jid: JID, +    jid: BareJID,  ) -> Result<Chat, DatabaseError> {      Ok(logic.db().read_chat(jid).await?)  }  pub async fn handle_get_chat_and_user<Fs: FileStore + Clone>(      logic: &ClientLogic<Fs>, -    jid: JID, +    jid: BareJID,  ) -> Result<(Chat, User), DatabaseError> {      Ok(logic.db().read_chat_and_user(jid).await?)  } @@ -60,21 +60,21 @@ pub async fn handle_get_message<Fs: FileStore + Clone>(  pub async fn handle_get_messages<Fs: FileStore + Clone>(      logic: &ClientLogic<Fs>, -    jid: JID, +    jid: BareJID,  ) -> Result<Vec<Message>, DatabaseError> {      Ok(logic.db().read_message_history(jid).await?)  }  pub async fn handle_get_messages_with_users<Fs: FileStore + Clone>(      logic: &ClientLogic<Fs>, -    jid: JID, +    jid: BareJID,  ) -> Result<Vec<(Message, User)>, DatabaseError> {      Ok(logic.db().read_message_history_with_users(jid).await?)  }  pub async fn handle_delete_chat<Fs: FileStore + Clone>(      logic: &ClientLogic<Fs>, -    jid: JID, +    jid: BareJID,  ) -> Result<(), DatabaseError> {      Ok(logic.db().delete_chat(jid).await?)  } @@ -88,7 +88,7 @@ pub async fn handle_delete_messaage<Fs: FileStore + Clone>(  pub async fn handle_get_user<Fs: FileStore + Clone>(      logic: &ClientLogic<Fs>, -    jid: JID, +    jid: BareJID,  ) -> Result<User, DatabaseError> {      Ok(logic.db().read_user(jid).await?)  } diff --git a/filamento/src/logic/mod.rs b/filamento/src/logic/mod.rs index 5e05dac..146f3b0 100644 --- a/filamento/src/logic/mod.rs +++ b/filamento/src/logic/mod.rs @@ -1,6 +1,6 @@  use std::{collections::HashMap, sync::Arc}; -use jid::JID; +use jid::{BareJID, JID};  use lampada::{Connected, Logic, error::ReadError};  use stanza::client::Stanza;  use tokio::sync::{Mutex, mpsc, oneshot}; @@ -25,7 +25,7 @@ mod process_stanza;  #[derive(Clone)]  pub struct ClientLogic<Fs: FileStore> {      client: Client<Fs>, -    bare_jid: JID, +    jid: BareJID,      db: Db,      pending: Pending,      update_sender: mpsc::Sender<UpdateMessage>, @@ -80,7 +80,7 @@ impl Pending {  impl<Fs: FileStore> ClientLogic<Fs> {      pub fn new(          client: Client<Fs>, -        bare_jid: JID, +        jid: BareJID,          db: Db,          update_sender: mpsc::Sender<UpdateMessage>,          file_store: Fs, @@ -90,7 +90,7 @@ impl<Fs: FileStore> ClientLogic<Fs> {              pending: Pending::new(),              update_sender,              client, -            bare_jid, +            jid,              file_store,          }      } diff --git a/filamento/src/logic/offline.rs b/filamento/src/logic/offline.rs index 606b04f..aa84f3d 100644 --- a/filamento/src/logic/offline.rs +++ b/filamento/src/logic/offline.rs @@ -1,6 +1,7 @@  use std::process::id;  use chrono::Utc; +use jid::FullJID;  use lampada::error::WriteError;  use tracing::error;  use uuid::Uuid; @@ -19,9 +20,13 @@ use crate::{  };  use super::{ +    ClientLogic,      local_only::{ -        handle_delete_chat, handle_delete_messaage, handle_get_chat, handle_get_chat_and_user, handle_get_chats, handle_get_chats_ordered, handle_get_chats_ordered_with_latest_messages, handle_get_chats_ordered_with_latest_messages_and_users, handle_get_message, handle_get_messages, handle_get_messages_with_users, handle_get_user -    }, ClientLogic +        handle_delete_chat, handle_delete_messaage, handle_get_chat, handle_get_chat_and_user, +        handle_get_chats, handle_get_chats_ordered, handle_get_chats_ordered_with_latest_messages, +        handle_get_chats_ordered_with_latest_messages_and_users, handle_get_message, +        handle_get_messages, handle_get_messages_with_users, handle_get_user, +    },  };  pub async fn handle_offline<Fs: FileStore + Clone>(logic: ClientLogic<Fs>, command: Command<Fs>) { @@ -153,7 +158,7 @@ pub async fn handle_offline_result<Fs: FileStore + Clone>(              let message = Message {                  id, -                from: logic.bare_jid.clone(), +                from: logic.jid.clone(),                  // TODO: failure reason                  delivery: Some(Delivery::Failed),                  timestamp, @@ -163,11 +168,15 @@ pub async fn handle_offline_result<Fs: FileStore + Clone>(              // TODO: mark these as potentially failed upon client launch              if let Err(e) = logic                  .db() +                // TODO: can create message without a resource....                  .create_message_with_user_resource(                      message.clone(),                      jid.clone(),                      // TODO: when message is queued and sent, the from must also be updated with the correct resource -                    logic.bare_jid.clone(), +                    FullJID { +                        bare_jid: logic.jid.clone(), +                        resourcepart: "unsent".to_string(), +                    },                  )                  .await              { @@ -177,12 +186,12 @@ pub async fn handle_offline_result<Fs: FileStore + Clone>(                      .await;              } -            let from = match logic.db().read_user(logic.bare_jid.clone()).await { +            let from = match logic.db().read_user(logic.jid.clone()).await {                  Ok(u) => u,                  Err(e) => {                      error!("{}", e);                      User { -                        jid: logic.bare_jid.clone(), +                        jid: logic.jid.clone(),                          nick: None,                          avatar: None,                      } @@ -192,7 +201,7 @@ pub async fn handle_offline_result<Fs: FileStore + Clone>(              logic                  .update_sender()                  .send(crate::UpdateMessage::Message { -                    to: jid.as_bare(), +                    to: jid,                      message,                      from,                  }) diff --git a/filamento/src/logic/online.rs b/filamento/src/logic/online.rs index 9814ff2..febd3e1 100644 --- a/filamento/src/logic/online.rs +++ b/filamento/src/logic/online.rs @@ -3,7 +3,7 @@ use std::{io::Cursor, time::Duration};  use base64::{prelude::BASE64_STANDARD, Engine};  use chrono::Utc;  use image::ImageReader; -use jid::JID; +use jid::{BareJID, JID};  use lampada::{Connected, WriteMessage, error::WriteError};  use sha1::{Digest, Sha1};  use stanza::{ @@ -41,7 +41,7 @@ pub async fn handle_get_roster<Fs: FileStore + Clone>(  ) -> Result<Vec<Contact>, RosterError> {      let iq_id = Uuid::new_v4().to_string();      let stanza = Stanza::Iq(Iq { -        from: Some(connection.jid().clone()), +        from: Some(connection.jid().clone().into()),          id: iq_id.to_string(),          to: None,          r#type: IqType::Get, @@ -101,7 +101,7 @@ pub async fn handle_get_roster_with_users<Fs: FileStore + Clone>(  ) -> Result<Vec<(Contact, User)>, RosterError> {      let iq_id = Uuid::new_v4().to_string();      let stanza = Stanza::Iq(Iq { -        from: Some(connection.jid().clone()), +        from: Some(connection.jid().clone().into()),          id: iq_id.to_string(),          to: None,          r#type: IqType::Get, @@ -162,11 +162,11 @@ pub async fn handle_get_roster_with_users<Fs: FileStore + Clone>(  pub async fn handle_add_contact<Fs: FileStore + Clone>(      logic: &ClientLogic<Fs>,      connection: Connected, -    jid: JID, +    jid: BareJID,  ) -> Result<(), RosterError> {      let iq_id = Uuid::new_v4().to_string();      let set_stanza = Stanza::Iq(Iq { -        from: Some(connection.jid().clone()), +        from: Some(connection.jid().clone().into()),          id: iq_id.clone(),          to: None,          r#type: IqType::Set, @@ -220,9 +220,10 @@ pub async fn handle_add_contact<Fs: FileStore + Clone>(  pub async fn handle_buddy_request<Fs: FileStore + Clone>(      logic: &ClientLogic<Fs>,      connection: Connected, -    jid: JID, +    jid: BareJID,  ) -> Result<(), SubscribeError> { -    let client_user = logic.db.read_user(logic.bare_jid.clone()).await?; +    let jid: JID = jid.into(); +    let client_user = logic.db.read_user(logic.jid.clone()).await?;      let nick = client_user.nick.map(|nick| Nick(nick));      let presence = Stanza::Presence(stanza::client::presence::Presence {          to: Some(jid.clone()), @@ -243,13 +244,13 @@ pub async fn handle_buddy_request<Fs: FileStore + Clone>(  pub async fn handle_subscription_request<Fs: FileStore + Clone>(      logic: &ClientLogic<Fs>,      connection: Connected, -    jid: JID, +    jid: BareJID,  ) -> Result<(), SubscribeError> {      // TODO: i should probably have builders -    let client_user = logic.db.read_user(logic.bare_jid.clone()).await?; +    let client_user = logic.db.read_user(logic.jid.clone()).await?;      let nick = client_user.nick.map(|nick| Nick(nick));      let presence = Stanza::Presence(stanza::client::presence::Presence { -        to: Some(jid), +        to: Some(jid.into()),          r#type: Some(stanza::client::presence::PresenceType::Subscribe),          nick,          ..Default::default() @@ -261,15 +262,16 @@ pub async fn handle_subscription_request<Fs: FileStore + Clone>(  pub async fn handle_accept_buddy_request<Fs: FileStore + Clone>(      logic: &ClientLogic<Fs>,      connection: Connected, -    jid: JID, +    jid: BareJID,  ) -> Result<(), SubscribeError> { +    let jid: JID = jid.into();      let presence = Stanza::Presence(stanza::client::presence::Presence {          to: Some(jid.clone()),          r#type: Some(stanza::client::presence::PresenceType::Subscribed),          ..Default::default()      });      connection.write_handle().write(presence).await?; -    let client_user = logic.db.read_user(logic.bare_jid.clone()).await?; +    let client_user = logic.db.read_user(logic.jid.clone()).await?;      let nick = client_user.nick.map(|nick| Nick(nick));      let presence = Stanza::Presence(stanza::client::presence::Presence {          to: Some(jid), @@ -284,12 +286,12 @@ pub async fn handle_accept_buddy_request<Fs: FileStore + Clone>(  pub async fn handle_accept_subscription_request<Fs: FileStore + Clone>(      logic: &ClientLogic<Fs>,      connection: Connected, -    jid: JID, +    jid: BareJID,  ) -> Result<(), SubscribeError> { -    let client_user = logic.db.read_user(logic.bare_jid.clone()).await?; +    let client_user = logic.db.read_user(logic.jid.clone()).await?;      let nick = client_user.nick.map(|nick| Nick(nick));      let presence = Stanza::Presence(stanza::client::presence::Presence { -        to: Some(jid), +        to: Some(jid.into()),          r#type: Some(stanza::client::presence::PresenceType::Subscribe),          nick,          ..Default::default() @@ -300,10 +302,10 @@ pub async fn handle_accept_subscription_request<Fs: FileStore + Clone>(  pub async fn handle_unsubscribe_from_contact(      connection: Connected, -    jid: JID, +    jid: BareJID,  ) -> Result<(), WriteError> {      let presence = Stanza::Presence(stanza::client::presence::Presence { -        to: Some(jid), +        to: Some(jid.into()),          r#type: Some(stanza::client::presence::PresenceType::Unsubscribe),          ..Default::default()      }); @@ -311,9 +313,9 @@ pub async fn handle_unsubscribe_from_contact(      Ok(())  } -pub async fn handle_unsubscribe_contact(connection: Connected, jid: JID) -> Result<(), WriteError> { +pub async fn handle_unsubscribe_contact(connection: Connected, jid: BareJID) -> Result<(), WriteError> {      let presence = Stanza::Presence(stanza::client::presence::Presence { -        to: Some(jid), +        to: Some(jid.into()),          r#type: Some(stanza::client::presence::PresenceType::Unsubscribed),          ..Default::default()      }); @@ -321,7 +323,8 @@ pub async fn handle_unsubscribe_contact(connection: Connected, jid: JID) -> Resu      Ok(())  } -pub async fn handle_unfriend_contact(connection: Connected, jid: JID) -> Result<(), WriteError> { +pub async fn handle_unfriend_contact(connection: Connected, jid: BareJID) -> Result<(), WriteError> { +    let jid: JID = jid.into();      let presence = Stanza::Presence(stanza::client::presence::Presence {          to: Some(jid.clone()),          r#type: Some(stanza::client::presence::PresenceType::Unsubscribe), @@ -340,11 +343,11 @@ pub async fn handle_unfriend_contact(connection: Connected, jid: JID) -> Result<  pub async fn handle_delete_contact<Fs: FileStore + Clone>(      logic: &ClientLogic<Fs>,      connection: Connected, -    jid: JID, +    jid: BareJID,  ) -> Result<(), RosterError> {      let iq_id = Uuid::new_v4().to_string();      let set_stanza = Stanza::Iq(Iq { -        from: Some(connection.jid().clone()), +        from: Some(connection.jid().clone().into()),          id: iq_id.clone(),          to: None,          r#type: IqType::Set, @@ -399,7 +402,7 @@ pub async fn handle_delete_contact<Fs: FileStore + Clone>(  pub async fn handle_update_contact<Fs: FileStore + Clone>(      logic: &ClientLogic<Fs>,      connection: Connected, -    jid: JID, +    jid: BareJID,      contact_update: ContactUpdate,  ) -> Result<(), RosterError> {      let iq_id = Uuid::new_v4().to_string(); @@ -410,7 +413,8 @@ pub async fn handle_update_contact<Fs: FileStore + Clone>(              .map(|group| stanza::roster::Group(Some(group))),      );      let set_stanza = Stanza::Iq(Iq { -        from: Some(connection.jid().clone()), +        // TODO: these clones could technically be avoided? +        from: Some(connection.jid().clone().into()),          id: iq_id.clone(),          to: None,          r#type: IqType::Set, @@ -474,7 +478,7 @@ pub async fn handle_set_status<Fs: FileStore + Clone>(      Ok(())  } -pub async fn handle_send_message<Fs: FileStore + Clone>(logic: &ClientLogic<Fs>, connection: Connected, jid: JID, body: Body) { +pub async fn handle_send_message<Fs: FileStore + Clone>(logic: &ClientLogic<Fs>, connection: Connected, jid: BareJID, body: Body) {      // upsert the chat and user the message will be delivered to. if there is a conflict, it will return whatever was there, otherwise it will return false by default.      // let have_chatted = logic.db().upsert_chat_and_user(&jid).await.unwrap_or(false);      let have_chatted  = match logic.db().upsert_chat_and_user(jid.clone()).await { @@ -490,7 +494,7 @@ pub async fn handle_send_message<Fs: FileStore + Clone>(logic: &ClientLogic<Fs>,      let nick;      let mark_chat_as_chatted;      if have_chatted == false { -        match logic.db.read_user(logic.bare_jid.clone()).await { +        match logic.db.read_user(logic.jid.clone()).await {              Ok(u) => {                  nick = u.nick.map(|nick| Nick(nick));                  mark_chat_as_chatted = true; @@ -513,7 +517,7 @@ pub async fn handle_send_message<Fs: FileStore + Clone>(logic: &ClientLogic<Fs>,      let timestamp = Utc::now();      let message = Message {          id, -        from: connection.jid().as_bare(), +        from: connection.jid().to_bare(),          body: body.clone(),          timestamp,          delivery: Some(Delivery::Sending), @@ -532,12 +536,12 @@ pub async fn handle_send_message<Fs: FileStore + Clone>(logic: &ClientLogic<Fs>,              .await;      } -    let from = match logic.db().read_user(logic.bare_jid.clone()).await { +    let from = match logic.db().read_user(logic.jid.clone()).await {          Ok(u) => u,          Err(e) => {              error!("{}", e);              User { -                jid: logic.bare_jid.clone(), +                jid: logic.jid.clone(),                  nick: None,                  avatar: None,              } @@ -548,7 +552,7 @@ pub async fn handle_send_message<Fs: FileStore + Clone>(logic: &ClientLogic<Fs>,      logic          .update_sender()          .send(UpdateMessage::Message { -            to: jid.as_bare(), +            to: jid.clone(),              message,              from,          }) @@ -556,9 +560,9 @@ pub async fn handle_send_message<Fs: FileStore + Clone>(logic: &ClientLogic<Fs>,      // prepare the message stanza      let message_stanza = Stanza::Message(stanza::client::message::Message { -        from: Some(connection.jid().clone()), +        from: Some(connection.jid().clone().into()),          id: Some(id.to_string()), -        to: Some(jid.clone()), +        to: Some(jid.clone().into()),          // TODO: specify message type          r#type: stanza::client::message::MessageType::Chat,          // TODO: lang ? @@ -639,7 +643,7 @@ pub async fn handle_disco_info<Fs: FileStore + Clone>(  ) -> Result<Info, DiscoError> {      let id = Uuid::new_v4().to_string();      let request = Iq { -        from: Some(connection.jid().clone()), +        from: Some(connection.jid().clone().into()),          id: id.clone(),          to: jid.clone(),          r#type: IqType::Get, @@ -667,7 +671,7 @@ pub async fn handle_disco_info<Fs: FileStore + Clone>(          }) if r#type == IqType::Result || r#type == IqType::Error => {              if from == jid || {                  if jid == None { -                    from == Some(connection.jid().as_bare()) +                    from == Some(connection.jid().to_bare().into())                  } else {                      false                  } @@ -694,7 +698,7 @@ pub async fn handle_disco_info<Fs: FileStore + Clone>(                  }              } else {                  Err(DiscoError::IncorrectEntity( -                    from.unwrap_or_else(|| connection.jid().as_bare()), +                    from.unwrap_or_else(|| connection.jid().to_bare().into()),                  ))              }          } @@ -710,7 +714,7 @@ pub async fn handle_disco_items<Fs: FileStore + Clone>(  ) -> Result<Items, DiscoError> {      let id = Uuid::new_v4().to_string();      let request = Iq { -        from: Some(connection.jid().clone()), +        from: Some(connection.jid().clone().into()),          id: id.clone(),          to: jid.clone(),          r#type: IqType::Get, @@ -736,7 +740,7 @@ pub async fn handle_disco_items<Fs: FileStore + Clone>(          }) if r#type == IqType::Result || r#type == IqType::Error => {              if from == jid || {                  if jid == None { -                    from == Some(connection.jid().as_bare()) +                    from == Some(connection.jid().to_bare().into())                  } else {                      false                  } @@ -763,7 +767,7 @@ pub async fn handle_disco_items<Fs: FileStore + Clone>(                  }              } else {                  Err(DiscoError::IncorrectEntity( -                    from.unwrap_or_else(|| connection.jid().as_bare()), +                    from.unwrap_or_else(|| connection.jid().to_bare().into()),                  ))              }          } @@ -828,7 +832,7 @@ pub async fn handle_publish_pep_item<Fs: FileStore + Clone>(          },      };      let request = Iq { -        from: Some(connection.jid().clone()), +        from: Some(connection.jid().clone().into()),          id: id.clone(),          to: None,          r#type: IqType::Set, @@ -850,7 +854,7 @@ pub async fn handle_publish_pep_item<Fs: FileStore + Clone>(              // TODO: maybe abstract a bunch of these different errors related to iqs into an iq error thing? as in like call iq.result(), get the query from inside, error otherwise.          }) if r#type == IqType::Result || r#type == IqType::Error => {              if from == None ||  -                    from == Some(connection.jid().as_bare()) +                    from == Some(connection.jid().to_bare().into())               {                  match r#type {                      IqType::Result => { @@ -870,7 +874,7 @@ pub async fn handle_publish_pep_item<Fs: FileStore + Clone>(                  }              } else {                  Err(PEPError::IncorrectEntity( -                    from.unwrap_or_else(|| connection.jid().as_bare()), +                    from.unwrap_or_else(|| connection.jid().to_bare().into()),                  ))              }          } @@ -878,10 +882,11 @@ pub async fn handle_publish_pep_item<Fs: FileStore + Clone>(      }  } -pub async fn handle_get_pep_item<Fs: FileStore + Clone>(logic: &ClientLogic<Fs>, connection: Connected, jid: Option<JID>, node: String, id: String) -> Result<pep::Item, PEPError> { +pub async fn handle_get_pep_item<Fs: FileStore + Clone>(logic: &ClientLogic<Fs>, connection: Connected, jid: Option<BareJID>, node: String, id: String) -> Result<pep::Item, PEPError> { +    let jid = jid.map(|jid| Into::<JID>::into(jid));      let stanza_id = Uuid::new_v4().to_string();      let request = Iq { -        from: Some(connection.jid().clone()), +        from: Some(connection.jid().clone().into()),          id: stanza_id.clone(),          to: jid.clone(),          r#type: IqType::Get, @@ -909,7 +914,7 @@ pub async fn handle_get_pep_item<Fs: FileStore + Clone>(logic: &ClientLogic<Fs>,          }) if r#type == IqType::Result || r#type == IqType::Error => {              if from == jid || {                  if jid == None { -                    from == Some(connection.jid().as_bare()) +                    from == Some(connection.jid().to_bare().into())                  } else {                      false                  } @@ -955,7 +960,7 @@ pub async fn handle_get_pep_item<Fs: FileStore + Clone>(logic: &ClientLogic<Fs>,              } else {                  // TODO: include expected entity                  Err(PEPError::IncorrectEntity( -                    from.unwrap_or_else(|| connection.jid().as_bare()), +                    from.unwrap_or_else(|| connection.jid().to_bare().into()),                  ))              }          } @@ -1024,7 +1029,7 @@ pub async fn handle_delete_pep_node<Fs: FileStore + Clone>(  ) -> Result<(), PEPError> {      let id = Uuid::new_v4().to_string();      let request = Iq { -        from: Some(connection.jid().clone()), +        from: Some(connection.jid().clone().into()),          id: id.clone(),          to: None,          r#type: IqType::Set, @@ -1046,7 +1051,7 @@ pub async fn handle_delete_pep_node<Fs: FileStore + Clone>(              // TODO: maybe abstract a bunch of these different errors related to iqs into an iq error thing? as in like call iq.result(), get the query from inside, error otherwise.          }) if r#type == IqType::Result || r#type == IqType::Error => {              if from == None ||  -                    from == Some(connection.jid().as_bare()) +                    from == Some(connection.jid().to_bare().into())               {                  match r#type {                      IqType::Result => { @@ -1067,7 +1072,7 @@ pub async fn handle_delete_pep_node<Fs: FileStore + Clone>(                  }              } else {                  Err(PEPError::IncorrectEntity( -                    from.unwrap_or_else(|| connection.jid().as_bare()), +                    from.unwrap_or_else(|| connection.jid().to_bare().into()),                  ))              }          } diff --git a/filamento/src/logic/process_stanza.rs b/filamento/src/logic/process_stanza.rs index 30d0830..67b0d3f 100644 --- a/filamento/src/logic/process_stanza.rs +++ b/filamento/src/logic/process_stanza.rs @@ -70,7 +70,7 @@ pub async fn recv_message<Fs: FileStore + Clone>(                      // TODO: proper id xep                      .map(|id| Uuid::from_str(&id).unwrap_or_else(|_| Uuid::new_v4()))                      .unwrap_or_else(|| Uuid::new_v4()), -                from: from.as_bare(), +                from: from.to_bare(),                  timestamp,                  body: Body {                      body: body.body.unwrap_or_default(), @@ -80,31 +80,34 @@ pub async fn recv_message<Fs: FileStore + Clone>(              // TODO: process message type="error"              // save the message to the database -            match logic.db().upsert_chat_and_user(from.clone()).await { -                Ok(_) => { -                    if let Err(e) = logic -                        .db() -                        .create_message_with_user_resource( -                            message.clone(), -                            from.clone(), -                            from.clone(), -                        ) -                        .await -                    { -                        error!("failed to create message: {}", e); +            match logic.db().upsert_chat_and_user(from.to_bare()).await { +                Ok(_) => match from.as_full() { +                    Ok(from) => { +                        if let Err(e) = logic +                            .db() +                            .create_message_with_user_resource( +                                message.clone(), +                                from.to_bare(), +                                from.clone(), +                            ) +                            .await +                        { +                            error!("failed to create message: {}", e); +                        }                      } -                } +                    Err(e) => error!("failed to create message: {}", e), +                },                  Err(e) => {                      error!("failed to upsert chat and user: {}", e);                  }              }; -            let from_user = match logic.db().read_user(from.as_bare()).await { +            let from_user = match logic.db().read_user(from.to_bare()).await {                  Ok(u) => u,                  Err(e) => {                      error!("{}", e);                      User { -                        jid: from.as_bare(), +                        jid: from.to_bare(),                          nick: None,                          avatar: None,                      } @@ -115,7 +118,7 @@ pub async fn recv_message<Fs: FileStore + Clone>(              logic                  .update_sender()                  .send(UpdateMessage::Message { -                    to: from.as_bare(), +                    to: from.to_bare(),                      from: from_user,                      message,                  }) @@ -125,13 +128,13 @@ pub async fn recv_message<Fs: FileStore + Clone>(          if let Some(nick) = stanza_message.nick {              let nick = nick.0;              if nick.is_empty() { -                match logic.db().delete_user_nick(from.as_bare()).await { +                match logic.db().delete_user_nick(from.to_bare()).await {                      Ok(changed) => {                          if changed {                              logic                                  .update_sender()                                  .send(UpdateMessage::NickChanged { -                                    jid: from.as_bare(), +                                    jid: from.to_bare(),                                      nick: None,                                  })                                  .await; @@ -145,7 +148,7 @@ pub async fn recv_message<Fs: FileStore + Clone>(                          logic                              .update_sender()                              .send(UpdateMessage::NickChanged { -                                jid: from.as_bare(), +                                jid: from.to_bare(),                                  nick: None,                              })                              .await; @@ -154,7 +157,7 @@ pub async fn recv_message<Fs: FileStore + Clone>(              } else {                  match logic                      .db() -                    .upsert_user_nick(from.as_bare(), nick.clone()) +                    .upsert_user_nick(from.to_bare(), nick.clone())                      .await                  {                      Ok(changed) => { @@ -162,7 +165,7 @@ pub async fn recv_message<Fs: FileStore + Clone>(                              logic                                  .update_sender()                                  .send(UpdateMessage::NickChanged { -                                    jid: from.as_bare(), +                                    jid: from.to_bare(),                                      nick: Some(nick),                                  })                                  .await; @@ -176,7 +179,7 @@ pub async fn recv_message<Fs: FileStore + Clone>(                          logic                              .update_sender()                              .send(UpdateMessage::NickChanged { -                                jid: from.as_bare(), +                                jid: from.to_bare(),                                  nick: Some(nick),                              })                              .await; @@ -199,7 +202,7 @@ pub async fn recv_message<Fs: FileStore + Clone>(                                                  if nick.is_empty() {                                                      match logic                                                          .db() -                                                        .delete_user_nick(from.as_bare()) +                                                        .delete_user_nick(from.to_bare())                                                          .await                                                      {                                                          Ok(changed) => { @@ -207,7 +210,7 @@ pub async fn recv_message<Fs: FileStore + Clone>(                                                                  logic                                                                  .update_sender()                                                                  .send(UpdateMessage::NickChanged { -                                                                    jid: from.as_bare(), +                                                                    jid: from.to_bare(),                                                                      nick: None,                                                                  })                                                                  .await; @@ -223,7 +226,7 @@ pub async fn recv_message<Fs: FileStore + Clone>(                                                              logic                                                                  .update_sender()                                                                  .send(UpdateMessage::NickChanged { -                                                                    jid: from.as_bare(), +                                                                    jid: from.to_bare(),                                                                      nick: None,                                                                  })                                                                  .await; @@ -233,7 +236,7 @@ pub async fn recv_message<Fs: FileStore + Clone>(                                                      match logic                                                          .db()                                                          .upsert_user_nick( -                                                            from.as_bare(), +                                                            from.to_bare(),                                                              nick.clone(),                                                          )                                                          .await @@ -243,7 +246,7 @@ pub async fn recv_message<Fs: FileStore + Clone>(                                                                  logic                                                                  .update_sender()                                                                  .send(UpdateMessage::NickChanged { -                                                                    jid: from.as_bare(), +                                                                    jid: from.to_bare(),                                                                      nick: Some(nick),                                                                  })                                                                  .await; @@ -259,7 +262,7 @@ pub async fn recv_message<Fs: FileStore + Clone>(                                                              logic                                                                  .update_sender()                                                                  .send(UpdateMessage::NickChanged { -                                                                    jid: from.as_bare(), +                                                                    jid: from.to_bare(),                                                                      nick: Some(nick),                                                                  })                                                                  .await; @@ -294,7 +297,7 @@ pub async fn recv_message<Fs: FileStore + Clone>(                                                      match logic                                                          .db()                                                          .upsert_user_avatar( -                                                            from.as_bare(), +                                                            from.to_bare(),                                                              metadata.id.clone(),                                                          )                                                          .await @@ -323,7 +326,7 @@ pub async fn recv_message<Fs: FileStore + Clone>(                                                                      }) {                                                                      Ok(false) => {                                                                          // get data -                                                                        let pep_item = logic.client().get_pep_item(Some(from.as_bare()), "urn:xmpp:avatar:data".to_string(), metadata.id.clone()).await.map_err(|err| Into::<AvatarUpdateError<Fs>>::into(err))?; +                                                                        let pep_item = logic.client().get_pep_item(Some(from.to_bare()), "urn:xmpp:avatar:data".to_string(), metadata.id.clone()).await.map_err(|err| Into::<AvatarUpdateError<Fs>>::into(err))?;                                                                          match pep_item {                                                                              crate::pep::Item::AvatarData(data) => {                                                                                  let data = data.map(|data| data.data_b64).unwrap_or_default().replace("\n", ""); @@ -344,7 +347,7 @@ pub async fn recv_message<Fs: FileStore + Clone>(                                                                                                  .update_sender()                                                                                                  .send(                                                                                                      UpdateMessage::AvatarChanged { -                                                                                                        jid: from.as_bare(), +                                                                                                        jid: from.to_bare(),                                                                                                          id: Some(                                                                                                              metadata.id.clone(),                                                                                                          ), @@ -371,7 +374,7 @@ pub async fn recv_message<Fs: FileStore + Clone>(                                                                          .update_sender()                                                                          .send(                                                                              UpdateMessage::AvatarChanged { -                                                                                jid: from.as_bare(), +                                                                                jid: from.to_bare(),                                                                                  id: Some(                                                                                      metadata.id.clone(),                                                                                  ), @@ -401,7 +404,7 @@ pub async fn recv_message<Fs: FileStore + Clone>(                                                      // delete avatar                                                      match logic                                                          .db() -                                                        .delete_user_avatar(from.as_bare()) +                                                        .delete_user_avatar(from.to_bare())                                                          .await                                                      {                                                          Ok((changed, old_avatar)) => { @@ -419,7 +422,7 @@ pub async fn recv_message<Fs: FileStore + Clone>(                                                                      .update_sender()                                                                      .send(                                                                          UpdateMessage::AvatarChanged { -                                                                            jid: from.as_bare(), +                                                                            jid: from.to_bare(),                                                                              id: None,                                                                          },                                                                      ) @@ -488,6 +491,7 @@ pub async fn recv_presence(                  }                  stanza::client::presence::PresenceType::Subscribe => {                      // may get a subscription request from somebody who is not a contact!!! therefore should be its own kind of event +                    let from = from.try_into()?;                      Ok(Some(UpdateMessage::SubscriptionRequest(from)))                  }                  stanza::client::presence::PresenceType::Unavailable => { @@ -546,7 +550,8 @@ pub async fn recv_iq<Fs: FileStore + Clone>(      iq: Iq,  ) -> Result<Option<UpdateMessage>, IqProcessError> {      if let Some(to) = &iq.to { -        if *to == *connection.jid() { +        // TODO: this clone could mayb b avoided +        if *to == connection.jid().clone().into() {          } else {              return Err(IqProcessError::Iq(IqError::IncorrectAddressee(to.clone())));          } @@ -556,7 +561,9 @@ pub async fn recv_iq<Fs: FileStore + Clone>(              let from = iq                  .from                  .clone() -                .unwrap_or_else(|| connection.server().clone()); +                // TODO: maybe actually store the server in the connection again LOL +                // .unwrap_or_else(|| connection.server().clone()); +                .unwrap_or_else(|| connection.jid().domainpart.parse().unwrap());              let id = iq.id.clone();              debug!("received iq result with id `{}` from {}", id, from);              logic @@ -570,7 +577,8 @@ pub async fn recv_iq<Fs: FileStore + Clone>(              let from = iq                  .from                  .clone() -                .unwrap_or_else(|| connection.server().clone()); +                // .unwrap_or_else(|| connection.server().clone()); +                .unwrap_or_else(|| connection.jid().domainpart.parse().unwrap());              if let Some(query) = iq.query {                  match query {                      stanza::client::iq::Query::DiscoInfo(query) => { @@ -594,7 +602,7 @@ pub async fn recv_iq<Fs: FileStore + Clone>(                                          }                                          Err(_e) => {                                              let iq = Iq { -                                                from: Some(connection.jid().clone()), +                                                from: Some(connection.jid().clone().into()),                                                  id: iq.id,                                                  to: iq.from,                                                  r#type: IqType::Error, @@ -614,7 +622,7 @@ pub async fn recv_iq<Fs: FileStore + Clone>(                                      },                                      Err(_e) => {                                          let iq = Iq { -                                            from: Some(connection.jid().clone()), +                                            from: Some(connection.jid().clone().into()),                                              id: iq.id,                                              to: iq.from,                                              r#type: IqType::Error, @@ -634,7 +642,7 @@ pub async fn recv_iq<Fs: FileStore + Clone>(                                  }                              };                          let iq = Iq { -                            from: Some(connection.jid().clone()), +                            from: Some(connection.jid().clone().into()),                              id: iq.id,                              to: iq.from,                              r#type: IqType::Result, @@ -653,7 +661,7 @@ pub async fn recv_iq<Fs: FileStore + Clone>(                      _ => {                          warn!("received unsupported iq get from {}", from);                          let iq = Iq { -                            from: Some(connection.jid().clone()), +                            from: Some(connection.jid().clone().into()),                              id: iq.id,                              to: iq.from,                              r#type: IqType::Error, @@ -677,7 +685,7 @@ pub async fn recv_iq<Fs: FileStore + Clone>(              } else {                  info!("received malformed iq query from {}", from);                  let iq = Iq { -                    from: Some(connection.jid().clone()), +                    from: Some(connection.jid().clone().into()),                      id: iq.id,                      to: iq.from,                      r#type: IqType::Error, @@ -698,7 +706,8 @@ pub async fn recv_iq<Fs: FileStore + Clone>(              let from = iq                  .from                  .clone() -                .unwrap_or_else(|| connection.server().clone()); +                // .unwrap_or_else(|| connection.server().clone()); +                .unwrap_or_else(|| connection.jid().domainpart.parse().unwrap());              if let Some(query) = iq.query {                  match query {                      stanza::client::iq::Query::Roster(mut query) => { @@ -725,7 +734,7 @@ pub async fn recv_iq<Fs: FileStore + Clone>(                                              .await;                                      }                                      let iq = Iq { -                                        from: Some(connection.jid().clone()), +                                        from: Some(connection.jid().clone().into()),                                          id: iq.id,                                          to: iq.from,                                          r#type: IqType::Result, @@ -751,7 +760,7 @@ pub async fn recv_iq<Fs: FileStore + Clone>(                          } else {                              warn!("received malformed roster push");                              let iq = Iq { -                                from: Some(connection.jid().clone()), +                                from: Some(connection.jid().clone().into()),                                  id: iq.id,                                  to: iq.from,                                  r#type: IqType::Error, @@ -771,7 +780,7 @@ pub async fn recv_iq<Fs: FileStore + Clone>(                      _ => {                          warn!("received unsupported iq set from {}", from);                          let iq = Iq { -                            from: Some(connection.jid().clone()), +                            from: Some(connection.jid().clone().into()),                              id: iq.id,                              to: iq.from,                              r#type: IqType::Error, @@ -791,7 +800,7 @@ pub async fn recv_iq<Fs: FileStore + Clone>(              } else {                  warn!("received malformed iq set from {}", from);                  let iq = Iq { -                    from: Some(connection.jid().clone()), +                    from: Some(connection.jid().clone().into()),                      id: iq.id,                      to: iq.from,                      r#type: IqType::Error, @@ -820,7 +829,7 @@ pub async fn process_stanza<Fs: FileStore + Clone>(          Stanza::Presence(presence) => Ok(recv_presence(presence).await?),          Stanza::Iq(iq) => Ok(recv_iq(logic, connection.clone(), iq).await?),          // unreachable, always caught by lampada -        // TODO: make cleaner than this in some way +        // TODO: make cleaner than this in some way, by just reexporting a stanza enum from lampada ig.          Stanza::Error(error) => {              unreachable!()          } | 
