improve scalability and security
This commit is contained in:
parent
f754030997
commit
a698bbb14f
49
src/main.rs
49
src/main.rs
@ -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())
|
||||||
}
|
}
|
||||||
|
@ -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)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user