diff --git a/Cargo.toml b/Cargo.toml index bd9611d..f09be0b 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -7,9 +7,10 @@ license-file = "LICENSE" readme = "README.md" keywords = ["minecraft", "protocol", "packets", "lightweight"] -version = "0.1.5" +version = "0.1.6" edition = "2021" [dependencies] flate2 = "1.0.30" -bytebuffer = "2.2.0" \ No newline at end of file +bytebuffer = "2.2.0" +uuid = "1.8.0" \ No newline at end of file diff --git a/examples/recv_motd.rs b/examples/recv_motd.rs index 379a33b..5f6d485 100644 --- a/examples/recv_motd.rs +++ b/examples/recv_motd.rs @@ -38,12 +38,12 @@ fn read_status_response(conn: &mut MCConnTcp) -> Result { } fn main() { - let mut conn = MCConnTcp::connect("localhost:25565").unwrap(); + let mut conn = MCConnTcp::connect("sloganmc.ru:25565").unwrap(); - send_handshake(&mut conn, 765, "localhost", 25565, 1).unwrap(); + send_handshake(&mut conn, 765, "sloganmc.ru", 25565, 1).unwrap(); send_status_request(&mut conn).unwrap(); let motd = read_status_response(&mut conn).unwrap(); - println!("Motd: {}", motd); + dbg!(motd); } diff --git a/examples/status_server.rs b/examples/status_server.rs index aab7050..52ec436 100644 --- a/examples/status_server.rs +++ b/examples/status_server.rs @@ -50,7 +50,7 @@ fn accept_client(mut conn: MCConnTcp, server: Arc>) -> Re conn.write_packet(&status)?; } } else if packet.id == 0x00 { - let protocol_version = packet.read_u16_varint()?; + 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()?; @@ -79,7 +79,7 @@ fn main() { "localhost", 25565, 765, - "{}" + "{\"version\":{\"protocol\":765,\"name\":\"Куриный ништяк\"},\"players\":{\"online\":0,\"max\":1},\"description\":{\"extra\":[{\"extra\":[{\"color\":\"aqua\",\"text\":\"☄\"},\" \",{\"bold\":true,\"extra\":[{\"color\":\"#00D982\",\"text\":\"S\"},{\"color\":\"#0DCB8B\",\"text\":\"l\"},{\"color\":\"#1BBC93\",\"text\":\"o\"},{\"color\":\"#28AE9C\",\"text\":\"g\"},{\"color\":\"#35A0A5\",\"text\":\"a\"},{\"color\":\"#4392AE\",\"text\":\"n\"},{\"color\":\"#5083B6\",\"text\":\"M\"},{\"color\":\"#5D75BF\",\"text\":\"C\"},{\"color\":\"#6A67C8\",\"text\":\".\"},{\"color\":\"#7858D0\",\"text\":\"r\"},{\"color\":\"#854AD9\",\"text\":\"u\"}],\"text\":\"\"},\" \",{\"color\":\"aqua\",\"text\":\"☄\"},\" \"],\"text\":\"\"},\"\\n\",{\"extra\":[{\"extra\":[{\"bold\":true,\"color\":\"#A1999E\",\"text\":\"░\"},\" \",{\"color\":\"#D1C7CD\",\"text\":\"прикол\"},\" \",{\"bold\":true,\"color\":\"#A1999E\",\"text\":\"░\"}],\"text\":\"\"}],\"text\":\" \"}],\"text\":\" \"},\"favicon\":\"\\u003d\"}" ); let addr = server.server_ip.clone() + ":" + &server.server_port.to_string(); diff --git a/src/lib.rs b/src/lib.rs index f0d7dcf..ad7e3ee 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -3,6 +3,7 @@ use std::net::{TcpStream, ToSocketAddrs}; use flate2::{Compress, Compression, Decompress, FlushCompress, Status, FlushDecompress}; use bytebuffer::ByteBuffer; +use uuid::Uuid; pub trait Zigzag { fn zigzag(&self) -> T; } impl Zigzag for i8 { fn zigzag(&self) -> u8 { ((self << 1) ^ (self >> 7)) as u8 } } @@ -139,6 +140,12 @@ pub trait DataBufferReader { Err(_) => Err(ProtocolError::ReadError), } } + fn read_uuid(&mut self) -> Result { + match self.read_bytes(16)?.try_into() { + Ok(i) => Ok(Uuid::from_u128(u128::from_be_bytes(i))), + Err(_) => Err(ProtocolError::ReadError), + } + } fn read_usize_varint(&mut self) -> Result { read_varint!(usize, self) } fn read_u8_varint(&mut self) -> Result { read_varint!(u8, self) } @@ -166,6 +173,9 @@ pub trait DataBufferWriter { self.write_usize_varint(bytes.len())?; self.write_bytes(bytes) } + fn write_uuid(&mut self, val: &Uuid) -> Result<(), ProtocolError> { + self.write_bytes(&val.as_u128().to_be_bytes()) + } fn write_unsigned_short(&mut self, val: u16) -> Result<(), ProtocolError> { match self.write_bytes(&val.to_be_bytes()) { Ok(_) => Ok(()), diff --git a/src/main.rs b/src/main.rs deleted file mode 100644 index 48b7699..0000000 --- a/src/main.rs +++ /dev/null @@ -1,34 +0,0 @@ -use std::{net::TcpListener, sync::Arc, thread}; - -use rust_mc_proto::{DataBufferReader, DataBufferWriter, MCConn, MCConnTcp, MinecraftConnection, Packet, ProtocolError}; - -/* - - Example of simple server that sends motd - to client like an vanilla minecraft server - -*/ - -fn accept_client(mut conn: MCConnTcp) { - loop { - let packet = match conn.read_packet() { - Ok(p) => p, - Err(_) => { break }, - }; - - dbg!(packet); - } -} - -fn main() { - let listener = TcpListener::bind("localhost:25565").unwrap(); - - for stream in listener.incoming() { - let stream = stream.unwrap(); - - - thread::spawn(move || { - accept_client(MinecraftConnection::new(stream)); - }); - } -}