2025-04-10 11:28:15 +05:00
|
|
|
use std::{collections::HashMap, sync::Arc};
|
2025-04-08 17:48:38 +05:00
|
|
|
|
2025-04-10 11:28:15 +05:00
|
|
|
use futures::{SinkExt, StreamExt};
|
|
|
|
use tokio::{net::TcpListener, spawn, sync::{mpsc::{channel, Receiver, Sender}, Mutex}};
|
|
|
|
use tokio_tungstenite::{accept_async, tungstenite::Message};
|
|
|
|
|
|
|
|
#[tokio::main]
|
|
|
|
async fn main() {
|
2025-04-09 22:11:17 +05:00
|
|
|
let mut connection_count: usize = 0;
|
|
|
|
let senders = Arc::new(Mutex::new(HashMap::<usize, Sender<Arc<Message>>>::new()));
|
|
|
|
|
2025-04-10 11:28:15 +05:00
|
|
|
let server = TcpListener::bind("0.0.0.0:9001").await.unwrap();
|
|
|
|
|
|
|
|
while let Ok((stream, socket)) = server.accept().await {
|
|
|
|
|
|
|
|
println!("Connection Received from ip: {}, port: {}", socket.ip(), socket.port());
|
2025-04-09 22:11:17 +05:00
|
|
|
|
|
|
|
let t_senders = Arc::clone(&senders);
|
2025-04-10 11:28:15 +05:00
|
|
|
let (sender, mut receiver): (Sender<Arc<Message>>, Receiver<Arc<Message>>) = channel(100);
|
2025-04-09 22:11:17 +05:00
|
|
|
{
|
2025-04-10 11:28:15 +05:00
|
|
|
let mut sender_lock = t_senders.lock().await;
|
2025-04-09 22:11:17 +05:00
|
|
|
connection_count += 1;
|
|
|
|
(*sender_lock).insert(connection_count, sender);
|
|
|
|
}
|
|
|
|
|
2025-04-10 11:28:15 +05:00
|
|
|
let websocket = accept_async(stream).await.unwrap();
|
|
|
|
let (mut websocket_send, mut websocket_read) = websocket.split();
|
|
|
|
|
|
|
|
spawn(async move {
|
2025-04-09 22:11:17 +05:00
|
|
|
let id = connection_count;
|
|
|
|
println!("Connection Received: {}", id);
|
2025-04-10 11:28:15 +05:00
|
|
|
|
|
|
|
while let Some(res) = websocket_read.next().await {
|
2025-04-08 17:48:38 +05:00
|
|
|
match res {
|
2025-04-09 22:11:17 +05:00
|
|
|
Ok(msg) => {
|
|
|
|
let arc_msg = Arc::new(msg);
|
|
|
|
if arc_msg.is_close() {
|
2025-04-10 11:28:15 +05:00
|
|
|
let sender_lock = t_senders.lock().await;
|
2025-04-09 22:11:17 +05:00
|
|
|
let arc_msg_clone = Arc::clone(&arc_msg);
|
2025-04-10 11:28:15 +05:00
|
|
|
match (*sender_lock).get(&id).unwrap().send(arc_msg_clone).await {
|
2025-04-09 22:11:17 +05:00
|
|
|
Ok(_) => println!("close message sent to thread no {}", id),
|
|
|
|
Err(e) => println!("My Error: {}", e)
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
else if arc_msg.is_text() || arc_msg.is_binary() {
|
2025-04-10 11:28:15 +05:00
|
|
|
let sender_lock = t_senders.lock().await;
|
|
|
|
for (iter_id, sender) in (*sender_lock).iter() {
|
2025-04-09 22:11:17 +05:00
|
|
|
let arc_msg_clone = Arc::clone(&arc_msg);
|
|
|
|
if *iter_id != id {
|
2025-04-10 11:28:15 +05:00
|
|
|
match (*sender).send(arc_msg_clone).await {
|
2025-04-09 22:11:17 +05:00
|
|
|
Ok(_) => println!("message sent to thread no {}", *iter_id),
|
|
|
|
Err(e) => println!("My Error: {}", e)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2025-04-08 17:48:38 +05:00
|
|
|
}
|
|
|
|
Err(e) => {
|
2025-04-10 11:28:15 +05:00
|
|
|
let mut sender_lock = t_senders.lock().await;
|
|
|
|
(*sender_lock).remove(&id);
|
2025-04-08 17:48:38 +05:00
|
|
|
println!("MyError Occured: {}", e);
|
2025-04-09 22:11:17 +05:00
|
|
|
println!("Connection Closed");
|
2025-04-08 17:48:38 +05:00
|
|
|
break;
|
|
|
|
}
|
2025-04-09 22:11:17 +05:00
|
|
|
}
|
2025-04-08 17:48:38 +05:00
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
});
|
2025-04-09 22:11:17 +05:00
|
|
|
|
2025-04-10 11:28:15 +05:00
|
|
|
spawn(async move {
|
2025-04-09 22:11:17 +05:00
|
|
|
let id = connection_count;
|
|
|
|
loop {
|
2025-04-10 11:28:15 +05:00
|
|
|
match receiver.recv().await {
|
|
|
|
Some(arc_msg) => {
|
2025-04-09 22:11:17 +05:00
|
|
|
println!("Message received by thread {}", id);
|
|
|
|
println!("The message is {}", arc_msg);
|
|
|
|
let msg = (*arc_msg).clone();
|
2025-04-10 11:28:15 +05:00
|
|
|
match websocket_send.send(msg).await {
|
|
|
|
Ok(_) => println!("message sent to client {}", id),
|
|
|
|
Err(e) => {
|
|
|
|
println!("error in sending to client {}: {}", id, e);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
2025-04-09 22:11:17 +05:00
|
|
|
}
|
2025-04-10 11:28:15 +05:00
|
|
|
None => {
|
|
|
|
println!("Error in receiving from other threads");
|
2025-04-09 22:11:17 +05:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2025-04-08 17:48:38 +05:00
|
|
|
}
|
2025-04-07 17:31:16 +05:00
|
|
|
}
|