icalingua-python-bot/ica-rs/src/main.rs

53 lines
1.6 KiB
Rust
Raw Normal View History

2024-02-18 21:25:42 +08:00
use std::time::Duration;
use rust_socketio::ClientBuilder;
2024-02-20 14:47:53 +08:00
use tracing::info;
2024-02-18 21:25:42 +08:00
mod client;
mod config;
2024-02-18 21:25:42 +08:00
mod data_struct;
mod events;
mod py;
2024-02-20 14:47:53 +08:00
#[allow(non_upper_case_globals)]
pub static mut ClientStatus: client::IcalinguaStatus = client::IcalinguaStatus {
login: false,
online_data: None,
rooms: None,
};
fn main() {
tracing_subscriber::fmt()
.with_max_level(tracing::Level::DEBUG)
.init();
py::init_py();
2023-12-11 18:17:55 +08:00
// 从命令行获取 host 和 key
2023-12-24 17:27:15 +08:00
// 从命令行获取配置文件路径
let ica_config = config::IcaConfig::new_from_cli();
let ica_singer = client::IcalinguaSinger::new_from_config(ica_config);
2023-12-24 17:27:15 +08:00
let socket = ClientBuilder::new(ica_singer.host.clone())
2024-02-10 12:18:09 +08:00
.transport_type(rust_socketio::TransportType::Websocket)
2024-02-18 21:25:42 +08:00
.on_any(events::any_event)
.on("requireAuth", move |a, b| ica_singer.sign_callback(a, b))
2024-02-20 17:15:14 +08:00
.on("message", events::connect_callback)
2024-02-18 21:25:42 +08:00
.on("authSucceed", events::connect_callback)
.on("authFailed", events::connect_callback)
.on("onlineData", events::get_online_data)
2024-02-20 15:47:59 +08:00
.on("setAllRooms", events::update_all_room)
.on("addMessage", events::add_message)
.on("deleteMessage", events::delete_message)
.connect()
.expect("Connection failed");
2024-02-18 23:17:43 +08:00
info!("Connected");
std::thread::sleep(Duration::from_secs(3));
// 等待一个输入
info!("Press any key to exit");
let mut input = String::new();
std::io::stdin().read_line(&mut input).unwrap();
socket.disconnect().expect("Disconnect failed");
info!("Disconnected");
}