change to unix sockets
This commit is contained in:
		
							parent
							
								
									dbdfab1fd6
								
							
						
					
					
						commit
						ca43b2d75c
					
				
							
								
								
									
										110
									
								
								Cargo.lock
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										110
									
								
								Cargo.lock
									
									
									
										generated
									
									
									
								
							| @ -2,6 +2,34 @@ | |||||||
| # It is not intended for manual editing. | # It is not intended for manual editing. | ||||||
| version = 3 | version = 3 | ||||||
| 
 | 
 | ||||||
|  | [[package]] | ||||||
|  | name = "autocfg" | ||||||
|  | version = "1.1.0" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | checksum = "d468802bab17cbc0cc575e9b053f41e72aa36bfa6b7f55e3529ffa43161b97fa" | ||||||
|  | 
 | ||||||
|  | [[package]] | ||||||
|  | name = "hashbrown" | ||||||
|  | version = "0.12.3" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | checksum = "8a9ee70c43aaf417c914396645a0fa852624801b24ebb7ae78fe8272889ac888" | ||||||
|  | 
 | ||||||
|  | [[package]] | ||||||
|  | name = "indexmap" | ||||||
|  | version = "1.9.1" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | checksum = "10a35a97730320ffe8e2d410b5d3b69279b98d2c14bdb8b70ea89ecf7888d41e" | ||||||
|  | dependencies = [ | ||||||
|  |  "autocfg", | ||||||
|  |  "hashbrown", | ||||||
|  | ] | ||||||
|  | 
 | ||||||
|  | [[package]] | ||||||
|  | name = "itoa" | ||||||
|  | version = "1.0.4" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | checksum = "4217ad341ebadf8d8e724e264f13e593e0648f5b3e94b3896a5df283be015ecc" | ||||||
|  | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "linked-hash-map" | name = "linked-hash-map" | ||||||
| version = "0.5.6" | version = "0.5.6" | ||||||
| @ -12,9 +40,91 @@ checksum = "0717cef1bc8b636c6e1c1bbdefc09e6322da8a9321966e8928ef80d20f7f770f" | |||||||
| name = "minecraft_proxy" | name = "minecraft_proxy" | ||||||
| version = "0.1.0" | version = "0.1.0" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  |  "serde", | ||||||
|  |  "serde_yaml", | ||||||
|  "yaml-rust", |  "yaml-rust", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
|  | [[package]] | ||||||
|  | name = "proc-macro2" | ||||||
|  | version = "1.0.47" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | checksum = "5ea3d908b0e36316caf9e9e2c4625cdde190a7e6f440d794667ed17a1855e725" | ||||||
|  | dependencies = [ | ||||||
|  |  "unicode-ident", | ||||||
|  | ] | ||||||
|  | 
 | ||||||
|  | [[package]] | ||||||
|  | name = "quote" | ||||||
|  | version = "1.0.21" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | checksum = "bbe448f377a7d6961e30f5955f9b8d106c3f5e449d493ee1b125c1d43c2b5179" | ||||||
|  | dependencies = [ | ||||||
|  |  "proc-macro2", | ||||||
|  | ] | ||||||
|  | 
 | ||||||
|  | [[package]] | ||||||
|  | name = "ryu" | ||||||
|  | version = "1.0.11" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | checksum = "4501abdff3ae82a1c1b477a17252eb69cee9e66eb915c1abaa4f44d873df9f09" | ||||||
|  | 
 | ||||||
|  | [[package]] | ||||||
|  | name = "serde" | ||||||
|  | version = "1.0.147" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | checksum = "d193d69bae983fc11a79df82342761dfbf28a99fc8d203dca4c3c1b590948965" | ||||||
|  | dependencies = [ | ||||||
|  |  "serde_derive", | ||||||
|  | ] | ||||||
|  | 
 | ||||||
|  | [[package]] | ||||||
|  | name = "serde_derive" | ||||||
|  | version = "1.0.147" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | checksum = "4f1d362ca8fc9c3e3a7484440752472d68a6caa98f1ab81d99b5dfe517cec852" | ||||||
|  | dependencies = [ | ||||||
|  |  "proc-macro2", | ||||||
|  |  "quote", | ||||||
|  |  "syn", | ||||||
|  | ] | ||||||
|  | 
 | ||||||
|  | [[package]] | ||||||
|  | name = "serde_yaml" | ||||||
|  | version = "0.9.14" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | checksum = "6d232d893b10de3eb7258ff01974d6ee20663d8e833263c99409d4b13a0209da" | ||||||
|  | dependencies = [ | ||||||
|  |  "indexmap", | ||||||
|  |  "itoa", | ||||||
|  |  "ryu", | ||||||
|  |  "serde", | ||||||
|  |  "unsafe-libyaml", | ||||||
|  | ] | ||||||
|  | 
 | ||||||
