发送消息区分广播消息和定向消息

This commit is contained in:
李运家 2025-03-12 19:08:12 +08:00
parent 2f6622bf75
commit c2515858a8

View File

@ -9,7 +9,7 @@ use futures::stream::{SplitSink, SplitStream};
use futures::{SinkExt, StreamExt};
use lazy_static::lazy_static;
use library::context::Context;
use library::model::response::ResResult;
use library::model::response::{ResErr, ResResult};
lazy_static!{
static ref WS_POOL: DashMap<String, Arc<Mutex<SplitSink<WebSocket, Message>>>> = DashMap::<String, Arc<Mutex<SplitSink<WebSocket, Message>>>>::new();
@ -24,15 +24,17 @@ pub async fn handle_socket(socket: WebSocket, _who: SocketAddr, context: Context
// tokio::spawn(write(sender));
tokio::spawn(read(account.id.clone(), receiver));
// 测试消息发送
tokio::spawn(send());
WS_POOL.insert(account.id.clone(), Arc::new(Mutex::new(sender)));
}
/// 测试消息发送
async fn send() {
loop {
tokio::time::sleep(std::time::Duration::from_millis(2000)).await;
send_message(Message::Text("哈哈".into())).await;
let _ = broadcast_message(Message::Text("哈哈".into())).await;
}
}
@ -76,14 +78,26 @@ fn process_message(msg: Message) -> ControlFlow<(), ()> {
ControlFlow::Continue(())
}
pub async fn send_message(msg: Message) -> ResResult<()> {
/// 发送广播消息
pub async fn broadcast_message(msg: Message) {
for ele in WS_POOL.iter() {
let mut sender = ele.value().lock().await;
if let Err(err) = sender.send(msg.clone()).await {
tracing::error!("Failed to send message: {:?}", err);
}
}
Ok(())
}
/// 发送定向消息
pub async fn send_message(msg: Message, accoudIds: Vec<String>) {
for ele in WS_POOL.iter() {
let mut sender = ele.value().lock().await;
if accoudIds.contains(&ele.key().to_string()) {
if let Err(err) = sender.send(msg.clone()).await {
tracing::error!("Failed to send message: {:?}", err);
}
}
}
}
// async fn write(mut sender: SplitSink<WebSocket, Message>) {