xmpp-rs/xmpp/examples/hello_bot.rs
2024-12-18 21:55:01 +01:00

104 lines
3.5 KiB
Rust

// Copyright (c) 2019 Emmanuel Gil Peyrot <linkmauve@linkmauve.fr>
//
// This Source Code Form is subject to the terms of the Mozilla Public
// 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 xmpp::{
jid::BareJid,
muc::room::{JoinRoomSettings, RoomMessageSettings},
ClientBuilder, ClientFeature, ClientType, Event, RoomNick,
};
use std::env::args;
use std::str::FromStr;
#[tokio::main]
async fn main() -> Result<(), Option<()>> {
env_logger::init();
let args: Vec<String> = args().collect();
if args.len() < 3 {
println!("Usage: {} <jid> <password> [ROOM...]", args[0]);
return Err(None);
}
let jid = BareJid::from_str(&args[1]).expect(&format!("Invalid JID: {}", &args[1]));
let password = &args[2];
// Figure out which rooms to join to say hello
let mut rooms: Vec<BareJid> = Vec::new();
let mut counter = 3;
if args.len() > 3 {
while counter < args.len() {
match BareJid::from_str(&args[counter]) {
Ok(jid) => rooms.push(jid),
Err(e) => {
log::error!("Requested room {} is not a valid JID: {e}", args[counter]);
std::process::exit(1);
}
}
counter += 1;
}
}
let nick = RoomNick::from_str("bot").unwrap();
// Client instance
let mut client = ClientBuilder::new(jid, password)
.set_client(ClientType::Bot, "xmpp-rs")
.set_website("https://gitlab.com/xmpp-rs/xmpp-rs")
.set_default_nick(nick)
.enable_feature(ClientFeature::ContactList)
.enable_feature(ClientFeature::JoinRooms)
.build();
log::info!("Connecting...");
loop {
for event in client.wait_for_events().await {
match event {
Event::Online => {
log::info!("Online.");
for room in &rooms {
log::info!("Joining room {} from CLI argument…", room);
client
.join_room(JoinRoomSettings {
room: room.clone(),
nick: None,
password: None,
status: Some(("en", "Yet another bot!")),
})
.await;
}
}
Event::Disconnected(e) => {
log::info!("Disconnected: {}.", e);
}
Event::ChatMessage(_id, jid, body, time_info) => {
log::info!(
"{} {}: {}",
time_info.received.time().format("%H:%M"),
jid,
body.0
);
}
Event::RoomJoined(jid) => {
log::info!("Joined room {}.", jid);
client
.send_room_message(RoomMessageSettings::new(jid, "Hello world!"))
.await;
}
Event::RoomMessage(_id, jid, nick, body, time_info) => {
println!(
"Message in room {} from {} at {}: {}",
jid, nick, time_info.received, body.0
);
}
_ => {
log::debug!("Unimplemented event:\n{:#?}", event);
}
}
}
}
}