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
	
	 Kyler
						Kyler