|  | [[package]] | ||||||
|  | name = "syn" | ||||||
|  | version = "1.0.103" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | checksum = "a864042229133ada95abf3b54fdc62ef5ccabe9515b64717bcb9a1919e59445d" | ||||||
|  | dependencies = [ | ||||||
|  |  "proc-macro2", | ||||||
|  |  "quote", | ||||||
|  |  "unicode-ident", | ||||||
|  | ] | ||||||
|  | 
 | ||||||
|  | [[package]] | ||||||
|  | name = "unicode-ident" | ||||||
|  | version = "1.0.5" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | checksum = "6ceab39d59e4c9499d4e5a8ee0e2735b891bb7308ac83dfb4e80cad195c9f6f3" | ||||||
|  | 
 | ||||||
|  | [[package]] | ||||||
|  | name = "unsafe-libyaml" | ||||||
|  | version = "0.2.4" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | checksum = "c1e5fa573d8ac5f1a856f8d7be41d390ee973daf97c806b2c1a465e4e1406e68" | ||||||
|  | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "yaml-rust" | name = "yaml-rust" | ||||||
| version = "0.4.5" | version = "0.4.5" | ||||||
|  | |||||||
| @ -4,4 +4,6 @@ version = "0.1.0" | |||||||
| edition = "2021" | edition = "2021" | ||||||
| 
 | 
 | ||||||
| [dependencies] | [dependencies] | ||||||
| yaml-rust = "*" | yaml-rust = "*" | ||||||
|  | serde = { version = "*", features = ["derive"] } | ||||||
|  | serde_yaml = "*" | ||||||
| @ -1,4 +1,5 @@ | |||||||
| use yaml_rust::yaml; | use yaml_rust::yaml; | ||||||
|  | use serde::{Serialize, Deserialize}; | ||||||
| use std::fs::File; | use std::fs::File; | ||||||
| use std::str::FromStr; | use std::str::FromStr; | ||||||
| use std::io::prelude::*; | use std::io::prelude::*; | ||||||
|  | |||||||
| @ -1,34 +1,36 @@ | |||||||
| use std::net::{TcpListener, TcpStream}; | use std::net::{TcpListener, TcpStream}; | ||||||
|  | use std::os::unix::net::{UnixListener, UnixStream}; | ||||||
| use std::io::prelude::*; | use std::io::prelude::*; | ||||||
| use crate::conf; | use crate::conf; | ||||||
| use std::sync::{Arc, RwLock}; | use std::sync::{Arc, RwLock}; | ||||||
| 
 | 
 | ||||||
| pub fn server_conf(conf: Arc<RwLock<conf::Config>>){ | pub fn server_conf(conf: Arc<RwLock<conf::Config>>){ | ||||||
|     let listener = TcpListener::bind(String::from("0.0.0.0:") + |     let listener = UnixListener::bind("mineproxy").unwrap(); | ||||||
|                     conf.read().unwrap().get_port_conf()).unwrap(); |  | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|     for stream in listener.incoming() { |     for stream in listener.incoming() { | ||||||
|         match stream{ |         match stream{ | ||||||
|         Ok(s) => process_reques(s), |         Ok(s) => process_reques(s, conf.clone()), | ||||||
|         Err(_e) => println!("{}",_e), |         Err(_e) => println!("{}",_e), | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| fn process_reques(mut stream: TcpStream) { | fn process_reques(mut stream: UnixStream, conf: Arc<RwLock<conf::Config>>) { | ||||||
|     let mut buf: [u8; 256] = [1; 256]; |     let mut buf: [u8; 256] = [1; 256]; | ||||||
|     match stream.read(&mut buf){ |     match stream.read(&mut buf){ | ||||||
|         Ok(len) => check_state(&mut buf, len), |         Ok(len) => check_state(&mut buf, len, conf), | ||||||
|         Err(e) => println!("pos no {}", e), |         Err(e) => println!("Fatal: {}", e), | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| fn check_state(buf: &mut [u8; 256], len: usize) { | fn check_state(buf: &mut [u8; 256], len: usize, conf: Arc<RwLock<conf::Config>>) { | ||||||
|     let var = String::from_utf8(buf[0 .. len-2].to_vec()).unwrap(); |     let var = String::from_utf8(buf[0 .. len].to_vec()).unwrap(); | ||||||
|     match var.as_str(){ |     match var.as_str(){ | ||||||
|         "some" => println!("entra"), |         "add" => println!("entra"), | ||||||
|         _=> println!("pos no {}", var), |         "dell" => println!("del"), | ||||||
|  |         "mod" => println!("mod"), | ||||||
|  |         _=> println!("no recognice option: {}", var), | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user