forked from emma/liminality
rewrite
This commit is contained in:
parent
ed09e931c7
commit
410c0d5068
101
src/main.rs
101
src/main.rs
@ -17,89 +17,74 @@
|
||||
*/
|
||||
|
||||
use std::{
|
||||
io::Read,
|
||||
io::{ self, BufRead, BufReader, Write },
|
||||
net::{ TcpListener, TcpStream },
|
||||
thread,
|
||||
};
|
||||
|
||||
use serde_derive::Deserialize;
|
||||
|
||||
#[derive(Debug, Deserialize)]
|
||||
struct MessageOuter {
|
||||
auth: Option<String>,
|
||||
message: Message,
|
||||
to: String,
|
||||
}
|
||||
|
||||
#[derive(Debug, Deserialize)]
|
||||
struct Message {
|
||||
body: String,
|
||||
from: Option<String>,
|
||||
body: Option<String>,
|
||||
}
|
||||
|
||||
fn parse_message(input: &str) -> MessageOuter {
|
||||
let mut auth: Option<String> = None;
|
||||
let mut body = String::new();
|
||||
let mut from = None;
|
||||
let mut to = String::new();
|
||||
fn handle_client(stream: TcpStream) {
|
||||
let mut reader = BufReader::new(&stream);
|
||||
let mut writer = &stream;
|
||||
|
||||
for line in input.lines() {
|
||||
let mut parts = line.split_whitespace();
|
||||
if let Some(field) = parts.next() {
|
||||
if let Some(value) = parts.next() {
|
||||
match field {
|
||||
"AUTH" => auth = Some(value.to_string()),
|
||||
"BODY" => body = value.to_string(),
|
||||
"FROM" => from = Some(value.to_string()),
|
||||
"TO" => to = value.to_string(),
|
||||
_ => {},
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
let message_outer = MessageOuter {
|
||||
auth,
|
||||
message: Message { body, from },
|
||||
to,
|
||||
let mut message = Message {
|
||||
from: None,
|
||||
body: None,
|
||||
};
|
||||
|
||||
message_outer
|
||||
loop {
|
||||
let mut send = false;
|
||||
let mut buffer = String::new();
|
||||
if reader.read_line(&mut buffer).is_err() {
|
||||
println!(
|
||||
"{} disconnected.",
|
||||
message.from.unwrap_or_else(|| { format!("anon") }),
|
||||
);
|
||||
break;
|
||||
}
|
||||
|
||||
fn read_from(mut stream: TcpStream) {
|
||||
let mut buf = Vec::new();
|
||||
let words: Vec<&str> = buffer.split_whitespace().collect();
|
||||
if words.is_empty() {
|
||||
continue;
|
||||
}
|
||||
|
||||
while let Ok(bytes_read) = stream.read_to_end(&mut buf) {
|
||||
if bytes_read == 0 { break }
|
||||
match words[0] {
|
||||
"FROM" => {
|
||||
message.from = Some(words[1..].join(" "));
|
||||
}
|
||||
"BODY" => {
|
||||
message.body = Some(words[1..].join(" "));
|
||||
send = true;
|
||||
}
|
||||
_ => {}
|
||||
}
|
||||
|
||||
let message_outer = parse_message(
|
||||
String::from_utf8(buf.clone()).as_ref().unwrap()
|
||||
if send {
|
||||
println!(
|
||||
"{}: {}",
|
||||
message.from.clone().unwrap_or_else(|| { format!("anon") }),
|
||||
message.body.take().unwrap(),
|
||||
);
|
||||
|
||||
let user = message_outer.message.from.unwrap_or_else(|| {
|
||||
format!("anon")
|
||||
});
|
||||
|
||||
println!("{}: {}", user, message_outer.message.body);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
fn main() {
|
||||
let listener = TcpListener::bind("127.0.0.1:8080")
|
||||
.expect("Failed to bind address");
|
||||
|
||||
println!("Server listening on 127.0.0.1:8080");
|
||||
let listener = TcpListener::bind("0.0.0.0:8080")
|
||||
.expect("Failed to bind to port 8080.");
|
||||
println!("Server listening on port 8080.");
|
||||
|
||||
for stream in listener.incoming() {
|
||||
match stream {
|
||||
Ok(stream) => {
|
||||
thread::spawn(move || {
|
||||
read_from(stream);
|
||||
});
|
||||
thread::spawn(move || handle_client(stream));
|
||||
}
|
||||
Err(err) => {
|
||||
eprintln!("Error accepting client connection: {}", err);
|
||||
Err(e) => {
|
||||
eprintln!("Error accepting client connection: {}", e);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
123
temp.rs
Normal file
123
temp.rs
Normal file
@ -0,0 +1,123 @@
|
||||
use std::io::{Read, Write};
|
||||
use std::net::{TcpListener, TcpStream};
|
||||
use std::sync::{Arc, Mutex};
|
||||
use std::thread;
|
||||
|
||||
#[derive(Debug, Deserialize)]
|
||||
struct MessageOuter {
|
||||
auth: Option<String>,
|
||||
message: Message,
|
||||
to: String,
|
||||
}
|
||||
|
||||
#[derive(Debug, Deserialize)]
|
||||
struct Message {
|
||||
body: String,
|
||||
from: Option<String>,
|
||||
}
|
||||
|
||||
fn parse_message(input: &str) -> MessageOuter {
|
||||
let mut auth: Option<String> = None;
|
||||
let mut body = String::new();
|
||||
let mut from = None;
|
||||
let mut to = String::new();
|
||||
|
||||
for line in input.lines() {
|
||||
let mut parts = line.split_whitespace();
|
||||
if let Some(field) = parts.next() {
|
||||
if let Some(value) = parts.next() {
|
||||
match field {
|
||||
"AUTH" => auth = Some(value.to_string()),
|
||||
"BODY" => body = value.to_string(),
|
||||
"FROM" => from = Some(value.to_string()),
|
||||
"TO" => to = value.to_string(),
|
||||
_ => {}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
let message_outer = MessageOuter {
|
||||
auth,
|
||||
message: Message { body, from },
|
||||
to,
|
||||
};
|
||||
|
||||
message_outer
|
||||
}
|
||||
|
||||
fn read_from(mut stream: TcpStream) -> MessageOuter {
|
||||
let mut buf = Vec::new();
|
||||
let mut message_outer = MessageOuter {
|
||||
auth: None,
|
||||
message: Message {
|
||||
body: "".to_string(),
|
||||
from: None,
|
||||
},
|
||||
to: "".to_string(),
|
||||
};
|
||||
|
||||
while let Ok(bytes_read) = stream.read_to_end(&mut buf) {
|
||||
if bytes_read == 0 {
|
||||
break;
|
||||
}
|
||||
|
||||
message_outer = parse_message(
|
||||
String::from_utf8(buf.clone()).as_ref().unwrap()
|
||||
);
|
||||
}
|
||||
|
||||
message_outer.message.from = Some(
|
||||
message_outer.message.from.unwrap_or_else(|| "anon".to_string())
|
||||
);
|
||||
|
||||
message_outer
|
||||
}
|
||||
|
||||
fn main() {
|
||||
let listener = TcpListener::bind("127.0.0.1:8080")
|
||||
.expect("Failed to bind address");
|
||||
|
||||
println!("Server listening on 127.0.0.1:8080");
|
||||
|
||||
let client_list: Arc<Mutex<Vec<TcpStream>>> = Arc::new(
|
||||
Mutex::new(vec![])
|
||||
);
|
||||
|
||||
for stream in listener.incoming() {
|
||||
match stream {
|
||||
Ok(stream) => {
|
||||
let client_list = Arc::clone(&client_list);
|
||||
thread::spawn(move || {
|
||||
// Add the client's stream to the client list
|
||||
client_list.lock().unwrap().push(stream.try_clone().unwrap());
|
||||
|
||||
let message = read_from(stream);
|
||||
|
||||
// Send the received message to all connected clients
|
||||
let serialized_message = serde_json::to_string(&message).unwrap();
|
||||
let client_list = client_list.lock().unwrap();
|
||||
for client in &*client_list {
|
||||
if let Err(e) = client.write_all(serialized_message.as_bytes()) {
|
||||
eprintln!("Failed to write to client: {}", e);
|
||||
}
|
||||
if let Err(e) = client.flush() {
|
||||
eprintln!("Failed to flush stream: {}", e);
|
||||
}
|
||||
}
|
||||
|
||||
// Remove the client's stream from the client list
|
||||
client_list
|
||||
.lock()
|
||||
.unwrap()
|
||||
.retain(|client| client
|
||||
.peer_addr()
|
||||
.unwrap() != stream.peer_addr().unwrap());
|
||||
});
|
||||
}
|
||||
Err(err) => {
|
||||
eprintln!("Error accepting client connection: {}");
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user