Difference between revisions of "Pre-release protocol"
(16w39a) |
|||
(918 intermediate revisions by 53 users not shown) | |||
Line 1: | Line 1: | ||
− | This page documents the changes from the [[Protocol|last stable Minecraft release]] (currently [[Protocol version numbers|1. | + | This page documents the changes from the [[Protocol|last stable Minecraft release]] (currently [[Protocol version numbers|1.20.4, protocol 765]]) to the current pre-release (currently [[Protocol version numbers|24w13a, protocol {{Snapshot PVN|1073742006}}]]). Note that this page contains bleeding-edge information that may not be completely or correctly documented. |
One who wishes to commandeer the merging of this into [[Protocol]] when an update is made must be sure to respect any changes that may have occurred to the respective packets there. | One who wishes to commandeer the merging of this into [[Protocol]] when an update is made must be sure to respect any changes that may have occurred to the respective packets there. | ||
Line 12: | Line 12: | ||
=== Packets === | === Packets === | ||
− | |||
− | |||
{| class="wikitable" | {| class="wikitable" | ||
Line 20: | Line 18: | ||
!colspan="2"| Documentation | !colspan="2"| Documentation | ||
|- | |- | ||
− | !colspan="4"| | + | !colspan="4"| Handshake serverbound |
{{PacketList|0x00|Handshake}} | {{PacketList|0x00|Handshake}} | ||
+ | |- | ||
+ | !colspan="4"| Login clientbound | ||
+ | {{PacketList|0x01|Encryption Request}} | ||
+ | {{PacketList|0x05|Cookie Request (login)|rel=added}} | ||
+ | |- | ||
+ | !colspan="4"| Login serverbound | ||
+ | {{PacketList|0x04|Cookie Response (login)|rel=added}} | ||
+ | |- | ||
+ | !colspan="4"| Configuration clientbound | ||
+ | {{PacketList|0x00|Cookie Request (configuration)|rel=added}} | ||
+ | {{PacketList|{{change|0x00|0x01}}|Clientbound Plugin Message (configuration)|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x01|0x02}}|Disconnect (configuration)|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x02|0x03}}|Finish Configuration|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x03|0x04}}|Clientbound Keep Alive (configuration)|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x04|0x05}}|Ping (configuration)|pre=unchanged}} | ||
+ | {{PacketList|0x06|Reset Chat|rel=added}} | ||
+ | {{PacketList|{{change|0x05|0x07}}|Registry Data}} | ||
+ | {{PacketList|{{change|0x06|0x08}}|Remove Resource Pack (configuration)|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x07|0x09}}|Add Resource Pack (configuration)|pre=unchanged}} | ||
+ | {{PacketList|0x0A|Store Cookie (configuration)|rel=added}} | ||
+ | {{PacketList|0x0B|Transfer (configuration)|rel=added}} | ||
+ | {{PacketList|{{change|0x08|0x0C}}|Feature Flags|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x09|0x0D}}|Update Tags (configuration)|pre=unchanged}} | ||
+ | {{PacketList|0x0E|Clientbound Known Packs|rel=added}} | ||
+ | |- | ||
+ | !colspan="4"| Configuration serverbound | ||
+ | {{PacketList|0x01|Cookie Response (configuration)|rel=added}} | ||
+ | {{PacketList|{{change|0x01|0x02}}|Serverbound Plugin Message (configuration)|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x02|0x03}}|Finish Configuration|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x03|0x04}}|Serverbound Keep Alive (configuration)|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x04|0x05}}|Pong (configuration)|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x05|0x06}}|Resource Pack Response (configuration)|pre=unchanged}} | ||
+ | {{PacketList|0x07|Serverbound Known Packs|rel=added}} | ||
|- | |- | ||
!colspan="4"| Play clientbound | !colspan="4"| Play clientbound | ||
− | {{PacketList| | + | {{PacketList|0x16|Cookie Request (Play)|rel=added}} |
− | {{PacketList| | + | {{PacketList|{{change|0x16|0x17}}|Set Cooldown|pre=unchanged}} |
+ | {{PacketList|{{change|0x17|0x18}}|Chat Suggestions|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x18|0x19}}|Clientbound Plugin Message (play)|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x19|0x1A}}|Damage Event|pre=unchanged}} | ||
+ | {{PacketList|0x1B|Debug Sample|rel=added}} | ||
+ | {{PacketList|{{change|0x1A|0x1C}}|Delete Message|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x1B|0x1D}}|Disconnect (play)|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x1C|0x1E}}|Disguised Chat Message|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x1D|0x1F}}|Entity Event|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x1E|0x20}}|Explosion|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x1F|0x21}}|Unload Chunk|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x20|0x22}}|Game Event|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x21|0x23}}|Open Horse Screen|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x22|0x24}}|Hurt Animation|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x23|0x25}}|Initialize World Border|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x24|0x26}}|Clientbound Keep Alive (play)|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x25|0x27}}|Chunk Data and Update Light|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x26|0x28}}|World Event|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x27|0x29}}|Particle|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x28|0x2A}}|Update Light|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x29|0x2B}}|Login (play)}} | ||
+ | {{PacketList|{{change|0x2A|0x2C}}|Map Data|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x2B|0x2D}}|Merchant Offers|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x2C|0x2E}}|Update Entity Position|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x2D|0x2F}}|Update Entity Position and Rotation|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x2E|0x30}}|Update Entity Rotation|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x2F|0x31}}|Move Vehicle|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x30|0x32}}|Open Book|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x31|0x33}}|Open Screen|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x32|0x34}}|Open Sign Editor|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x33|0x35}}|Ping (play)|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x34|0x36}}|Ping Response (play)|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x35|0x37}}|Place Ghost Recipe|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x36|0x38}}|Player Abilities|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x37|0x39}}|Player Chat Message|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x38|0x3A}}|End Combat|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x39|0x3B}}|Enter Combat|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x3A|0x3C}}|Combat Death|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x3B|0x3D}}|Player Info Remove|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x3C|0x3E}}|Player Info Update|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x3D|0x3F}}|Look At|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x3E|0x40}}|Synchronize Player Position|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x3F|0x41}}|Update Recipe Book|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x40|0x42}}|Remove Entities|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x41|0x43}}|Remove Entity Effect|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x42|0x44}}|Reset Score|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x43|0x45}}|Remove Resource Pack (play)|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x44|0x46}}|Add Resource Pack (play)|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x45|0x47}}|Respawn}} | ||
+ | {{PacketList|{{change|0x46|0x48}}|Set Head Rotation|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x47|0x49}}|Update Section Blocks|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x48|0x4A}}|Select Advancements Tab|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x49|0x4B}}|Server Data|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x4A|0x4C}}|Set Action Bar Text|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x4B|0x4D}}|Set Border Center|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x4C|0x4E}}|Set Border Lerp Size|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x4D|0x4F}}|Set Border Size|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x4E|0x50}}|Set Border Warning Delay|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x4F|0x51}}|Set Border Warning Distance|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x50|0x52}}|Set Camera|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x51|0x53}}|Set Held Item|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x52|0x54}}|Set Center Chunk|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x53|0x55}}|Set Render Distance|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x54|0x56}}|Set Default Spawn Position|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x55|0x57}}|Display Objective|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x56|0x58}}|Set Entity Metadata|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x57|0x59}}|Link Entities|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x58|0x5A}}|Set Entity Velocity|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x59|0x5B}}|Set Equipment|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x5A|0x5C}}|Set Experience|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x5B|0x5D}}|Set Health|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x5C|0x5E}}|Update Objectives|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x5D|0x5F}}|Set Passengers|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x5E|0x60}}|Update Teams|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x5F|0x61}}|Update Score|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x60|0x62}}|Set Simulation Distance|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x61|0x63}}|Set Subtitle Text|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x62|0x64}}|Update Time|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x63|0x65}}|Set Title Text|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x64|0x66}}|Set Title Animation Times|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x65|0x67}}|Entity Sound Effect|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x66|0x68}}|Sound Effect|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x67|0x69}}|Start Configuration|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x68|0x6A}}|Stop Sound|pre=unchanged}} | ||
+ | {{PacketList|0x6B|Store Cookie (Play)|rel=added}} | ||
+ | {{PacketList|{{change|0x69|0x6C}}|System Chat Message|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x6A|0x6D}}|Set Tab List Header And Footer|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x6B|0x6E}}|Tag Query Response|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x6C|0x6F}}|Pickup Item|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x6D|0x70}}|Teleport Entity|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x6E|0x71}}|Set Ticking State|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x6F|0x72}}|Step Tick|pre=unchanged}} | ||
+ | {{PacketList|0x73|Transfer (Play)|rel=added}} | ||
+ | {{PacketList|{{change|0x70|0x74}}|Update Advancements|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x71|0x75}}|Update Attributes}} | ||
+ | {{PacketList|{{change|0x72|0x76}}|Entity Effect}} | ||
+ | {{PacketList|{{change|0x73|0x77}}|Update Recipes|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x74|0x78}}|Update Tags (play)|pre=unchanged}} | ||
|- | |- | ||
!colspan="4"| Play serverbound | !colspan="4"| Play serverbound | ||
− | {{PacketList| | + | {{PacketList|0x04|Chat Command}} |
− | | | + | {{PacketList|0x05|Signed Chat Command|rel=added}} |
− | |} | + | {{PacketList|{{change|0x05|0x06}}|Chat Message|pre=unchanged}} |
+ | {{PacketList|{{change|0x06|0x07}}|Player Session|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x07|0x08}}|Chunk Batch Received|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x08|0x09}}|Client Status|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x09|0x0A}}|Client Information (play)|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x0A|0x0B}}|Command Suggestions Request|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x0B|0x0C}}|Acknowledge Configuration|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x0C|0x0D}}|Click Container Button|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x0D|0x0E}}|Click Container|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x0E|0x0F}}|Close Container|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x0F|0x10}}|Change Container Slot State|pre=unchanged}} | ||
+ | {{PacketList|0x11|Cookie Response (play)|rel=added}} | ||
+ | {{PacketList|{{change|0x10|0x12}}|Serverbound Plugin Message (play)|pre=unchanged}} | ||
+ | {{PacketList|0x13|Debug Sample Subscription|rel=added}} | ||
+ | {{PacketList|{{change|0x11|0x14}}|Edit Book|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x12|0x15}}|Query Entity Tag|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x13|0x16}}|Interact|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x14|0x17}}|Jigsaw Generate|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x15|0x18}}|Serverbound Keep Alive (play)|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x16|0x19}}|Lock Difficulty|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x17|0x1A}}|Set Player Position|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x18|0x1B}}|Set Player Position and Rotation|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x19|0x1C}}|Set Player Rotation|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x1A|0x1D}}|Set Player On Ground|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x1B|0x1E}}|Move Vehicle|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x1C|0x1F}}|Paddle Boat|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x1D|0x20}}|Pick Item|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x1E|0x21}}|Ping Request (play)|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x1F|0x22}}|Place Recipe|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x20|0x23}}|Player Abilities|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x21|0x24}}|Player Action|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x22|0x25}}|Player Command|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x23|0x26}}|Player Input|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x24|0x27}}|Pong (play)|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x25|0x28}}|Change Recipe Book Settings|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x26|0x29}}|Set Seen Recipe|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x27|0x2A}}|Rename Item|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x28|0x2B}}|Resource Pack Response (play)|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x29|0x2C}}|Seen Advancements|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x2A|0x2D}}|Select Trade|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x2B|0x2E}}|Set Beacon Effect|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x2C|0x2F}}|Set Held Item|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x2D|0x30}}|Program Command Block|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x2E|0x31}}|Program Command Block Minecart|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x2F|0x32}}|Set Creative Mode Slot|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x30|0x33}}|Program Jigsaw Block|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x31|0x34}}|Program Structure Block|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x32|0x35}}|Update Sign|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x33|0x36}}|Swing Arm|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x34|0x37}}|Teleport To Entity|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x35|0x38}}|Use Item On|pre=unchanged}} | ||
+ | {{PacketList|{{change|0x36|0x39}}|Use Item|pre=unchanged}} | ||
+ | |} | ||
== New/modified data types == | == New/modified data types == | ||
− | == | + | No changes so far. |
+ | |||
+ | == Entity Metadata == | ||
+ | |||
+ | {{#vardefine: meta_prerelease | 1}} | ||
− | + | {{Metadata type definition/begin}} | |
+ | ! Value | ||
+ | ! Notes | ||
+ | {{Metadata type definition|Byte}} | ||
+ | | {{Type|Byte}} | ||
+ | | | ||
+ | {{Metadata type definition|VarInt}} | ||
+ | | {{Type|VarInt}} | ||
+ | | | ||
+ | {{Metadata type definition|VarLong}} | ||
+ | | {{Type|VarLong}} | ||
+ | | | ||
+ | {{Metadata type definition|Float}} | ||
+ | | {{Type|Float}} | ||
+ | | | ||
+ | {{Metadata type definition|String}} | ||
+ | | {{Type|String}} | ||
+ | | | ||
+ | {{Metadata type definition|Text Component}} | ||
+ | | {{Type|Text Component}} | ||
+ | | | ||
+ | {{Metadata type definition|Optional Text Component}} | ||
+ | | ({{Type|Boolean}}, {{Type|Optional}} {{Type|Text Component}}) | ||
+ | | Text Component is present if the Boolean is set to true. | ||
+ | {{Metadata type definition|Slot}} | ||
+ | | {{Type|Slot}} | ||
+ | | | ||
+ | {{Metadata type definition|Boolean}} | ||
+ | | {{Type|Boolean}} | ||
+ | | | ||
+ | {{Metadata type definition|Rotations}} | ||
+ | | ({{Type|Float}}, {{Type|Float}}, {{Type|Float}}) | ||
+ | | rotation on x, rotation on y, rotation on z | ||
+ | {{Metadata type definition|Position}} | ||
+ | | {{Type|Position}} | ||
+ | | | ||
+ | {{Metadata type definition|Optional Position}} | ||
+ | | ({{Type|Boolean}}, {{Type|Optional}} {{Type|Position}}) | ||
+ | | Position is present if the Boolean is set to true. | ||
+ | {{Metadata type definition|Direction}} | ||
+ | | {{Type|VarInt}} {{Type|Enum}} | ||
+ | | Down = 0, Up = 1, North = 2, South = 3, West = 4, East = 5 | ||
+ | {{Metadata type definition|Optional UUID}} | ||
+ | | ({{Type|Boolean}}, {{Type|Optional}} {{Type|UUID}}) | ||
+ | | UUID is present if the Boolean is set to true. | ||
+ | {{Metadata type definition|Block State}} | ||
+ | | {{Type|VarInt}} | ||
+ | | An ID in the block state registry. | ||
+ | {{Metadata type definition|Optional Block State}} | ||
+ | | {{Type|VarInt}} | ||
+ | | 0 for absent (air is unrepresentable); otherwise, an ID in the block state registry. | ||
+ | {{Metadata type definition|NBT}} | ||
+ | | {{Type|NBT}} | ||
+ | | | ||
+ | {{Metadata type definition|Particle}} | ||
+ | | ({{Type|VarInt}}, Varies) | ||
+ | | particle type (an ID in the <code>minecraft:particle_type</code> registry), particle data (See [[Particles]].) | ||
+ | {{Metadata type definition|Particles|rel=added}} | ||
+ | | ({{Type|VarInt}}, Array of Particle) | ||
+ | | length of array, particle data (See directly above.) | ||
+ | {{Metadata type definition|Villager Data}} | ||
+ | | ({{Type|VarInt}}, {{Type|VarInt}}, {{Type|VarInt}}) | ||
+ | | villager type, villager profession, level (See below.) | ||
+ | {{Metadata type definition|Optional VarInt}} | ||
+ | | {{Type|VarInt}} | ||
+ | | 0 for absent; 1 + actual value otherwise. Used for entity IDs. | ||
+ | {{Metadata type definition|Pose}} | ||
+ | | {{Type|VarInt}} {{Type|Enum}} | ||
+ | | STANDING = 0, FALL_FLYING = 1, SLEEPING = 2, SWIMMING = 3, SPIN_ATTACK = 4, SNEAKING = 5, LONG_JUMPING = 6, DYING = 7, CROAKING = 8, USING_TONGUE = 9, SITTING = 10, ROARING = 11, SNIFFING = 12, EMERGING = 13, DIGGING = 14{{change||2=, SLIDING = 15, SHOOTING = 16, INHALING = 17}} | ||
+ | {{Metadata type definition|Cat Variant}} | ||
+ | | {{Type|VarInt}} | ||
+ | | An ID in the <code>minecraft:cat_variant</code> registry. | ||
+ | {{Metadata type definition|Wolf Variant|rel=added}} | ||
+ | | {{Type|VarInt}} | ||
+ | | An ID in the <code>minecraft:wolf_variant</code> registry. | ||
+ | {{Metadata type definition|Frog Variant}} | ||
+ | | {{Type|VarInt}} | ||
+ | | An ID in the <code>minecraft:frog_variant</code> registry. | ||
+ | {{Metadata type definition|Optional Global Position}} | ||
+ | | ({{Type|Boolean}}, {{Type|Optional}} {{Type|Identifier}}, {{Type|Optional}} {{Type|Position}}) | ||
+ | | dimension identifier, position; only if the Boolean is set to true. | ||
+ | {{Metadata type definition|Painting Variant}} | ||
+ | | {{Type|VarInt}} | ||
+ | | An ID in the <code>minecraft:painting_variant</code> registry. | ||
+ | {{Metadata type definition|Sniffer State}} | ||
+ | | {{Type|VarInt}} {{Type|Enum}} | ||
+ | | IDLING = 0, FEELING_HAPPY = 1, SCENTING = 2, SNIFFING = 3, SEARCHING = 4, DIGGING = 5, RISING = 6 | ||
+ | {{Metadata type definition|Armadillo State|rel=added}} | ||
+ | | {{Type|VarInt}} {{Type|Enum}} | ||
+ | | IDLE = 0, ROLLING = 1, SCARED = 2 | ||
+ | {{Metadata type definition|Vector3}} | ||
+ | | ({{Type|Float}}, {{Type|Float}}, {{Type|Float}}) | ||
+ | | x, y, z | ||
+ | {{Metadata type definition|Quaternion}} | ||
+ | | ({{Type|Float}}, {{Type|Float}}, {{Type|Float}}, {{Type|Float}}) | ||
+ | | x, y, z, w | ||
+ | |} | ||
− | + | === Living Entity === | |
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | + | TODO: This has changed to use the PARTICLES attribute | |
− | === | + | === Wolf === |
− | + | {{Metadata inherit|Wolf|inherits=Tameable Animal}} | |
− | {| class="wikitable | + | {| class="wikitable" |
! Index | ! Index | ||
! Type | ! Type | ||
!style="width: 250px;" colspan="2"| Meaning | !style="width: 250px;" colspan="2"| Meaning | ||
+ | ! Default | ||
+ | |- {{added}} | ||
+ | | {{Metadata id|}} | ||
+ | | {{Metadata type|Wolf Variant}} | ||
+ | |colspan="2"| Wolf Variant | ||
+ | | PALE | ||
+ | |- | ||
+ | | {{Metadata id|}} | ||
+ | | {{Metadata type|Boolean}} | ||
+ | |colspan="2"| Is begging | ||
+ | | false | ||
+ | |- | ||
+ | | {{Metadata id|}} | ||
+ | | {{Metadata type|VarInt}} | ||
+ | |colspan="2"| Collar color (values are those {{Minecraft Wiki|Data_values#Dyes|used with dyes}}) | ||
+ | | 14 (Red) | ||
|- | |- | ||
− | | | + | | {{Metadata id|}} |
− | | | + | | {{Metadata type|VarInt}} |
− | |colspan="2"| | + | |colspan="2"| Anger time |
+ | | 0 | ||
|} | |} | ||
− | === | + | === Armadillo === |
− | + | {{Metadata inherit|Armadillo|inherits=Animal|start_at=17}} | |
− | + | {| class="wikitable" {{added}} | |
− | {| class="wikitable" | ||
! Index | ! Index | ||
! Type | ! Type | ||
!style="width: 250px;" colspan="2"| Meaning | !style="width: 250px;" colspan="2"| Meaning | ||
+ | ! Default | ||
|- | |- | ||
− | | | + | | {{Metadata id|added}} |
− | | | + | | {{Metadata type|Armadillo State}} |
− | |colspan="2"| | + | |colspan="2"| Armadillo State |
− | | | + | | IDLE |
− | |||
− | |||
− | |||
|} | |} | ||
− | === | + | == Block Actions == |
+ | |||
+ | No changes so far. | ||
+ | |||
+ | == Inventories == | ||
+ | |||
+ | No changes so far. | ||
− | + | == Plugin Channels == | |
− | + | No changes so far. | |
− | + | == Handshake == | |
− | === | + | === Serverbound === |
− | + | ==== Handshake ==== | |
+ | |||
+ | This causes the server to switch into the target state. | ||
{| class="wikitable" | {| class="wikitable" | ||
− | ! | + | ! Packet ID |
− | ! Type | + | ! State |
− | ! | + | ! Bound To |
+ | ! Field Name | ||
+ | ! Field Type | ||
+ | ! Notes | ||
+ | |- | ||
+ | | rowspan="4"| 0x00 | ||
+ | | rowspan="4"| Handshaking | ||
+ | | rowspan="4"| Server | ||
+ | | Protocol Version | ||
+ | | [[#Definitions:varint|VarInt]] | ||
+ | | See [[protocol version numbers]] (currently 765 in Minecraft 1.20.4). | ||
|- | |- | ||
− | | | + | | Server Address |
− | | | + | | [[#Definitions:string|String]] (255) |
− | | | + | | Hostname or IP, e.g. localhost or 127.0.0.1, that was used to connect. The Notchian server does not use this information. Note that SRV records are a simple redirect, e.g. if _minecraft._tcp.example.com points to mc.example.org, users connecting to example.com will provide example.org as server address in addition to connecting to it. |
|- | |- | ||
− | | | + | | Server Port |
− | + | | [[#Definitions:unsigned-short|Unsigned Short]] | |
− | + | | Default is 25565. The Notchian server does not use this information. | |
− | |- | ||
− | |||
− | | | ||
− | |||
|- | |- | ||
− | | | + | | Next State |
− | | | + | | [[#Definitions:varint|VarInt]] [[#Definitions:enum|Enum]] |
− | + | | 1 for [[#Status|Status]], 2 for [[#Login|Login]]{{change||, 3 for [[#Login|Transfer]]}}. | |
|} | |} | ||
− | == | + | == Status == |
− | + | === Clientbound === | |
− | + | No changes so far. | |
− | + | ||
− | + | === Serverbound === | |
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | + | No changes so far. | |
− | + | == Login == | |
− | === | + | === Clientbound === |
− | + | ==== Encryption Request ==== | |
{| class="wikitable" | {| class="wikitable" | ||
− | ! | + | ! Packet ID |
− | ! Type | + | ! State |
− | ! | + | ! Bound To |
− | | | + | ! Field Name |
− | |rowspan=" | + | ! Field Type |
− | |rowspan=" | + | ! Notes |
− | + | |- | |
− | + | | rowspan="6"| 0x01 | |
− | |- | + | | rowspan="6"| Login |
− | | | + | | rowspan="6"| Client |
− | | | + | | Server ID |
− | |- | + | | {{Type|String}} (20) |
− | | | + | | Appears to be empty. |
− | | | + | |- |
− | |- | + | | Public Key Length |
− | | | + | | {{Type|VarInt}} |
− | | | + | | Length of Public Key. |
− | | | + | |- |
+ | | Public Key | ||
+ | | {{Type|Byte Array}} | ||
+ | | The server's public key, in bytes. | ||
+ | |- | ||
+ | | Verify Token Length | ||
+ | | {{Type|VarInt}} | ||
+ | | Length of Verify Token. Always 4 for Notchian servers. | ||
|- | |- | ||
− | | | + | | Verify Token |
− | | | + | | {{Type|Byte Array}} |
− | | | + | | A sequence of random bytes generated by the server. |
+ | |- {{added}} | ||
+ | | Should Authenticate | ||
+ | | {{Type|Boolean}} | ||
+ | | | ||
|} | |} | ||
− | === | + | ==== Cookie Request (login) ==== |
+ | |||
+ | Requests a cookie that was previously stored. | ||
+ | |||
+ | {| class="wikitable" {{added}} | ||
+ | ! Packet ID | ||
+ | ! State | ||
+ | ! Bound To | ||
+ | ! colspan="2"| Field Name | ||
+ | ! colspan="2"| Field Type | ||
+ | ! Notes | ||
+ | |- | ||
+ | | rowspan="1"| 0x05 | ||
+ | | rowspan="1"| Login | ||
+ | | rowspan="1"| Client | ||
+ | | colspan="2"| Key | ||
+ | | colspan="2"| Identifier | ||
+ | | The identifier of the cookie. | ||
+ | |} | ||
− | + | === Serverbound === | |
− | === | + | ==== Cookie Response (login) ==== |
− | + | Response to a [[#Cookie_Request_(login)|Cookie Request (login)]] from the server. The Notchian server only accepts responses of up to 5 kiB in size. | |
− | {| class="wikitable" | + | {| class="wikitable" {{added}} |
− | ! | + | ! Packet ID |
− | ! | + | ! State |
− | ! | + | ! Bound To |
+ | ! colspan="2"| Field Name | ||
+ | ! colspan="2"| Field Type | ||
+ | ! Notes | ||
|- | |- | ||
− | |rowspan=" | + | | rowspan="4"| 0x04 |
− | |rowspan=" | + | | rowspan="4"| Login |
− | + | | rowspan="4"| Server | |
− | + | | colspan="2"| Key | |
+ | | colspan="2"| Identifier | ||
+ | | The identifier of the cookie. | ||
|- | |- | ||
− | | | + | | colspan="2"| Has Payload |
− | | | + | | colspan="2"| Boolean |
+ | | The payload is only present if the cookie exists on the client. | ||
|- | |- | ||
− | | | + | | colspan="2"| Payload Length |
− | | | + | | colspan="2"| VarInt |
+ | | Length of the following byte array. | ||
|- | |- | ||
− | | | + | | colspan="2"| Payload |
− | | | + | | colspan="2"| Optional Byte Array (5120) |
+ | | The data of the cookie, if any. | ||
+ | |} | ||
+ | |||
+ | == Configuration == | ||
+ | |||
+ | === Clientbound === | ||
+ | |||
+ | ==== Cookie Request (configuration) ==== | ||
+ | |||
+ | Requests a cookie that was previously stored. | ||
+ | |||
+ | {| class="wikitable" {{added}} | ||
+ | ! Packet ID | ||
+ | ! State | ||
+ | ! Bound To | ||
+ | ! colspan="2"| Field Name | ||
+ | ! colspan="2"| Field Type | ||
+ | ! Notes | ||
|- | |- | ||
− | | | + | | rowspan="1"| 0x00 |
− | | | + | | rowspan="1"| Configuration |
+ | | rowspan="1"| Client | ||
+ | | colspan="2"| Key | ||
+ | | colspan="2"| Identifier | ||
+ | | The identifier of the cookie. | ||
+ | |} | ||
+ | |||
+ | ==== Reset Chat ==== | ||
+ | |||
+ | {| class="wikitable" {{added}} | ||
+ | ! Packet ID | ||
+ | ! State | ||
+ | ! Bound To | ||
+ | ! Field Name | ||
+ | ! Field Type | ||
+ | ! Notes | ||
|- | |- | ||
− | | | + | | 0x06 |
− | | | + | | Configuration |
+ | | Client | ||
+ | | colspan="3"| ''no fields'' | ||
+ | |} | ||
+ | |||
+ | ==== Registry Data ==== | ||
+ | |||
+ | Represents certain registries that are sent from the server and are applied on the client. {{change||The packet is sent for each of the following registries: <code>minecraft:worldgen/biome</code>, <code>minecraft:chat_type</code>, <code>minecraft:trim_pattern</code>, <code>minecraft:trim_material</code>, <code>minecraft:wolf_variant</code>, <code>minecraft:dimension_type</code>, <code>minecraft:damage_type</code>, and <code>minecraft:banner_pattern</code>.}} | ||
+ | |||
+ | {| class="wikitable" | ||
+ | ! Packet ID | ||
+ | ! State | ||
+ | ! Bound To | ||
+ | ! colspan="2"| Field Name | ||
+ | ! colspan="2"| Field Type | ||
+ | ! Notes | ||
|- | |- | ||
− | | | + | | rowspan="6"| 0x07 |
− | | | + | | rowspan="6"| Configuration |
− | |- | + | | rowspan="6"| Client |
− | | | + | |{{removed}} colspan="2"| Registry Codec |
− | | | + | |{{removed}} colspan="2"| {{Type|NBT}} (Compound) |
+ | |{{removed}}| See [[Registry Data]]. | ||
+ | |- {{added}} | ||
+ | | colspan="2"| Registry ID | ||
+ | | colspan="2"| Identifier | ||
+ | | | ||
+ | |- {{added}} | ||
+ | | colspan="2"| Entry Count | ||
+ | | colspan="2"| VarInt | ||
+ | | Number of entries in the following array. | ||
+ | |- {{added}} | ||
+ | | rowspan="3"| Entries | ||
+ | | Entry ID | ||
+ | | rowspan="3"| Array | ||
+ | | Identifier | ||
+ | | | ||
+ | |- {{added}} | ||
+ | | Has Data | ||
+ | | Boolean | ||
+ | | Whether the entry has any data following. | ||
+ | |- {{added}} | ||
+ | | Data | ||
+ | | NBT Tag | ||
+ | | Entry data. Only present if Has Data is true. | ||
+ | |} | ||
+ | |||
+ | ==== Store Cookie (configuration) ==== | ||
+ | |||
+ | Stores some arbitrary data on the client, which persists between server transfers. The Notchian client only accepts cookies of up to 5 kiB in size. | ||
+ | |||
+ | {| class="wikitable" {{added}} | ||
+ | ! Packet ID | ||
+ | ! State | ||
+ | ! Bound To | ||
+ | ! colspan="2"| Field Name | ||
+ | ! colspan="2"| Field Type | ||
+ | ! Notes | ||
|- | |- | ||
− | | | + | | rowspan="2"| 0x0A |
− | | | + | | rowspan="2"| Configuration |
+ | | rowspan="2"| Client | ||
+ | | colspan="2"| Key | ||
+ | | colspan="2"| Identifier | ||
+ | | The identifier of the cookie. | ||
|- | |- | ||
− | | | + | | colspan="2"| Payload |
− | + | | colspan="2"| ByteArray(5120) | |
− | |colspan="2"| | + | | The data of the cookie. |
|} | |} | ||
− | === | + | ==== Transfer (configuration) ==== |
− | + | Notifies the client that it should transfer to the given server. Cookies previously stored are preserved between server transfers. | |
− | {| class="wikitable" | + | {| class="wikitable" {{added}} |
− | ! | + | ! Packet ID |
− | ! | + | ! State |
− | ! | + | ! Bound To |
+ | ! colspan="2"| Field Name | ||
+ | ! colspan="2"| Field Type | ||
+ | ! Notes | ||
|- | |- | ||
− | | | + | | rowspan="2"| 0x0B |
− | | | + | | rowspan="2"| Configuration |
− | |colspan="2"| | + | | rowspan="2"| Client |
+ | | colspan="2"| Host | ||
+ | | colspan="2"| String | ||
+ | | The hostname of IP of the server. | ||
|- | |- | ||
− | | | + | | colspan="2"| Port |
− | + | | colspan="2"| VarInt | |
− | |colspan="2"| | + | | The port of the server. |
|} | |} | ||
− | === | + | ==== Clientbound Known Packs ==== |
+ | Informs the client of which data packs are present on the server. | ||
+ | The client is expected to respond with its own [[#Serverbound_Known_Packs|Serverbown Known Packs]] packet. | ||
+ | The Notchian server does not continue with Configuration until it receives a response. | ||
− | + | {| class="wikitable" {{added}} | |
+ | ! Packet ID | ||
+ | ! State | ||
+ | ! Bound To | ||
+ | ! colspan="2"| Field Name | ||
+ | ! colspan="2"| Field Type | ||
+ | ! Notes | ||
+ | |- | ||
+ | | rowspan="4"| 0x0E | ||
+ | | rowspan="4"| Configuration | ||
+ | | rowspan="4"| Client | ||
+ | | colspan="2"| Known Pack Count | ||
+ | | colspan="2"| VarInt | ||
+ | | The number of known packs in the following array. | ||
+ | |- | ||
+ | | rowspan="3"| Known Packs | ||
+ | | Namespace | ||
+ | | rowspan="3"| Array | ||
+ | | String | ||
+ | | | ||
+ | |- | ||
+ | | ID | ||
+ | | String | ||
+ | | | ||
+ | |- | ||
+ | | Version | ||
+ | | String | ||
+ | | | ||
+ | |} | ||
− | === | + | === Serverbound === |
− | + | ==== Cookie Response (configuration) ==== | |
− | + | Response to a [[#Cookie_Request_(configuration)|Cookie Request (configuration)]] from the server. The Notchian server only accepts responses of up to 5 kiB in size. | |
− | + | {| class="wikitable" {{added}} | |
− | + | ! Packet ID | |
− | {| class="wikitable" | + | ! State |
− | ! | + | ! Bound To |
− | ! | + | ! colspan="2"| Field Name |
− | + | ! colspan="2"| Field Type | |
+ | ! Notes | ||
+ | |- | ||
+ | | rowspan="4"| 0x01 | ||
+ | | rowspan="4"| Configuration | ||
+ | | rowspan="4"| Server | ||
+ | | colspan="2"| Key | ||
+ | | colspan="2"| Identifier | ||
+ | | The identifier of the cookie. | ||
+ | |- | ||
+ | | colspan="2"| Has Payload | ||
+ | | colspan="2"| Boolean | ||
+ | | The payload is only present if the cookie exists on the client. | ||
+ | |- | ||
+ | | colspan="2"| Payload Length | ||
+ | | colspan="2"| VarInt | ||
+ | | Length of the following byte array. | ||
|- | |- | ||
− | | | + | | colspan="2"| Payload |
− | + | | colspan="2"| Optional Byte Array (5120) | |
− | |colspan="2"| | + | | The data of the cookie, if any. |
|} | |} | ||
− | === | + | ==== Serverbound Known Packs ==== |
− | + | ID 0x07, same structure as Clientbound Known Packs. If the client specifies a pack in this packet, the server should omit its contained data from Registry Data. | |
− | == | + | == Play == |
− | |||
− | |||
− | |||
− | |||
=== Clientbound === | === Clientbound === | ||
− | + | ==== Cookie Request (play) ==== | |
− | + | Requests a cookie that was previously stored. | |
− | ==== | + | {| class="wikitable" {{added}} |
+ | ! Packet ID | ||
+ | ! State | ||
+ | ! Bound To | ||
+ | ! colspan="2"| Field Name | ||
+ | ! colspan="2"| Field Type | ||
+ | ! Notes | ||
+ | |- | ||
+ | | rowspan="1"| 0x16 | ||
+ | | rowspan="1"| Play | ||
+ | | rowspan="1"| Client | ||
+ | | colspan="2"| Key | ||
+ | | colspan="2"| Identifier | ||
+ | | The identifier of the cookie. | ||
+ | |} | ||
− | + | ==== Debug Sample ==== | |
− | {| class="wikitable" | + | {| class="wikitable" {{added}} |
! Packet ID | ! Packet ID | ||
! State | ! State | ||
Line 549: | Line 759: | ||
! Notes | ! Notes | ||
|- | |- | ||
− | |rowspan=" | + | | rowspan="3"| 0x1B |
− | |rowspan=" | + | | rowspan="3"| Play |
− | |rowspan=" | + | | rowspan="3"| Client |
− | | | + | | Sample Length |
| VarInt | | VarInt | ||
− | | | + | | The length of the following array. |
|- | |- | ||
− | | | + | | Sample |
− | | | + | | Long Array |
− | | | + | | TODO: What is the structure of the data in this array? |
− | |||
− | |||
− | |||
− | |||
|- | |- | ||
− | | | + | | Sample Type |
| VarInt Enum | | VarInt Enum | ||
− | | | + | | The type of sample data. Currently always 0 (TICK_TIME). |
|} | |} | ||
− | == | + | ==== Login (play) ==== |
− | === | + | {| class="wikitable" |
+ | ! Packet ID | ||
+ | ! State | ||
+ | ! Bound To | ||
+ | ! Field Name | ||
+ | ! Field Type | ||
+ | ! Notes | ||
+ | |- | ||
+ | | rowspan="22"| 0x2B | ||
+ | | rowspan="22"| Play | ||
+ | | rowspan="22"| Client | ||
+ | | Entity ID | ||
+ | | {{Type|Int}} | ||
+ | | The player's Entity ID (EID). | ||
+ | |- | ||
+ | | Is hardcore | ||
+ | | {{Type|Boolean}} | ||
+ | | | ||
+ | |- | ||
+ | | Dimension Count | ||
+ | | {{Type|VarInt}} | ||
+ | | Size of the following array. | ||
+ | |- | ||
+ | | Dimension Names | ||
+ | | {{Type|Array}} of {{Type|Identifier}} | ||
+ | | Identifiers for all dimensions on the server. | ||
+ | |- | ||
+ | | Max Players | ||
+ | | {{Type|VarInt}} | ||
+ | | Was once used by the client to draw the player list, but now is ignored. | ||
+ | |- | ||
+ | | View Distance | ||
+ | | {{Type|VarInt}} | ||
+ | | Render distance (2-32). | ||
+ | |- | ||
+ | | Simulation Distance | ||
+ | | {{Type|VarInt}} | ||
+ | | The distance that the client will process specific things, such as entities. | ||
+ | |- | ||
+ | | Reduced Debug Info | ||
+ | | {{Type|Boolean}} | ||
+ | | If true, a Notchian client shows reduced information on the {{Minecraft Wiki|debug screen}}. For servers in development, this should almost always be false. | ||
+ | |- | ||
+ | | Enable respawn screen | ||
+ | | {{Type|Boolean}} | ||
+ | | Set to false when the doImmediateRespawn gamerule is true. | ||
+ | |- | ||
+ | | Do limited crafting | ||
+ | | {{Type|Boolean}} | ||
+ | | Whether players can only craft recipes they have already unlocked. Currently unused by the client. | ||
+ | |- | ||
+ | | Dimension Type | ||
+ | | {{change|Identifier|VarInt}} | ||
+ | | The ID of the type of dimension in the <code>minecraft:dimension_type</code> registry, defined by the Registry Data packet. | ||
+ | |- | ||
+ | | Dimension Name | ||
+ | | {{Type|Identifier}} | ||
+ | | Name of the dimension being spawned into. | ||
+ | |- | ||
+ | | Hashed seed | ||
+ | | {{Type|Long}} | ||
+ | | First 8 bytes of the SHA-256 hash of the world's seed. Used client side for biome noise | ||
+ | |- | ||
+ | | Game mode | ||
+ | | {{Type|Unsigned Byte}} | ||
+ | | 0: Survival, 1: Creative, 2: Adventure, 3: Spectator. | ||
+ | |- | ||
+ | | Previous Game mode | ||
+ | | {{Type|Byte}} | ||
+ | | -1: Undefined (null), 0: Survival, 1: Creative, 2: Adventure, 3: Spectator. The previous game mode. Vanilla client uses this for the debug (F3 + N & F3 + F4) game mode switch. (More information needed) | ||
+ | |- | ||
+ | | Is Debug | ||
+ | | {{Type|Boolean}} | ||
+ | | True if the world is a {{Minecraft Wiki|debug mode}} world; debug mode worlds cannot be modified and have predefined blocks. | ||
+ | |- | ||
+ | | Is Flat | ||
+ | | {{Type|Boolean}} | ||
+ | | True if the world is a {{Minecraft Wiki|superflat}} world; flat worlds have different void fog and a horizon at y=0 instead of y=63. | ||
+ | |- | ||
+ | | Has death location | ||
+ | | {{Type|Boolean}} | ||
+ | | If true, then the next two fields are present. | ||
+ | |- | ||
+ | | Death dimension name | ||
+ | | {{Type|Optional}} {{Type|Identifier}} | ||
+ | | Name of the dimension the player died in. | ||
+ | |- | ||
+ | | Death location | ||
+ | | {{Type|Optional}} {{Type|Position}} | ||
+ | | The location that the player died at. | ||
+ | |- | ||
+ | | Portal cooldown | ||
+ | | {{Type|VarInt}} | ||
+ | | The number of ticks until the player can use the portal again. | ||
+ | |- | ||
+ | | Enforces Secure Chat | ||
+ | | {{Type|Boolean}} | ||
+ | | | ||
+ | |} | ||
− | ==== | + | ==== Respawn ==== |
− | |||
− | |||
{| class="wikitable" | {| class="wikitable" | ||
Line 585: | Line 887: | ||
! Notes | ! Notes | ||
|- | |- | ||
− | |rowspan=" | + | | rowspan="12"| 0x47 |
− | |rowspan=" | + | | rowspan="12"| Play |
− | |rowspan=" | + | | rowspan="12"| Client |
− | | | + | | Dimension Type |
− | | | + | | {{change|Identifier|VarInt}} |
− | | | + | | The ID of the type of dimension in the <code>minecraft:dimension_type</code> registry, defined by the [[Protocol#Registry_Data|Registry Data]] packet. |
+ | |- | ||
+ | | Dimension Name | ||
+ | | {{Type|Identifier}} | ||
+ | | Name of the dimension being spawned into. | ||
+ | |- | ||
+ | | Hashed seed | ||
+ | | {{Type|Long}} | ||
+ | | First 8 bytes of the SHA-256 hash of the world's seed. Used client side for biome noise | ||
+ | |- | ||
+ | | Game mode | ||
+ | | {{Type|Unsigned Byte}} | ||
+ | | 0: Survival, 1: Creative, 2: Adventure, 3: Spectator. | ||
+ | |- | ||
+ | | Previous Game mode | ||
+ | | {{Type|Byte}} | ||
+ | | -1: Undefined (null), 0: Survival, 1: Creative, 2: Adventure, 3: Spectator. The previous game mode. Vanilla client uses this for the debug (F3 + N & F3 + F4) game mode switch. (More information needed) | ||
|- | |- | ||
− | | | + | | Is Debug |
− | | | + | | {{Type|Boolean}} |
− | | | + | | True if the world is a {{Minecraft Wiki|debug mode}} world; debug mode worlds cannot be modified and have predefined blocks. |
|- | |- | ||
− | | | + | | Is Flat |
− | | {{ | + | | {{Type|Boolean}} |
− | | | + | | True if the world is a {{Minecraft Wiki|superflat}} world; flat worlds have different void fog and a horizon at y=0 instead of y=63. |
|- | |- | ||
− | | | + | | Has death location |
− | | | + | | {{Type|Boolean}} |
− | | | + | | If true, then the next two fields are present. |
|- | |- | ||
− | | | + | | Death dimension Name |
− | | | + | | {{Type|Optional}} {{Type|Identifier}} |
− | | | + | | Name of the dimension the player died in. |
|- | |- | ||
− | | | + | | Death location |
− | | | + | | {{Type|Optional}} {{Type|Position}} |
− | | | + | | The location that the player died at. |
|- | |- | ||
− | | | + | | Portal cooldown |
− | | | + | | {{Type|VarInt}} |
− | | | + | | The number of ticks until the player can use the portal again. |
|- | |- | ||
− | | | + | | Data kept |
− | | | + | | {{Type|Byte}} |
− | | | + | | Bit mask. 0x01: Keep attributes, 0x02: Keep metadata. Tells which data should be kept on the client side once the player has respawned. |
+ | In the Notchian implementation, this is context dependent: | ||
+ | * normal respawns (after death) keep no data; | ||
+ | * exiting the end poem/credits keeps the attributes; | ||
+ | * other dimension changes (portals or teleports) keep all data. | ||
+ | |} | ||
+ | |||
+ | ==== Store Cookie (play) ==== | ||
+ | |||
+ | Stores some arbitrary data on the client, which persists between server transfers. The Notchian client only accepts cookies of up to 5 kiB in size. | ||
+ | |||
+ | {| class="wikitable" {{added}} | ||
+ | ! Packet ID | ||
+ | ! State | ||
+ | ! Bound To | ||
+ | ! colspan="2"| Field Name | ||
+ | ! colspan="2"| Field Type | ||
+ | ! Notes | ||
|- | |- | ||
− | | | + | | rowspan="3"| 0x6B |
− | | | + | | rowspan="3"| Play |
− | | | + | | rowspan="3"| Client |
+ | | colspan="2"| Key | ||
+ | | colspan="2"| Identifier | ||
+ | | The identifier of the cookie. | ||
|- | |- | ||
− | | | + | | colspan="2"| Payload Length |
− | | | + | | colspan="2"| VarInt |
− | | | + | | Length of the following byte array. |
|- | |- | ||
− | | | + | | colspan="2"| Payload |
− | | | + | | colspan="2"| Byte Array (5120) |
− | | | + | | The data of the cookie. |
+ | |} | ||
+ | |||
+ | ==== Transfer (play) ==== | ||
+ | |||
+ | Notifies the client that it should transfer to the given server. Cookies previously stored are preserved between server transfers. | ||
+ | |||
+ | {| class="wikitable" {{added}} | ||
+ | ! Packet ID | ||
+ | ! State | ||
+ | ! Bound To | ||
+ | ! colspan="2"| Field Name | ||
+ | ! colspan="2"| Field Type | ||
+ | ! Notes | ||
|- | |- | ||
− | | | + | | rowspan="2"| 0x73 |
− | | | + | | rowspan="2"| Play |
− | | | + | | rowspan="2"| Client |
+ | | colspan="2"| Host | ||
+ | | colspan="2"| String | ||
+ | | The hostname of IP of the server. | ||
|- | |- | ||
− | | | + | | colspan="2"| Port |
− | | | + | | colspan="2"| VarInt |
− | | | + | | The port of the server. |
|} | |} | ||
− | ==== | + | ==== Update Attributes ==== |
− | + | Sets {{Minecraft Wiki|Attribute|attributes}} on the given entity. | |
{| class="wikitable" | {| class="wikitable" | ||
Line 649: | Line 1,003: | ||
! State | ! State | ||
! Bound To | ! Bound To | ||
+ | ! colspan="2"| Field Name | ||
+ | ! colspan="2"| Field Type | ||
+ | ! Notes | ||
+ | |- | ||
+ | | rowspan="6"| 0x71 | ||
+ | | rowspan="6"| Play | ||
+ | | rowspan="6"| Client | ||
+ | | colspan="2"| Entity ID | ||
+ | | colspan="2"| VarInt | ||
+ | | | ||
+ | |- | ||
+ | | colspan="2"| Number Of Properties | ||
+ | | colspan="2"| VarInt | ||
+ | | Number of elements in the following array. | ||
+ | |- | ||
+ | | rowspan="4"| Property | ||
+ | | {{change|Key|Id}} | ||
+ | | rowspan="4"| Array | ||
+ | | {{change|Identifier|VarInt Enum}} | ||
+ | | See below. | ||
+ | |- | ||
+ | | Value | ||
+ | | Double | ||
+ | | See below. | ||
+ | |- | ||
+ | | Number Of Modifiers | ||
+ | | VarInt | ||
+ | | Number of elements in the following array. | ||
+ | |- | ||
+ | | Modifiers | ||
+ | | Array of Modifier Data | ||
+ | | See {{Minecraft Wiki|Attribute#Modifiers}}. Modifier Data defined below. | ||
+ | |} | ||
+ | |||
+ | Known Key values (see also {{Minecraft Wiki|Attribute#Modifiers}}): | ||
+ | |||
+ | These changed between 24w03b and 24w13a, TODO: Update this | ||
+ | |||
+ | {| class="wikitable" | ||
+ | |- | ||
+ | ! Id | ||
+ | ! Key | ||
+ | ! Default | ||
+ | ! Min | ||
+ | ! Max | ||
+ | ! Label | ||
+ | |- | ||
+ | | 0 | ||
+ | | generic.armor | ||
+ | | 0.0 | ||
+ | | 0.0 | ||
+ | | 30.0 | ||
+ | | Armor. | ||
+ | |- | ||
+ | | 1 | ||
+ | | generic.armor_toughness | ||
+ | | 0.0 | ||
+ | | 0.0 | ||
+ | | 20.0 | ||
+ | | Armor Toughness. | ||
+ | |- | ||
+ | | 2 | ||
+ | | generic.attack_damage | ||
+ | | 2.0 | ||
+ | | 0.0 | ||
+ | | 2048.0 | ||
+ | | Attack Damage. | ||
+ | |- | ||
+ | | 3 | ||
+ | | generic.attack_knockback | ||
+ | | 0.0 | ||
+ | | 0.0 | ||
+ | | 5.0 | ||
+ | | Attack Knockback. | ||
+ | |- | ||
+ | | 4 | ||
+ | | generic.attack_speed | ||
+ | | 4.0 | ||
+ | | 0.0 | ||
+ | | 1024.0 | ||
+ | | Attack Speed. | ||
+ | |- {{added}} | ||
+ | | 5 | ||
+ | | generic.block_interaction_range | ||
+ | | 4.5 | ||
+ | | 0.0 | ||
+ | | 64.0 | ||
+ | | Block Interaction Range. | ||
+ | |- {{added}} | ||
+ | | 6 | ||
+ | | generic.entity_interaction_range | ||
+ | | 3.0 | ||
+ | | 0.0 | ||
+ | | 64.0 | ||
+ | | Entity Interaction Range. | ||
+ | |- | ||
+ | | 7 | ||
+ | | generic.flying_speed | ||
+ | | 0.4 | ||
+ | | 0.0 | ||
+ | | 1024.0 | ||
+ | | Flying Speed. | ||
+ | |- | ||
+ | | 8 | ||
+ | | generic.follow_range | ||
+ | | 32.0 | ||
+ | | 0.0 | ||
+ | | 2048.0 | ||
+ | | Follow Range. | ||
+ | |- | ||
+ | | 9 | ||
+ | | horse.jump_strength | ||
+ | | 0.7 | ||
+ | | 0.0 | ||
+ | | 2.0 | ||
+ | | Jump Strength. | ||
+ | |- | ||
+ | | 10 | ||
+ | | generic.knockback_resistance | ||
+ | | 0.0 | ||
+ | | 0.0 | ||
+ | | 1.0 | ||
+ | | Knockback Resistance. | ||
+ | |- | ||
+ | | 11 | ||
+ | | generic.luck | ||
+ | | 0.0 | ||
+ | | -1024.0 | ||
+ | | 1024.0 | ||
+ | | Luck. | ||
+ | |- | ||
+ | | 12 | ||
+ | | generic.max_absorption | ||
+ | | 0.0 | ||
+ | | 0.0 | ||
+ | | 2048.0 | ||
+ | | Max Absorption. | ||
+ | |- | ||
+ | | 13 | ||
+ | | generic.max_health | ||
+ | | 20.0 | ||
+ | | 1.0 | ||
+ | | 1024.0 | ||
+ | | Max Health. | ||
+ | |- | ||
+ | | 14 | ||
+ | | generic.movement_speed | ||
+ | | 0.7 | ||
+ | | 0.0 | ||
+ | | 1024.0 | ||
+ | | Movement Speed. | ||
+ | |- {{added}} | ||
+ | | 15 | ||
+ | | generic.scale | ||
+ | | 1.0 | ||
+ | | 0.0625 | ||
+ | | 16.0 | ||
+ | | Scale. | ||
+ | |- | ||
+ | | 16 | ||
+ | | zombie.spawn_reinforcements | ||
+ | | 0.0 | ||
+ | | 0.0 | ||
+ | | 1.0 | ||
+ | | Spawn Reinforcements Chance. | ||
+ | |- {{added}} | ||
+ | | 17 | ||
+ | | generic.step_height | ||
+ | | 0.6 | ||
+ | | 0.0 | ||
+ | | 10.0 | ||
+ | | Step Height. | ||
+ | |} | ||
+ | |||
+ | ''Modifier Data'' structure: | ||
+ | |||
+ | {| class="wikitable" | ||
+ | |- | ||
! Field Name | ! Field Name | ||
! Field Type | ! Field Type | ||
! Notes | ! Notes | ||
|- | |- | ||
− | | | + | | UUID |
− | + | | UUID | |
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | | | ||
| | | | ||
− | |- | + | |- |
− | | | + | | Amount |
− | | | + | | Double |
− | | | + | | May be positive or negative. |
+ | |- | ||
+ | | Operation | ||
+ | | Byte | ||
+ | | See below. | ||
|} | |} | ||
− | + | The operation controls how the base value of the modifier is changed. | |
− | + | * 0: Add/subtract amount | |
+ | * 1: Add/subtract amount percent of the current value | ||
+ | * 2: Multiply by amount percent | ||
− | + | All of the 0's are applied first, and then the 1's, and then the 2's. | |
− | + | ==== Entity Effect ==== | |
{| class="wikitable" | {| class="wikitable" | ||
Line 685: | Line 1,216: | ||
! Notes | ! Notes | ||
|- | |- | ||
− | |rowspan=" | + | | rowspan="7"| 0x72 |
− | |rowspan=" | + | | rowspan="7"| Play |
− | |rowspan=" | + | | rowspan="7"| Client |
− | | | + | | Entity ID |
− | | | + | | VarInt |
− | | | + | | |
+ | |- | ||
+ | | Effect ID | ||
+ | | VarInt | ||
+ | | See {{Minecraft Wiki|Status effect#Effect list|this table}}. | ||
+ | |- | ||
+ | | Amplifier | ||
+ | | Byte | ||
+ | | Notchian client displays effect level as Amplifier + 1. | ||
+ | |- | ||
+ | | Duration | ||
+ | | VarInt | ||
+ | | Duration in ticks. (-1 for infinite) | ||
+ | |- | ||
+ | | Flags | ||
+ | | Byte | ||
+ | | Bit field, see below. | ||
+ | |- {{removed}} | ||
+ | | Has Factor Data | ||
+ | | Boolean | ||
+ | | Used in DARKNESS effect | ||
+ | |- {{removed}} | ||
+ | | Factor Codec | ||
+ | | NBT Tag | ||
+ | | See below | ||
|} | |} | ||
+ | {{Need Info|What exact effect does the blend bit flag have on the client? What happens if it is used on effects besides DARKNESS?}} | ||
− | + | Within flags: | |
− | + | * 0x01: Is ambient - was the effect spawned from a beacon? All beacon-generated effects are ambient. Ambient effects use a different icon in the HUD (blue border rather than gray). If all effects on an entity are ambient, the [[Entity_metadata#Living Entity|"Is potion effect ambient" living metadata field]] should be set to true. Usually should not be enabled. | |
+ | * 0x02: Show particles - should all particles from this effect be hidden? Effects with particles hidden are not included in the calculation of the effect color, and are not rendered on the HUD (but are still rendered within the inventory). Usually should be enabled. | ||
+ | * 0x04: Show icon - should the icon be displayed on the client? Usually should be enabled. | ||
+ | * {{change||0x08: Blend - should the effect's hard-coded blending be applied? Currently only used in the DARKNESS effect to apply extra void fog and adjust the gamma value for lighting.}} | ||
− | + | {{change|Factor Data|}} | |
+ | {| class="wikitable" {{removed}} | ||
+ | !Name | ||
+ | !Type | ||
+ | !style="width: 250px;" colspan="2"| Notes | ||
+ | |- | ||
+ | | padding_duration | ||
+ | | TAG_INT | ||
+ | | | ||
+ | |- | ||
+ | | factor_start | ||
+ | | TAG_FLOAT | ||
+ | | | ||
+ | |- | ||
+ | | factor_target | ||
+ | | TAG_FLOAT | ||
+ | | | ||
+ | |- | ||
+ | | factor_current | ||
+ | | TAG_FLOAT | ||
+ | | | ||
+ | |- | ||
+ | | effect_changed_timestamp | ||
+ | | TAG_INT | ||
+ | |- | ||
+ | | factor_previous_frame | ||
+ | | TAG_FLOAT | ||
+ | |- | ||
+ | | had_effect_last_tick | ||
+ | | TAG_BOOLEAN | ||
+ | |} | ||
=== Serverbound === | === Serverbound === | ||
− | + | ==== Chat Command ==== | |
+ | |||
+ | {| class="wikitable" | ||
+ | ! Packet ID | ||
+ | ! State | ||
+ | ! Bound To | ||
+ | ! colspan="2"| Field Name | ||
+ | ! colspan="2"| Field Type | ||
+ | ! Notes | ||
+ | |- | ||
+ | | rowspan="8"| 0x04 | ||
+ | | rowspan="8"| Play | ||
+ | | rowspan="8"| Server | ||
+ | | colspan="2"| Command | ||
+ | | colspan="2"| {{Type|String}} (256) | ||
+ | | colspan="2"| The command typed by the client. | ||
+ | |- {{removed}} | ||
+ | | colspan="2"| Timestamp | ||
+ | | colspan="2"| {{Type|Long}} | ||
+ | | colspan="2"| The timestamp that the command was executed. | ||
+ | |- {{removed}} | ||
+ | | colspan="2"| Salt | ||
+ | | colspan="2"| {{Type|Long}} | ||
+ | | colspan="2"| The salt for the following argument signatures. | ||
+ | |- {{removed}} | ||
+ | | colspan="2"| Array length | ||
+ | | colspan="2"| {{Type|VarInt}} | ||
+ | | colspan="2"| Number of entries in the following array. The maximum length in Notchian server is 8. | ||
+ | |- {{removed}} | ||
+ | | rowspan="2"| Array of argument signatures | ||
+ | | Argument name | ||
+ | | rowspan="2"| {{Type|Array}} (8) | ||
+ | | {{Type|String}} (16) | ||
+ | | The name of the argument that is signed by the following signature. | ||
+ | |- {{removed}} | ||
+ | | Signature | ||
+ | | {{Type|Byte Array}} (256) | ||
+ | | The signature that verifies the argument. Always 256 bytes and is not length-prefixed. | ||
+ | |- {{removed}} | ||
+ | | colspan="2"| Message Count | ||
+ | | colspan="2"| {{Type|VarInt}} | ||
+ | | colspan="2"| | ||
+ | |- {{removed}} | ||
+ | | colspan="2"| Acknowledged | ||
+ | | colspan="2"| {{Type|Fixed BitSet}} (20) | ||
+ | | colspan="2"| | ||
+ | |} | ||
+ | |||
+ | |||
+ | ==== Signed Chat Command ==== | ||
+ | |||
+ | {| class="wikitable" {{added}} | ||
+ | ! Packet ID | ||
+ | ! State | ||
+ | ! Bound To | ||
+ | ! colspan="2"| Field Name | ||
+ | ! colspan="2"| Field Type | ||
+ | ! Notes | ||
+ | |- | ||
+ | | rowspan="8"| 0x05 | ||
+ | | rowspan="8"| Play | ||
+ | | rowspan="8"| Server | ||
+ | | colspan="2"| Command | ||
+ | | colspan="2"| String(256) | ||
+ | | The command typed by the client. | ||
+ | |- | ||
+ | | colspan="2"| Timestamp | ||
+ | | colspan="2"| Long | ||
+ | | The timestamp that the command was executed. Milliseconds since the Unix epoch. | ||
+ | |- | ||
+ | | colspan="2"| Salt | ||
+ | | colspan="2"| Long | ||
+ | | The salt for the following argument signatures. | ||
+ | |- | ||
+ | | colspan="2"| Argument Signature Count | ||
+ | | colspan="2"| VarInt | ||
+ | | Number of elements in the following array. The maximum length in Notchian server is 8. | ||
+ | |- | ||
+ | | rowspan="2"| Argument Signatures | ||
+ | | Name | ||
+ | | rowspan="2"| Array | ||
+ | | String(16) | ||
+ | | The name of the argument that is signed by the following signature. | ||
+ | |- | ||
+ | | Signature | ||
+ | | ByteArray(256) | ||
+ | | The signature that verifies the argument. Always 256 bytes and is not length-prefixed. | ||
+ | |- | ||
+ | | colspan="2"| Seen Messages Offset | ||
+ | | colspan="2"| VarInt | ||
+ | | | ||
+ | |- | ||
+ | | colspan="2"| Seen Messages Acknowledged | ||
+ | | colspan="2"| Fixed BitSet(20) | ||
+ | | | ||
+ | |} | ||
+ | |||
+ | ==== Cookie Response (play) ==== | ||
− | + | Response to a [[#Cookie_Request_(play)|Cookie Request (play)]] from the server. The Notchian server only accepts responses of up to 5 kiB in size. | |
− | === | + | {| class="wikitable" {{added}} |
+ | ! Packet ID | ||
+ | ! State | ||
+ | ! Bound To | ||
+ | ! colspan="2"| Field Name | ||
+ | ! colspan="2"| Field Type | ||
+ | ! Notes | ||
+ | |- | ||
+ | | rowspan="4"| 0x11 | ||
+ | | rowspan="4"| Play | ||
+ | | rowspan="4"| Server | ||
+ | | colspan="2"| Key | ||
+ | | colspan="2"| Identifier | ||
+ | | The identifier of the cookie. | ||
+ | |- | ||
+ | | colspan="2"| Has Payload | ||
+ | | colspan="2"| Boolean | ||
+ | | The payload is only present if the cookie exists on the client. | ||
+ | |- | ||
+ | | colspan="2"| Payload Length | ||
+ | | colspan="2"| Optional VarInt | ||
+ | | Length of the following byte array. | ||
+ | |- | ||
+ | | colspan="2"| Payload | ||
+ | | colspan="2"| Optional Byte Array (5120) | ||
+ | | The data of the cookie, if any. | ||
+ | |} | ||
− | + | ==== Debug Sample Subscription ==== | |
− | = | + | {| class="wikitable" {{added}} |
+ | ! Packet ID | ||
+ | ! State | ||
+ | ! Bound To | ||
+ | ! Field Name | ||
+ | ! Field Type | ||
+ | ! Notes | ||
+ | |- | ||
+ | | 0x13 | ||
+ | | Play | ||
+ | | Server | ||
+ | | Sample Type | ||
+ | | VarInt Enum | ||
+ | | The type of debug sample to subscribe to. Currently always 0 (TICK_TIME). | ||
+ | |} | ||
− | + | [[Category:Minecraft Modern]] |
Revision as of 19:57, 25 April 2024
This page documents the changes from the last stable Minecraft release (currently 1.20.4, protocol 765) to the current pre-release (currently 24w13a, protocol Snapshot 182). Note that this page contains bleeding-edge information that may not be completely or correctly documented.
One who wishes to commandeer the merging of this into Protocol when an update is made must be sure to respect any changes that may have occurred to the respective packets there.
Contents
Data types
No changes so far.
Packets
ID | Packet name | Documentation | |
---|---|---|---|
Handshake serverbound | |||
0x00 | Handshake | Current | Pre |
Login clientbound | |||
0x01 | Encryption Request | Current | Pre |
0x05 | Cookie Request (login) | Pre | |
Login serverbound | |||
0x04 | Cookie Response (login) | Pre | |
Configuration clientbound | |||
0x00 | Cookie Request (configuration) | Pre | |
Clientbound Plugin Message (configuration) | Current | (unchanged) | |
Disconnect (configuration) | Current | (unchanged) | |
Finish Configuration | Current | (unchanged) | |
Clientbound Keep Alive (configuration) | Current | (unchanged) | |
Ping (configuration) | Current | (unchanged) | |
0x06 | Reset Chat | Pre | |
Registry Data | Current | Pre | |
Remove Resource Pack (configuration) | Current | (unchanged) | |
Add Resource Pack (configuration) | Current | (unchanged) | |
0x0A | Store Cookie (configuration) | Pre | |
0x0B | Transfer (configuration) | Pre | |
Feature Flags | Current | (unchanged) | |
Update Tags (configuration) | Current | (unchanged) | |
0x0E | Clientbound Known Packs | Pre | |
Configuration serverbound | |||
0x01 | Cookie Response (configuration) | Pre | |
Serverbound Plugin Message (configuration) | Current | (unchanged) | |
Finish Configuration | Current | (unchanged) | |
Serverbound Keep Alive (configuration) | Current | (unchanged) | |
Pong (configuration) | Current | (unchanged) | |
Resource Pack Response (configuration) | Current | (unchanged) | |
0x07 | Serverbound Known Packs | Pre | |
Play clientbound | |||
0x16 | Cookie Request (Play) | Pre | |
Set Cooldown | Current | (unchanged) | |
Chat Suggestions | Current | (unchanged) | |
Clientbound Plugin Message (play) | Current | (unchanged) | |
Damage Event | Current | (unchanged) | |
0x1B | Debug Sample | Pre | |
Delete Message | Current | (unchanged) | |
Disconnect (play) | Current | (unchanged) | |
Disguised Chat Message | Current | (unchanged) | |
Entity Event | Current | (unchanged) | |
Explosion | Current | (unchanged) | |
Unload Chunk | Current | (unchanged) | |
Game Event | Current | (unchanged) | |
Open Horse Screen | Current | (unchanged) | |
Hurt Animation | Current | (unchanged) | |
Initialize World Border | Current | (unchanged) | |
Clientbound Keep Alive (play) | Current | (unchanged) | |
Chunk Data and Update Light | Current | (unchanged) | |
World Event | Current | (unchanged) | |
Particle | Current | (unchanged) | |
Update Light | Current | (unchanged) | |
Login (play) | Current | Pre | |
Map Data | Current | (unchanged) | |
Merchant Offers | Current | (unchanged) | |
Update Entity Position | Current | (unchanged) | |
Update Entity Position and Rotation | Current | (unchanged) | |
Update Entity Rotation | Current | (unchanged) | |
Move Vehicle | Current | (unchanged) | |
Open Book | Current | (unchanged) | |
Open Screen | Current | (unchanged) | |
Open Sign Editor | Current | (unchanged) | |
Ping (play) | Current | (unchanged) | |
Ping Response (play) | Current | (unchanged) | |
Place Ghost Recipe | Current | (unchanged) | |
Player Abilities | Current | (unchanged) | |
Player Chat Message | Current | (unchanged) | |
End Combat | Current | (unchanged) | |
Enter Combat | Current | (unchanged) | |
Combat Death | Current | (unchanged) | |
Player Info Remove | Current | (unchanged) | |
Player Info Update | Current | (unchanged) | |
Look At | Current | (unchanged) | |
Synchronize Player Position | Current | (unchanged) | |
Update Recipe Book | Current | (unchanged) | |
Remove Entities | Current | (unchanged) | |
Remove Entity Effect | Current | (unchanged) | |
Reset Score | Current | (unchanged) | |
Remove Resource Pack (play) | Current | (unchanged) | |
Add Resource Pack (play) | Current | (unchanged) | |
Respawn | Current | Pre | |
Set Head Rotation | Current | (unchanged) | |
Update Section Blocks | Current | (unchanged) | |
Select Advancements Tab | Current | (unchanged) | |
Server Data | Current | (unchanged) | |
Set Action Bar Text | Current | (unchanged) | |
Set Border Center | Current | (unchanged) | |
Set Border Lerp Size | Current | (unchanged) | |
Set Border Size | Current | (unchanged) | |
Set Border Warning Delay | Current | (unchanged) | |
Set Border Warning Distance | Current | (unchanged) | |
Set Camera | Current | (unchanged) | |
Set Held Item | Current | (unchanged) | |
Set Center Chunk | Current | (unchanged) | |
Set Render Distance | Current | (unchanged) | |
Set Default Spawn Position | Current | (unchanged) | |
Display Objective | Current | (unchanged) | |
Set Entity Metadata | Current | (unchanged) | |
Link Entities | Current | (unchanged) | |
Set Entity Velocity | Current | (unchanged) | |
Set Equipment | Current | (unchanged) | |
Set Experience | Current | (unchanged) | |
Set Health | Current | (unchanged) | |
Update Objectives | Current | (unchanged) | |
Set Passengers | Current | (unchanged) | |
Update Teams | Current | (unchanged) | |
Update Score | Current | (unchanged) | |
Set Simulation Distance | Current | (unchanged) | |
Set Subtitle Text | Current | (unchanged) | |
Update Time | Current | (unchanged) | |
Set Title Text | Current | (unchanged) | |
Set Title Animation Times | Current | (unchanged) | |
Entity Sound Effect | Current | (unchanged) | |
Sound Effect | Current | (unchanged) | |
Start Configuration | Current | (unchanged) | |
Stop Sound | Current | (unchanged) | |
0x6B | Store Cookie (Play) | Pre | |
System Chat Message | Current | (unchanged) | |
Set Tab List Header And Footer | Current | (unchanged) | |
Tag Query Response | Current | (unchanged) | |
Pickup Item | Current | (unchanged) | |
Teleport Entity | Current | (unchanged) | |
Set Ticking State | Current | (unchanged) | |
Step Tick | Current | (unchanged) | |
0x73 | Transfer (Play) | Pre | |
Update Advancements | Current | (unchanged) | |
Update Attributes | Current | Pre | |
Entity Effect | Current | Pre | |
Update Recipes | Current | (unchanged) | |
Update Tags (play) | Current | (unchanged) | |
Play serverbound | |||
0x04 | Chat Command | Current | Pre |
0x05 | Signed Chat Command | Pre | |
Chat Message | Current | (unchanged) | |
Player Session | Current | (unchanged) | |
Chunk Batch Received | Current | (unchanged) | |
Client Status | Current | (unchanged) | |
Client Information (play) | Current | (unchanged) | |
Command Suggestions Request | Current | (unchanged) | |
Acknowledge Configuration | Current | (unchanged) | |
Click Container Button | Current | (unchanged) | |
Click Container | Current | (unchanged) | |
Close Container | Current | (unchanged) | |
Change Container Slot State | Current | (unchanged) | |
0x11 | Cookie Response (play) | Pre | |
Serverbound Plugin Message (play) | Current | (unchanged) | |
0x13 | Debug Sample Subscription | Pre | |
Edit Book | Current | (unchanged) | |
Query Entity Tag | Current | (unchanged) | |
Interact | Current | (unchanged) | |
Jigsaw Generate | Current | (unchanged) | |
Serverbound Keep Alive (play) | Current | (unchanged) | |
Lock Difficulty | Current | (unchanged) | |
Set Player Position | Current | (unchanged) | |
Set Player Position and Rotation | Current | (unchanged) | |
Set Player Rotation | Current | (unchanged) | |
Set Player On Ground | Current | (unchanged) | |
Move Vehicle | Current | (unchanged) | |
Paddle Boat | Current | (unchanged) | |
Pick Item | Current | (unchanged) | |
Ping Request (play) | Current | (unchanged) | |
Place Recipe | Current | (unchanged) | |
Player Abilities | Current | (unchanged) | |
Player Action | Current | (unchanged) | |
Player Command | Current | (unchanged) | |
Player Input | Current | (unchanged) | |
Pong (play) | Current | (unchanged) | |
Change Recipe Book Settings | Current | (unchanged) | |
Set Seen Recipe | Current | (unchanged) | |
Rename Item | Current | (unchanged) | |
Resource Pack Response (play) | Current | (unchanged) | |
Seen Advancements | Current | (unchanged) | |
Select Trade | Current | (unchanged) | |
Set Beacon Effect | Current | (unchanged) | |
Set Held Item | Current | (unchanged) | |
Program Command Block | Current | (unchanged) | |
Program Command Block Minecart | Current | (unchanged) | |
Set Creative Mode Slot | Current | (unchanged) | |
Program Jigsaw Block | Current | (unchanged) | |
Program Structure Block | Current | (unchanged) | |
Update Sign | Current | (unchanged) | |
Swing Arm | Current | (unchanged) | |
Teleport To Entity | Current | (unchanged) | |
Use Item On | Current | (unchanged) | |
Use Item | Current | (unchanged) |
New/modified data types
No changes so far.
Entity Metadata
Type | Name | Value | Notes |
---|---|---|---|
0 | Byte | Byte | |
1 | VarInt | VarInt | |
2 | VarLong | VarLong | |
3 | Float | Float | |
4 | String | String | |
5 | Text Component | Text Component | |
6 | Optional Text Component | (Boolean, Optional Text Component) | Text Component is present if the Boolean is set to true. |
7 | Slot | Slot | |
8 | Boolean | Boolean | |
9 | Rotations | (Float, Float, Float) | rotation on x, rotation on y, rotation on z |
10 | Position | Position | |
11 | Optional Position | (Boolean, Optional Position) | Position is present if the Boolean is set to true. |
12 | Direction | VarInt Enum | Down = 0, Up = 1, North = 2, South = 3, West = 4, East = 5 |
13 | Optional UUID | (Boolean, Optional UUID) | UUID is present if the Boolean is set to true. |
14 | Block State | VarInt | An ID in the block state registry. |
15 | Optional Block State | VarInt | 0 for absent (air is unrepresentable); otherwise, an ID in the block state registry. |
16 | NBT | NBT | |
17 | Particle | (VarInt, Varies) | particle type (an ID in the minecraft:particle_type registry), particle data (See Particles.)
|
18 | Particles | (VarInt, Array of Particle) | length of array, particle data (See directly above.) |
Villager Data | (VarInt, VarInt, VarInt) | villager type, villager profession, level (See below.) | |
Optional VarInt | VarInt | 0 for absent; 1 + actual value otherwise. Used for entity IDs. | |
Pose | VarInt Enum | STANDING = 0, FALL_FLYING = 1, SLEEPING = 2, SWIMMING = 3, SPIN_ATTACK = 4, SNEAKING = 5, LONG_JUMPING = 6, DYING = 7, CROAKING = 8, USING_TONGUE = 9, SITTING = 10, ROARING = 11, SNIFFING = 12, EMERGING = 13, DIGGING = 14, SLIDING = 15, SHOOTING = 16, INHALING = 17 | |
Cat Variant | VarInt | An ID in the minecraft:cat_variant registry.
| |
Wolf Variant | VarInt | An ID in the minecraft:wolf_variant registry.
| |
Frog Variant | VarInt | An ID in the minecraft:frog_variant registry.
| |
Optional Global Position | (Boolean, Optional Identifier, Optional Position) | dimension identifier, position; only if the Boolean is set to true. | |
Painting Variant | VarInt | An ID in the minecraft:painting_variant registry.
| |
Sniffer State | VarInt Enum | IDLING = 0, FEELING_HAPPY = 1, SCENTING = 2, SNIFFING = 3, SEARCHING = 4, DIGGING = 5, RISING = 6 | |
Armadillo State | VarInt Enum | IDLE = 0, ROLLING = 1, SCARED = 2 | |
Vector3 | (Float, Float, Float) | x, y, z | |
Quaternion | (Float, Float, Float, Float) | x, y, z, w |
Living Entity
TODO: This has changed to use the PARTICLES attribute
Wolf
Extends Tameable Animal.Inherited entity Tameable Animal does not existInherited entity Tameable Animal does not exist
Index | Type | Meaning | Default | |
---|---|---|---|---|
0 | Wolf Variant ( |
Wolf Variant | PALE | |
1 | Boolean (8) | Is begging | false | |
2 | VarInt (1) | Collar color (values are those used with dyes) | 14 (Red) | |
3 | VarInt (1) | Anger time | 0 |
Armadillo
Extends Animal.
Index | Type | Meaning | Default | |
---|---|---|---|---|
17 | Armadillo State ( |
Armadillo State | IDLE |
Block Actions
No changes so far.
Inventories
No changes so far.
Plugin Channels
No changes so far.
Handshake
Serverbound
Handshake
This causes the server to switch into the target state.
Packet ID | State | Bound To | Field Name | Field Type | Notes |
---|---|---|---|---|---|
0x00 | Handshaking | Server | Protocol Version | VarInt | See protocol version numbers (currently 765 in Minecraft 1.20.4). |
Server Address | String (255) | Hostname or IP, e.g. localhost or 127.0.0.1, that was used to connect. The Notchian server does not use this information. Note that SRV records are a simple redirect, e.g. if _minecraft._tcp.example.com points to mc.example.org, users connecting to example.com will provide example.org as server address in addition to connecting to it. | |||
Server Port | Unsigned Short | Default is 25565. The Notchian server does not use this information. | |||
Next State | VarInt Enum | 1 for Status, 2 for Login, 3 for Transfer. |
Status
Clientbound
No changes so far.
Serverbound
No changes so far.
Login
Clientbound
Encryption Request
Packet ID | State | Bound To | Field Name | Field Type | Notes |
---|---|---|---|---|---|
0x01 | Login | Client | Server ID | String (20) | Appears to be empty. |
Public Key Length | VarInt | Length of Public Key. | |||
Public Key | Byte Array | The server's public key, in bytes. | |||
Verify Token Length | VarInt | Length of Verify Token. Always 4 for Notchian servers. | |||
Verify Token | Byte Array | A sequence of random bytes generated by the server. | |||
Should Authenticate | Boolean |
Cookie Request (login)
Requests a cookie that was previously stored.
Packet ID | State | Bound To | Field Name | Field Type | Notes | ||
---|---|---|---|---|---|---|---|
0x05 | Login | Client | Key | Identifier | The identifier of the cookie. |
Serverbound
Cookie Response (login)
Response to a Cookie Request (login) from the server. The Notchian server only accepts responses of up to 5 kiB in size.
Packet ID | State | Bound To | Field Name | Field Type | Notes | ||
---|---|---|---|---|---|---|---|
0x04 | Login | Server | Key | Identifier | The identifier of the cookie. | ||
Has Payload | Boolean | The payload is only present if the cookie exists on the client. | |||||
Payload Length | VarInt | Length of the following byte array. | |||||
Payload | Optional Byte Array (5120) | The data of the cookie, if any. |
Configuration
Clientbound
Cookie Request (configuration)
Requests a cookie that was previously stored.
Packet ID | State | Bound To | Field Name | Field Type | Notes | ||
---|---|---|---|---|---|---|---|
0x00 | Configuration | Client | Key | Identifier | The identifier of the cookie. |
Reset Chat
Packet ID | State | Bound To | Field Name | Field Type | Notes |
---|---|---|---|---|---|
0x06 | Configuration | Client | no fields |
Registry Data
Represents certain registries that are sent from the server and are applied on the client. The packet is sent for each of the following registries: minecraft:worldgen/biome
, minecraft:chat_type
, minecraft:trim_pattern
, minecraft:trim_material
, minecraft:wolf_variant
, minecraft:dimension_type
, minecraft:damage_type
, and minecraft:banner_pattern
.
Packet ID | State | Bound To | Field Name | Field Type | Notes | ||
---|---|---|---|---|---|---|---|
0x07 | Configuration | Client | Registry Codec | NBT (Compound) | See Registry Data. | ||
Registry ID | Identifier | ||||||
Entry Count | VarInt | Number of entries in the following array. | |||||
Entries | Entry ID | Array | Identifier | ||||
Has Data | Boolean | Whether the entry has any data following. | |||||
Data | NBT Tag | Entry data. Only present if Has Data is true. |
Store Cookie (configuration)
Stores some arbitrary data on the client, which persists between server transfers. The Notchian client only accepts cookies of up to 5 kiB in size.
Packet ID | State | Bound To | Field Name | Field Type | Notes | ||
---|---|---|---|---|---|---|---|
0x0A | Configuration | Client | Key | Identifier | The identifier of the cookie. | ||
Payload | ByteArray(5120) | The data of the cookie. |
Transfer (configuration)
Notifies the client that it should transfer to the given server. Cookies previously stored are preserved between server transfers.
Packet ID | State | Bound To | Field Name | Field Type | Notes | ||
---|---|---|---|---|---|---|---|
0x0B | Configuration | Client | Host | String | The hostname of IP of the server. | ||
Port | VarInt | The port of the server. |
Clientbound Known Packs
Informs the client of which data packs are present on the server. The client is expected to respond with its own Serverbown Known Packs packet. The Notchian server does not continue with Configuration until it receives a response.
Packet ID | State | Bound To | Field Name | Field Type | Notes | ||
---|---|---|---|---|---|---|---|
0x0E | Configuration | Client | Known Pack Count | VarInt | The number of known packs in the following array. | ||
Known Packs | Namespace | Array | String | ||||
ID | String | ||||||
Version | String |
Serverbound
Cookie Response (configuration)
Response to a Cookie Request (configuration) from the server. The Notchian server only accepts responses of up to 5 kiB in size.
Packet ID | State | Bound To | Field Name | Field Type | Notes | ||
---|---|---|---|---|---|---|---|
0x01 | Configuration | Server | Key | Identifier | The identifier of the cookie. | ||
Has Payload | Boolean | The payload is only present if the cookie exists on the client. | |||||
Payload Length | VarInt | Length of the following byte array. | |||||
Payload | Optional Byte Array (5120) | The data of the cookie, if any. |
Serverbound Known Packs
ID 0x07, same structure as Clientbound Known Packs. If the client specifies a pack in this packet, the server should omit its contained data from Registry Data.
Play
Clientbound
Cookie Request (play)
Requests a cookie that was previously stored.
Packet ID | State | Bound To | Field Name | Field Type | Notes | ||
---|---|---|---|---|---|---|---|
0x16 | Play | Client | Key | Identifier | The identifier of the cookie. |
Debug Sample
Packet ID | State | Bound To | Field Name | Field Type | Notes |
---|---|---|---|---|---|
0x1B | Play | Client | Sample Length | VarInt | The length of the following array. |
Sample | Long Array | TODO: What is the structure of the data in this array? | |||
Sample Type | VarInt Enum | The type of sample data. Currently always 0 (TICK_TIME). |
Login (play)
Packet ID | State | Bound To | Field Name | Field Type | Notes |
---|---|---|---|---|---|
0x2B | Play | Client | Entity ID | Int | The player's Entity ID (EID). |
Is hardcore | Boolean | ||||
Dimension Count | VarInt | Size of the following array. | |||
Dimension Names | Array of Identifier | Identifiers for all dimensions on the server. | |||
Max Players | VarInt | Was once used by the client to draw the player list, but now is ignored. | |||
View Distance | VarInt | Render distance (2-32). | |||
Simulation Distance | VarInt | The distance that the client will process specific things, such as entities. | |||
Reduced Debug Info | Boolean | If true, a Notchian client shows reduced information on the debug screen. For servers in development, this should almost always be false. | |||
Enable respawn screen | Boolean | Set to false when the doImmediateRespawn gamerule is true. | |||
Do limited crafting | Boolean | Whether players can only craft recipes they have already unlocked. Currently unused by the client. | |||
Dimension Type | The ID of the type of dimension in the minecraft:dimension_type registry, defined by the Registry Data packet.
| ||||
Dimension Name | Identifier | Name of the dimension being spawned into. | |||
Hashed seed | Long | First 8 bytes of the SHA-256 hash of the world's seed. Used client side for biome noise | |||
Game mode | Unsigned Byte | 0: Survival, 1: Creative, 2: Adventure, 3: Spectator. | |||
Previous Game mode | Byte | -1: Undefined (null), 0: Survival, 1: Creative, 2: Adventure, 3: Spectator. The previous game mode. Vanilla client uses this for the debug (F3 + N & F3 + F4) game mode switch. (More information needed) | |||
Is Debug | Boolean | True if the world is a debug mode world; debug mode worlds cannot be modified and have predefined blocks. | |||
Is Flat | Boolean | True if the world is a superflat world; flat worlds have different void fog and a horizon at y=0 instead of y=63. | |||
Has death location | Boolean | If true, then the next two fields are present. | |||
Death dimension name | Optional Identifier | Name of the dimension the player died in. | |||
Death location | Optional Position | The location that the player died at. | |||
Portal cooldown | VarInt | The number of ticks until the player can use the portal again. | |||
Enforces Secure Chat | Boolean |
Respawn
Packet ID | State | Bound To | Field Name | Field Type | Notes |
---|---|---|---|---|---|
0x47 | Play | Client | Dimension Type | The ID of the type of dimension in the minecraft:dimension_type registry, defined by the Registry Data packet.
| |
Dimension Name | Identifier | Name of the dimension being spawned into. | |||
Hashed seed | Long | First 8 bytes of the SHA-256 hash of the world's seed. Used client side for biome noise | |||
Game mode | Unsigned Byte | 0: Survival, 1: Creative, 2: Adventure, 3: Spectator. | |||
Previous Game mode | Byte | -1: Undefined (null), 0: Survival, 1: Creative, 2: Adventure, 3: Spectator. The previous game mode. Vanilla client uses this for the debug (F3 + N & F3 + F4) game mode switch. (More information needed) | |||
Is Debug | Boolean | True if the world is a debug mode world; debug mode worlds cannot be modified and have predefined blocks. | |||
Is Flat | Boolean | True if the world is a superflat world; flat worlds have different void fog and a horizon at y=0 instead of y=63. | |||
Has death location | Boolean | If true, then the next two fields are present. | |||
Death dimension Name | Optional Identifier | Name of the dimension the player died in. | |||
Death location | Optional Position | The location that the player died at. | |||
Portal cooldown | VarInt | The number of ticks until the player can use the portal again. | |||
Data kept | Byte | Bit mask. 0x01: Keep attributes, 0x02: Keep metadata. Tells which data should be kept on the client side once the player has respawned.
In the Notchian implementation, this is context dependent:
|
Store Cookie (play)
Stores some arbitrary data on the client, which persists between server transfers. The Notchian client only accepts cookies of up to 5 kiB in size.
Packet ID | State | Bound To | Field Name | Field Type | Notes | ||
---|---|---|---|---|---|---|---|
0x6B | Play | Client | Key | Identifier | The identifier of the cookie. | ||
Payload Length | VarInt | Length of the following byte array. | |||||
Payload | Byte Array (5120) | The data of the cookie. |
Transfer (play)
Notifies the client that it should transfer to the given server. Cookies previously stored are preserved between server transfers.
Packet ID | State | Bound To | Field Name | Field Type | Notes | ||
---|---|---|---|---|---|---|---|
0x73 | Play | Client | Host | String | The hostname of IP of the server. | ||
Port | VarInt | The port of the server. |
Update Attributes
Sets attributes on the given entity.
Packet ID | State | Bound To | Field Name | Field Type | Notes | ||
---|---|---|---|---|---|---|---|
0x71 | Play | Client | Entity ID | VarInt | |||
Number Of Properties | VarInt | Number of elements in the following array. | |||||
Property | Array | See below. | |||||
Value | Double | See below. | |||||
Number Of Modifiers | VarInt | Number of elements in the following array. | |||||
Modifiers | Array of Modifier Data | See Attribute#Modifiers. Modifier Data defined below. |
Known Key values (see also Attribute#Modifiers):
These changed between 24w03b and 24w13a, TODO: Update this
Id | Key | Default | Min | Max | Label |
---|---|---|---|---|---|
0 | generic.armor | 0.0 | 0.0 | 30.0 | Armor. |
1 | generic.armor_toughness | 0.0 | 0.0 | 20.0 | Armor Toughness. |
2 | generic.attack_damage | 2.0 | 0.0 | 2048.0 | Attack Damage. |
3 | generic.attack_knockback | 0.0 | 0.0 | 5.0 | Attack Knockback. |
4 | generic.attack_speed | 4.0 | 0.0 | 1024.0 | Attack Speed. |
5 | generic.block_interaction_range | 4.5 | 0.0 | 64.0 | Block Interaction Range. |
6 | generic.entity_interaction_range | 3.0 | 0.0 | 64.0 | Entity Interaction Range. |
7 | generic.flying_speed | 0.4 | 0.0 | 1024.0 | Flying Speed. |
8 | generic.follow_range | 32.0 | 0.0 | 2048.0 | Follow Range. |
9 | horse.jump_strength | 0.7 | 0.0 | 2.0 | Jump Strength. |
10 | generic.knockback_resistance | 0.0 | 0.0 | 1.0 | Knockback Resistance. |
11 | generic.luck | 0.0 | -1024.0 | 1024.0 | Luck. |
12 | generic.max_absorption | 0.0 | 0.0 | 2048.0 | Max Absorption. |
13 | generic.max_health | 20.0 | 1.0 | 1024.0 | Max Health. |
14 | generic.movement_speed | 0.7 | 0.0 | 1024.0 | Movement Speed. |
15 | generic.scale | 1.0 | 0.0625 | 16.0 | Scale. |
16 | zombie.spawn_reinforcements | 0.0 | 0.0 | 1.0 | Spawn Reinforcements Chance. |
17 | generic.step_height | 0.6 | 0.0 | 10.0 | Step Height. |
Modifier Data structure:
Field Name | Field Type | Notes |
---|---|---|
UUID | UUID | |
Amount | Double | May be positive or negative. |
Operation | Byte | See below. |
The operation controls how the base value of the modifier is changed.
- 0: Add/subtract amount
- 1: Add/subtract amount percent of the current value
- 2: Multiply by amount percent
All of the 0's are applied first, and then the 1's, and then the 2's.
Entity Effect
Packet ID | State | Bound To | Field Name | Field Type | Notes |
---|---|---|---|---|---|
0x72 | Play | Client | Entity ID | VarInt | |
Effect ID | VarInt | See this table. | |||
Amplifier | Byte | Notchian client displays effect level as Amplifier + 1. | |||
Duration | VarInt | Duration in ticks. (-1 for infinite) | |||
Flags | Byte | Bit field, see below. | |||
Has Factor Data | Boolean | Used in DARKNESS effect | |||
Factor Codec | NBT Tag | See below |
The following information needs to be added to this page: | |
What exact effect does the blend bit flag have on the client? What happens if it is used on effects besides DARKNESS? |
Within flags:
- 0x01: Is ambient - was the effect spawned from a beacon? All beacon-generated effects are ambient. Ambient effects use a different icon in the HUD (blue border rather than gray). If all effects on an entity are ambient, the "Is potion effect ambient" living metadata field should be set to true. Usually should not be enabled.
- 0x02: Show particles - should all particles from this effect be hidden? Effects with particles hidden are not included in the calculation of the effect color, and are not rendered on the HUD (but are still rendered within the inventory). Usually should be enabled.
- 0x04: Show icon - should the icon be displayed on the client? Usually should be enabled.
- 0x08: Blend - should the effect's hard-coded blending be applied? Currently only used in the DARKNESS effect to apply extra void fog and adjust the gamma value for lighting.
Factor Data
Name | Type | Notes | |
---|---|---|---|
padding_duration | TAG_INT | ||
factor_start | TAG_FLOAT | ||
factor_target | TAG_FLOAT | ||
factor_current | TAG_FLOAT | ||
effect_changed_timestamp | TAG_INT | ||
factor_previous_frame | TAG_FLOAT | ||
had_effect_last_tick | TAG_BOOLEAN |
Serverbound
Chat Command
Packet ID | State | Bound To | Field Name | Field Type | Notes | |||
---|---|---|---|---|---|---|---|---|
0x04 | Play | Server | Command | String (256) | The command typed by the client. | |||
Timestamp | Long | The timestamp that the command was executed. | ||||||
Salt | Long | The salt for the following argument signatures. | ||||||
Array length | VarInt | Number of entries in the following array. The maximum length in Notchian server is 8. | ||||||
Array of argument signatures | Argument name | Array (8) | String (16) | The name of the argument that is signed by the following signature. | ||||
Signature | Byte Array (256) | The signature that verifies the argument. Always 256 bytes and is not length-prefixed. | ||||||
Message Count | VarInt | |||||||
Acknowledged | Fixed BitSet (20) |
Signed Chat Command
Packet ID | State | Bound To | Field Name | Field Type | Notes | ||
---|---|---|---|---|---|---|---|
0x05 | Play | Server | Command | String(256) | The command typed by the client. | ||
Timestamp | Long | The timestamp that the command was executed. Milliseconds since the Unix epoch. | |||||
Salt | Long | The salt for the following argument signatures. | |||||
Argument Signature Count | VarInt | Number of elements in the following array. The maximum length in Notchian server is 8. | |||||
Argument Signatures | Name | Array | String(16) | The name of the argument that is signed by the following signature. | |||
Signature | ByteArray(256) | The signature that verifies the argument. Always 256 bytes and is not length-prefixed. | |||||
Seen Messages Offset | VarInt | ||||||
Seen Messages Acknowledged | Fixed BitSet(20) |
Cookie Response (play)
Response to a Cookie Request (play) from the server. The Notchian server only accepts responses of up to 5 kiB in size.
Packet ID | State | Bound To | Field Name | Field Type | Notes | ||
---|---|---|---|---|---|---|---|
0x11 | Play | Server | Key | Identifier | The identifier of the cookie. | ||
Has Payload | Boolean | The payload is only present if the cookie exists on the client. | |||||
Payload Length | Optional VarInt | Length of the following byte array. | |||||
Payload | Optional Byte Array (5120) | The data of the cookie, if any. |
Debug Sample Subscription
Packet ID | State | Bound To | Field Name | Field Type | Notes |
---|---|---|---|---|---|
0x13 | Play | Server | Sample Type | VarInt Enum | The type of debug sample to subscribe to. Currently always 0 (TICK_TIME). |