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),
|
||||
EncryptionRequest(EncryptionRequest),
|
||||
LoginSuccess(LoginSuccess),
|
||||
SetCompression(SetCompression),
|
||||
PluginRequest(PluginRequest),
|
||||
}
|
||||
|
||||
impl Login {
|
||||
|
@ -23,6 +25,12 @@ pub mod clientbound {
|
|||
EncryptionRequest::get(&mut data)?))
|
||||
} else if packet_id == LoginSuccess::packet_id() {
|
||||
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 {
|
||||
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