aboutsummaryrefslogtreecommitdiff
path: root/azalea-protocol/src/packets/status/c_status_response.rs
diff options
context:
space:
mode:
authormat <27899617+mat-1@users.noreply.github.com>2024-11-27 19:31:40 -0600
committerGitHub <noreply@github.com>2024-11-27 19:31:40 -0600
commit08958c2278b15ebeac8a964f392ebb792e479b61 (patch)
tree4ae3664cea38d7fd1a8f1e95ed06fac04ffe519e /azalea-protocol/src/packets/status/c_status_response.rs
parent139d77d3c2b0922fba5e9d4fa2bd9819d78bd773 (diff)
downloadazalea-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-xazalea-protocol/src/packets/status/c_status_response.rs61
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(())
+ }
+}