more fiery commit
This commit is contained in:
parent
95a7bb21e0
commit
e2cc99dfb7
@ -11,86 +11,86 @@ use rust_mc_proto::{DataBufferReader, DataBufferWriter, MCConnTcp, MinecraftConn
|
|||||||
struct MinecraftServer {
|
struct MinecraftServer {
|
||||||
server_ip: String,
|
server_ip: String,
|
||||||
server_port: u16,
|
server_port: u16,
|
||||||
protocol_version: u16,
|
|
||||||
motd: String
|
motd: String
|
||||||
}
|
}
|
||||||
|
|
||||||
impl MinecraftServer {
|
impl MinecraftServer {
|
||||||
fn new(server_ip: &str,
|
fn new(server_ip: &str,
|
||||||
server_port: u16,
|
server_port: u16,
|
||||||
protocol_version: u16,
|
|
||||||
motd: &str) -> Self {
|
motd: &str) -> Self {
|
||||||
MinecraftServer {
|
MinecraftServer {
|
||||||
server_ip: server_ip.to_string(),
|
server_ip: server_ip.to_string(),
|
||||||
server_port,
|
server_port,
|
||||||
protocol_version,
|
|
||||||
motd: motd.to_string()
|
motd: motd.to_string()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
fn accept_client(mut conn: MCConnTcp, server: Arc<Mutex<MinecraftServer>>) -> Result<(), ProtocolError> {
|
fn start(self) {
|
||||||
let mut handshake = false;
|
let addr = self.server_ip.clone() + ":" + &self.server_port.to_string();
|
||||||
|
let listener = TcpListener::bind(addr).unwrap();
|
||||||
|
let server = Arc::new(Mutex::new(self));
|
||||||
|
|
||||||
loop {
|
for stream in listener.incoming() {
|
||||||
let mut packet = match conn.read_packet() {
|
let stream = stream.unwrap();
|
||||||
Ok(i) => i,
|
let local_server = server.clone();
|
||||||
Err(_) => {
|
|
||||||
break;
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
if handshake {
|
thread::spawn(move || {
|
||||||
if packet.id() == 0x00 {
|
Self::accept_client(MinecraftConnection::new(stream), local_server).unwrap();
|
||||||
let mut status = Packet::empty(0x00);
|
});
|
||||||
|
|
||||||
let serv = server.lock().unwrap();
|
|
||||||
|
|
||||||
let motd = serv.motd.clone();
|
|
||||||
let motd = motd.replace(
|
|
||||||
"PROTOCOL_VERSION",
|
|
||||||
&serv.protocol_version.to_string());
|
|
||||||
|
|
||||||
status.write_string(&motd)?;
|
|
||||||
conn.write_packet(&status)?;
|
|
||||||
} else if packet.id() == 0x01 {
|
|
||||||
let mut status = Packet::empty(0x01);
|
|
||||||
status.write_long(packet.read_long()?)?;
|
|
||||||
conn.write_packet(&status)?;
|
|
||||||
}
|
|
||||||
} else if packet.id() == 0x00 {
|
|
||||||
let protocol_version = packet.read_i32_varint()?;
|
|
||||||
let server_address = packet.read_string()?;
|
|
||||||
let server_port = packet.read_unsigned_short()?;
|
|
||||||
let next_state = packet.read_u8_varint()?;
|
|
||||||
|
|
||||||
if next_state != 1 { break; }
|
|
||||||
|
|
||||||
println!("Client handshake info:");
|
|
||||||
println!(" IP: {}", conn.get_ref().peer_addr().unwrap());
|
|
||||||
println!(" Protocol version: {}", protocol_version);
|
|
||||||
println!(" Server address: {}", server_address);
|
|
||||||
println!(" Server port: {}", server_port);
|
|
||||||
|
|
||||||
handshake = true;
|
|
||||||
} else {
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
conn.close();
|
fn accept_client(mut conn: MCConnTcp, server: Arc<Mutex<MinecraftServer>>) -> Result<(), ProtocolError> {
|
||||||
|
let mut handshake = false;
|
||||||
|
|
||||||
Ok(())
|
loop {
|
||||||
|
let Ok(mut packet) = conn.read_packet() else { break; };
|
||||||
|
|
||||||
|
if handshake {
|
||||||
|
if packet.id() == 0x00 {
|
||||||
|
let motd = server.lock().unwrap().motd.clone();
|
||||||
|
|
||||||
|
conn.write_packet(&Packet::build(0x00, |status|
|
||||||
|
status.write_string(&motd)
|
||||||
|
)?)?;
|
||||||
|
} else if packet.id() == 0x01 {
|
||||||
|
conn.write_packet(&Packet::build(0x01, |status|
|
||||||
|
status.write_long(packet.read_long()?)
|
||||||
|
)?)?;
|
||||||
|
}
|
||||||
|
} else if packet.id() == 0x00 {
|
||||||
|
let protocol_version = packet.read_i32_varint()?;
|
||||||
|
let server_address = packet.read_string()?;
|
||||||
|
let server_port = packet.read_unsigned_short()?;
|
||||||
|
let next_state = packet.read_u8_varint()?;
|
||||||
|
|
||||||
|
if next_state != 1 { break; }
|
||||||
|
|
||||||
|
println!("Client handshake info:");
|
||||||
|
println!(" IP: {}", conn.get_ref().peer_addr().unwrap());
|
||||||
|
println!(" Protocol version: {}", protocol_version);
|
||||||
|
println!(" Server address: {}", server_address);
|
||||||
|
println!(" Server port: {}", server_port);
|
||||||
|
|
||||||
|
handshake = true;
|
||||||
|
} else {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
conn.close();
|
||||||
|
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn main() {
|
fn main() {
|
||||||
let server = MinecraftServer::new(
|
let server = MinecraftServer::new(
|
||||||
"127.0.0.1",
|
"127.0.0.1",
|
||||||
25565,
|
25565,
|
||||||
765,
|
|
||||||
"{
|
"{
|
||||||
\"version\":{
|
\"version\":{
|
||||||
\"protocol\":PROTOCOL_VERSION,
|
\"protocol\":765,
|
||||||
\"name\":\"Version name\"
|
\"name\":\"Version name\"
|
||||||
},
|
},
|
||||||
\"players\":{
|
\"players\":{
|
||||||
@ -111,17 +111,5 @@ fn main() {
|
|||||||
\"favicon\": \"\"
|
\"favicon\": \"\"
|
||||||
}"
|
}"
|
||||||
);
|
);
|
||||||
|
server.start();
|
||||||
let addr = server.server_ip.clone() + ":" + &server.server_port.to_string();
|
|
||||||
let listener = TcpListener::bind(addr).unwrap();
|
|
||||||
let server = Arc::new(Mutex::new(server));
|
|
||||||
|
|
||||||
for stream in listener.incoming() {
|
|
||||||
let stream = stream.unwrap();
|
|
||||||
let local_server = server.clone();
|
|
||||||
|
|
||||||
thread::spawn(move || {
|
|
||||||
accept_client(MinecraftConnection::new(stream), local_server).unwrap();
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user