Finished Login Packets
This commit is contained in:
parent
9f987c0d0a
commit
8a2a144258
188
src/login.rs
188
src/login.rs
|
@ -10,6 +10,8 @@ pub mod clientbound {
|
||||||
Disconnect(Disconnect),
|
Disconnect(Disconnect),
|
||||||
EncryptionRequest(EncryptionRequest),
|
EncryptionRequest(EncryptionRequest),
|
||||||
LoginSuccess(LoginSuccess),
|
LoginSuccess(LoginSuccess),
|
||||||
|
SetCompression(SetCompression),
|
||||||
|
PluginRequest(PluginRequest),
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Login {
|
impl Login {
|
||||||
|
@ -23,6 +25,12 @@ pub mod clientbound {
|
||||||
EncryptionRequest::get(&mut data)?))
|
EncryptionRequest::get(&mut data)?))
|
||||||
} else if packet_id == LoginSuccess::packet_id() {
|
} else if packet_id == LoginSuccess::packet_id() {
|
||||||
return Ok(Self::LoginSuccess(LoginSuccess::get(&mut data)?))
|
return Ok(Self::LoginSuccess(LoginSuccess::get(&mut data)?))
|
||||||
|
} else if packet_id == SetCompression::packet_id() {
|
||||||
|
return Ok(Self::SetCompression(
|
||||||
|
SetCompression::get(&mut data)?))
|
||||||
|
} else if packet_id == PluginRequest::packet_id() {
|
||||||
|
return Ok(Self::PluginRequest(
|
||||||
|
PluginRequest::get(&mut data)?))
|
||||||
} else {
|
} else {
|
||||||
return Err(Box::new(PacketError::InvalidPacketId))
|
return Err(Box::new(PacketError::InvalidPacketId))
|
||||||
}
|
}
|
||||||
|
@ -166,4 +174,184 @@ pub mod clientbound {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub struct SetCompression {
|
||||||
|
pub threshold: i32,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Packet for SetCompression {
|
||||||
|
|
||||||
|
fn packet_id() -> i32 {3}
|
||||||
|
|
||||||
|
fn get(mut data: &mut Vec<u8>) -> Result<Self> {
|
||||||
|
Ok(Self {
|
||||||
|
threshold: mc_types::get_var_int(&mut data)?,
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
fn convert(&self) -> Vec<u8> {
|
||||||
|
let mut data: Vec<u8> = vec![];
|
||||||
|
data.append(&mut mc_types::convert_var_int(Self::packet_id()));
|
||||||
|
data.append(&mut mc_types::convert_var_int(self.threshold));
|
||||||
|
|
||||||
|
data
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
pub struct PluginRequest {
|
||||||
|
pub message_id: i32,
|
||||||
|
pub channel: String,
|
||||||
|
pub data: Vec<u8>,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Packet for PluginRequest {
|
||||||
|
|
||||||
|
fn packet_id() -> i32 {4}
|
||||||
|
|
||||||
|
fn get(mut data: &mut Vec<u8>) -> Result<Self> {
|
||||||
|
Ok(Self {
|
||||||
|
message_id: mc_types::get_var_int(&mut data)?,
|
||||||
|
channel: mc_types::get_string(&mut data)?,
|
||||||
|
data: data.clone(),
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
fn convert(&self) -> Vec<u8> {
|
||||||
|
let mut data: Vec<u8> = vec![];
|
||||||
|
data.append(&mut mc_types::convert_var_int(Self::packet_id()));
|
||||||
|
data.append(&mut mc_types::convert_var_int(self.message_id));
|
||||||
|
data.append(&mut mc_types::convert_string(&self.channel));
|
||||||
|
data.append(&mut self.data.clone());
|
||||||
|
|
||||||
|
data
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
pub mod serverbound {
|
||||||
|
|
||||||
|
use tokio::net::tcp::OwnedReadHalf;
|
||||||
|
|
||||||
|
use crate::mc_types::{self, Result, Packet, PacketError};
|
||||||
|
|
||||||
|
pub enum Login {
|
||||||
|
LoginStart(LoginStart),
|
||||||
|
EncryptionResponse(EncryptionResponse),
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Login {
|
||||||
|
pub async fn read(stream: &mut OwnedReadHalf) -> Result<Self> {
|
||||||
|
let mut data = mc_types::read_data(stream).await?;
|
||||||
|
let packet_id = mc_types::get_var_int(&mut data)?;
|
||||||
|
if packet_id == LoginStart::packet_id() {
|
||||||
|
return Ok(Self::LoginStart(LoginStart::get(&mut data)?))
|
||||||
|
} else if packet_id == EncryptionResponse::packet_id() {
|
||||||
|
return Ok(Self::EncryptionResponse(
|
||||||
|
EncryptionResponse::get(&mut data)?))
|
||||||
|
} else {
|
||||||
|
return Err(Box::new(PacketError::InvalidPacketId))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub struct LoginStart {
|
||||||
|
pub name: String,
|
||||||
|
pub player_uuid: Option<u128>,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Packet for LoginStart {
|
||||||
|
|
||||||
|
fn packet_id() -> i32 {0}
|
||||||
|
|
||||||
|
fn get(mut data: &mut Vec<u8>) -> Result<Self> {
|
||||||
|
let name = mc_types::get_string(&mut data)?;
|
||||||
|
let has_uuid = mc_types::get_bool(&mut data);
|
||||||
|
let mut player_uuid: Option<u128> = None;
|
||||||
|
if has_uuid {
|
||||||
|
player_uuid = Some(mc_types::get_uuid(&mut data));
|
||||||
|
}
|
||||||
|
Ok(Self {
|
||||||
|
name,
|
||||||
|
player_uuid,
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
fn convert(&self) -> Vec<u8> {
|
||||||
|
let mut data: Vec<u8> = vec![];
|
||||||
|
data.append(&mut mc_types::convert_var_int(Self::packet_id()));
|
||||||
|
data.append(&mut mc_types::convert_string(&self.name));
|
||||||
|
match self.player_uuid {
|
||||||
|
Some(value) => {
|
||||||
|
data.append(&mut mc_types::convert_bool(true));
|
||||||
|
data.append(&mut mc_types::convert_uuid(value));
|
||||||
|
},
|
||||||
|
None => data.append(&mut mc_types::convert_bool(false))
|
||||||
|
}
|
||||||
|
|
||||||
|
data
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
pub struct EncryptionResponse {
|
||||||
|
pub shared_secret: Vec<u8>,
|
||||||
|
pub verify_token: Vec<u8>,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Packet for EncryptionResponse {
|
||||||
|
|
||||||
|
fn packet_id() -> i32 {1}
|
||||||
|
|
||||||
|
fn get(mut data: &mut Vec<u8>) -> Result<Self> {
|
||||||
|
Ok(Self {
|
||||||
|
shared_secret: mc_types::get_byte_array(&mut data)?,
|
||||||
|
verify_token: mc_types::get_byte_array(&mut data)?,
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
fn convert(&self) -> Vec<u8> {
|
||||||
|
let mut data: Vec<u8> = vec![];
|
||||||
|
data.append(&mut mc_types::convert_var_int(Self::packet_id()));
|
||||||
|
data.append(&mut mc_types::convert_byte_array(
|
||||||
|
&mut self.shared_secret.clone()));
|
||||||
|
data.append(&mut mc_types::convert_byte_array(
|
||||||
|
&mut self.verify_token.clone()));
|
||||||
|
|
||||||
|
data
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
pub struct PluginResponse {
|
||||||
|
pub message_id: i32,
|
||||||
|
pub successful: bool,
|
||||||
|
pub data: Vec<u8>,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Packet for PluginResponse {
|
||||||
|
|
||||||
|
fn packet_id() -> i32 {2}
|
||||||
|
|
||||||
|
fn get(mut data: &mut Vec<u8>) -> Result<Self> {
|
||||||
|
Ok(Self {
|
||||||
|
message_id: mc_types::get_var_int(&mut data)?,
|
||||||
|
successful: mc_types::get_bool(&mut data),
|
||||||
|
data: data.clone(),
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
fn convert(&self) -> Vec<u8> {
|
||||||
|
let mut data: Vec<u8> = vec![];
|
||||||
|
data.append(&mut mc_types::convert_var_int(Self::packet_id()));
|
||||||
|
data.append(&mut mc_types::convert_var_int(self.message_id));
|
||||||
|
data.append(&mut mc_types::convert_bool(self.successful));
|
||||||
|
data.append(&mut self.data.clone());
|
||||||
|
|
||||||
|
data
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue