improve scalability and security

This commit is contained in:
Guillermo Roche 2022-09-26 23:03:16 +02:00
parent f754030997
commit a698bbb14f
2 changed files with 34 additions and 20 deletions

View File

@ -1,4 +1,5 @@
use std::net::{TcpListener, TcpStream}; use std::net::{TcpListener, TcpStream};
use std::sync::{Arc, RwLock};
use std::io::prelude::*; use std::io::prelude::*;
use crate::client::guard; use crate::client::guard;
use std::thread; use std::thread;
@ -10,24 +11,16 @@ mod conf;
mod protocol; mod protocol;
fn main() { fn main() {
let listener = TcpListener::bind("127.0.0.1:25567").unwrap(); let listener = TcpListener::bind("0.0.0.0:25565").unwrap();
let mut buf: [u8; 256] = [1; 256]; let servers = Arc::new(RwLock::new(conf::Servers::new()));
let servers = conf::Servers::new(); let guard = Arc::new(RwLock::new(guard::Guard::new()));
let mut guard = guard::Guard::new();
for stream in listener.incoming() { for stream in listener.incoming() {
if guard.can_add(){ if guard.read().unwrap().can_add(){
match stream { match stream {
Ok(mut stream) => { Ok(stream) => {
stream.set_read_timeout(Some(Duration::from_millis(5000))); let g = guard.clone();
//stream.set_write_timeout(Some(Duration::from_millis(5000))); let s = servers.clone();
let leng = match stream.read(&mut buf) { thread::spawn(|| read_connection(stream, s , g));
Ok(l) => l,
Err(_e) => break,
};
let mut hs = protocol::HandShake::new(&mut buf[.. leng]);
if hs.get_raw()[0] < 200 { //Filtra los ping, solo controlamos los handshakes
conect_server(&servers, hs, stream, &mut guard);
}
}, },
Err(_e) => println!("{}",_e), Err(_e) => println!("{}",_e),
@ -36,18 +29,34 @@ fn main() {
} }
} }
fn conect_server(servers: &conf::Servers, fn read_connection(mut stream: TcpStream,
servers: Arc<RwLock<conf::Servers>>,
guard: Arc<RwLock<guard::Guard>> ) {
let mut buf: [u8; 256] = [1; 256];
stream.set_read_timeout(Some(Duration::from_millis(5000)));
let leng = match stream.read(&mut buf) {
Ok(l) => l,
Err(_e) => return,
};
let hs = protocol::HandShake::new(&mut buf[.. leng]);
if hs.is_handshake() { //Filtra los ping, solo controlamos los handshakes
conect_server(servers, hs, stream, guard);
}
}
fn conect_server(servers: Arc<RwLock<conf::Servers>>,
mut hs: protocol::HandShake, mut hs: protocol::HandShake,
stream: TcpStream, stream: TcpStream,
guard: &mut guard::Guard){ guard: Arc<RwLock<guard::Guard>>){
match servers.get_server(&hs.get_host_name()) { match servers.read().unwrap().get_server(&hs.get_host_name()) {
Some(s) => { Some(s) => {
hs.replace_port(s.1); hs.replace_port(s.1);
let mut sstream = TcpStream::connect(s.0 + ":" + &s.1.to_string()).unwrap(); let mut sstream = TcpStream::connect(s.0 + ":" + &s.1.to_string()).unwrap();
sstream.write(hs.get_raw()); sstream.write(hs.get_raw());
let c1 = client::Client::new(stream,sstream, hs); let c1 = client::Client::new(stream,sstream, hs);
guard.add_thread(c1.start_proxy()); guard.write().unwrap().add_thread(c1.start_proxy());
}, },
None => println!("No server found for {}", hs.get_host_name()) None => println!("No server found for {}", hs.get_host_name())
} }

View File

@ -36,5 +36,10 @@ impl<'a> HandShake<'a>{
pub fn get_raw(&self) -> &[u8]{ pub fn get_raw(&self) -> &[u8]{
self.datagram self.datagram
} }
pub fn is_handshake(&self) -> bool {
(self.datagram[0] == self.len_pack) &&
(self.len_dom + 7 == self.len_pack)
}
} }