add server menu, work on nick reg

This commit is contained in:
David Westgate 2023-11-25 12:45:57 -08:00
parent 52b6422e1a
commit 7e4a6578dc
3 changed files with 48 additions and 19 deletions

View File

@ -1,5 +1,6 @@
use prompted::input;
use std::io::{self, Read, Write};
use rust_irc::codes::client::*;
use std::io::{ Read, Write};
use std::net::TcpStream;
use std::thread;
@ -23,21 +24,29 @@ fn read_messages(mut stream: TcpStream) {
fn process_message(message: &[u8]) {
if let Ok(text) = String::from_utf8(message.to_vec()) {
println!("{}", text);
println!("from serv: {}", text);
}
}
pub fn start() {
println!("Starting the IRC client");
// let nick: String = input!("Enter your nickname: ");
let nick: String = "testy".to_string();
let nick: String = input!("Enter your nickname: ");
// let host: String = input!("Enter the server host: ");
let host: &str = "localhost";
if let Ok(mut stream) = TcpStream::connect(host.to_owned() + ":6667") {
println!("Connected to {}", host);
let stream_clone: TcpStream = stream.try_clone().expect("Faile to clone stream");
//try to register the nickname
let mut buf: Vec<u8> = vec![0; nick.capacity()];
buf[0] = REGISTER_NICK;
for i in 1..nick.len()+1 {
buf[i] = *nick.as_bytes().get(i - 1).unwrap();
}
stream.write(&buf);
//another stream for reading messages
let stream_clone: TcpStream = stream.try_clone().expect("Failed to clone stream");
thread::spawn(move || {
read_messages(stream_clone);
});

View File

@ -1,10 +1,12 @@
pub mod codes {
pub const END: u8 = 0x00;
pub mod client {
pub const JOIN_ROOM: u8 = 0x01;
pub const JOIN_SERVER: u8 = 0x02;
pub const LEAVE_ROOM: u8 = 0x03;
pub const LIST_ROOMS: u8 = 0x04;
pub const SEND_MESSAGE: u8 = 0x05;
pub const REGISTER_NICK: u8 = 0x06;
}
pub const KEEP_ALIVE: u8 = 0x0C;
pub const RESPONSE: u8 = 0x0D;

View File

@ -1,3 +1,4 @@
use std::sync::{Arc, Mutex};
use std::{
collections::{HashMap, HashSet},
io::{Read, Write},
@ -5,6 +6,7 @@ use std::{
thread,
};
use prompted::input;
use rust_irc::codes;
const SERVER_ADDRESS: &str = "0.0.0.0:6667";
@ -50,30 +52,46 @@ impl Server {
stream.write_all(&[codes::RESPONSE_OK]);
// handle user commands
loop {
let mut cmd_buf = [0; 2];
println!("yo, {:?}", self.users);
// todo!();
break;
}
}
}
pub fn start() {
let listener: TcpListener = TcpListener::bind(SERVER_ADDRESS).expect("Failed to bind to port");
let server: Server = Server::new();
let server = Server::new();
let server_mutx = Arc::new(Mutex::new(server));
let io_thread = Arc::clone(&server_mutx);
println!("Server listening on {}", SERVER_ADDRESS);
thread::spawn(move || loop {
println!("0: Quit Server");
println!("1: list connected users");
println!("2: list rooms");
let inp: String = input!(":");
let local_server = io_thread.lock().unwrap();
match inp.parse::<u8>() {
Ok(num) => match num {
0 => break,
1 => println!("Users: {:?}", local_server.users),
2 => println!("Rooms: {:?}", local_server.rooms),
_ => println!("Invalid Input"),
},
Err(_) => {
println!("Invalid input");
}
}
});
for stream in listener.incoming() {
match stream {
Ok(stream) => {
if server.users.len() < MAX_USERS {
let mut server_clone = server.clone();
thread::spawn(move || {
server_clone.handle_client(stream);
});
Ok(mut stream) => {
let mut cmd_buf: [i32; 2] = [0; 2];
let mut local_server = server_mutx.lock().unwrap();
if local_server.users.len() < MAX_USERS {
local_server.handle_client(stream);
} else {
// stream.write_all(&[codes::ERROR, codes::error::SERVER_FULL]);
let _ = stream.write_all(&[codes::ERROR, codes::error::SERVER_FULL]);
}
}
Err(e) => {