diff options
| author | mat <27899617+mat-1@users.noreply.github.com> | 2024-11-27 19:31:40 -0600 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2024-11-27 19:31:40 -0600 |
| commit | 08958c2278b15ebeac8a964f392ebb792e479b61 (patch) | |
| tree | 4ae3664cea38d7fd1a8f1e95ed06fac04ffe519e /azalea-protocol/src/packets/status/c_status_response.rs | |
| parent | 139d77d3c2b0922fba5e9d4fa2bd9819d78bd773 (diff) | |
| download | azalea-drasl-08958c2278b15ebeac8a964f392ebb792e479b61.tar.xz | |
Refactor azalea-protocol (#190)
* start updating to 1.21.4
* fix block codegen and stop using block data from burger
* rename packet related modules and structs to be simpler
* ItemSlot -> ItemStack for more consistency with mojmap
* .get() -> .into_packet()
* simplify declare_state_packets by removing packet ids
* rename read_from and write_into to azalea_read and azalea_write
* rename McBufReadable and McBufWritable to AzaleaRead and AzaleaWrite
* McBuf -> AzBuf
* remove most uses of into_variant
* update codegen and use resourcelocation names for packets
* implement #[limit(i)] attribute for AzBuf derive macro
* fixes for 1.21.4
* fix examples
* update some physics code and fix ChatType
* remove unused imports in codegen
* re-add some things to migrate.py and update +mc version numbers automatically
* downgrade to 1.21.3 lol
Diffstat (limited to 'azalea-protocol/src/packets/status/c_status_response.rs')
| -rwxr-xr-x | azalea-protocol/src/packets/status/c_status_response.rs | 61 |
1 files changed, 61 insertions, 0 deletions
diff --git a/azalea-protocol/src/packets/status/c_status_response.rs b/azalea-protocol/src/packets/status/c_status_response.rs new file mode 100755 index 00000000..b30c75be --- /dev/null +++ b/azalea-protocol/src/packets/status/c_status_response.rs @@ -0,0 +1,61 @@ +use std::io::{Cursor, Write}; + +use azalea_buf::{AzaleaRead, AzaleaWrite, BufReadError}; +use azalea_chat::FormattedText; +use azalea_protocol_macros::ClientboundStatusPacket; +use serde::{Deserialize, Serialize}; +use serde_json::value::Serializer; + +#[derive(Clone, Debug, Serialize, Deserialize)] +pub struct Version { + pub name: String, + pub protocol: i32, +} + +#[derive(Clone, Debug, Serialize, Deserialize)] +pub struct SamplePlayer { + pub id: String, + pub name: String, +} + +#[derive(Clone, Debug, Serialize, Deserialize)] +pub struct Players { + pub max: i32, + pub online: i32, + #[serde(default)] + pub sample: Vec<SamplePlayer>, +} + +// the entire packet is just json, which is why it has deserialize +#[derive(Clone, Debug, Serialize, Deserialize, ClientboundStatusPacket)] +pub struct ClientboundStatusResponse { + pub description: FormattedText, + #[serde(default)] + #[serde(skip_serializing_if = "Option::is_none")] + pub favicon: Option<String>, + pub players: Players, + pub version: Version, + #[serde(default)] + #[serde(skip_serializing_if = "Option::is_none")] + #[serde(rename = "enforcesSecureChat")] + pub enforces_secure_chat: Option<bool>, +} + +impl AzaleaRead for ClientboundStatusResponse { + fn azalea_read(buf: &mut Cursor<&[u8]>) -> Result<ClientboundStatusResponse, BufReadError> { + let status_string = String::azalea_read(buf)?; + let status_json: serde_json::Value = serde_json::from_str(status_string.as_str())?; + + Ok(ClientboundStatusResponse::deserialize(status_json)?) + } +} + +impl AzaleaWrite for ClientboundStatusResponse { + fn azalea_write(&self, buf: &mut impl Write) -> Result<(), std::io::Error> { + let status_string = ClientboundStatusResponse::serialize(self, Serializer) + .unwrap() + .to_string(); + status_string.azalea_write(buf)?; + Ok(()) + } +} |
