use tokio_xmpp::{
jid::Jid,
parsers::{confirm::Confirm, message::Message, message_correct::Replace, muc::user::MucUser},
};
use crate::{Agent, Event, RoomNick, delay::StanzaTimeInfo};
pub async fn handle_message_chat(
agent: &mut Agent,
events: &mut Vec<Event>,
from: Jid,
message: &mut Message,
time_info: StanzaTimeInfo,
) {
let config = agent.get_config().await;
let langs: Vec<&str> = config.lang.iter().map(String::as_str).collect();
let confirm = message.extract_valid_payload::<Confirm>();
let is_muc_pm = message.extract_valid_payload::<MucUser>().is_some();
if !is_muc_pm && confirm.is_some() {
events.push(Event::AuthConfirm(
from.to_bare(),
confirm.unwrap(),
time_info,
));
return;
}
let Some((_lang, body)) = message.get_best_body_cloned(langs) else {
return;
};
let correction = message.extract_valid_payload::<Replace>();
if is_muc_pm {
if from.resource().is_none() {
warn!(
"Received malformed MessageType::Chat in muc#user namespace from a bare JID:\n{message:#?}"
);
} else {
let full_from = from.clone().try_into_full().unwrap();
let event = if let Some(correction) = correction {
Event::RoomPrivateMessageCorrection(
correction.id,
full_from.to_bare(),
RoomNick::from_resource_ref(full_from.resource()),
body.clone(),
time_info,
)
} else {
Event::RoomPrivateMessage(
message.id.clone(),
from.to_bare(),
RoomNick::from_resource_ref(full_from.resource()),
body.clone(),
time_info,
)
};
events.push(event);
}
} else {
let event = if let Some(correction) = correction {
Event::ChatMessageCorrection(correction.id, from.to_bare(), body.clone(), time_info)
} else {
Event::ChatMessage(message.id.clone(), from.to_bare(), body, time_info)
};
events.push(event);
}
}
pub async fn handle_message_error(
_agent: &mut Agent,
events: &mut Vec<Event>,
from: Jid,
message: &mut Message,
time_info: StanzaTimeInfo,
) {
let confirm = message.extract_valid_payload::<Confirm>();
if let Some(confirm) = confirm {
events.push(Event::AuthReject(from.to_bare(), confirm, time_info));
}
}