3 Copyright (C) 2010 celeron55, Perttu Ahola <celeron55@gmail.com>
5 This program is free software; you can redistribute it and/or modify
6 it under the terms of the GNU Lesser General Public License as published by
7 the Free Software Foundation; either version 2.1 of the License, or
8 (at your option) any later version.
10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 GNU Lesser General Public License for more details.
15 You should have received a copy of the GNU Lesser General Public License along
16 with this program; if not, write to the Free Software Foundation, Inc.,
17 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
20 #ifndef CLIENTSERVER_HEADER
21 #define CLIENTSERVER_HEADER
23 #include "util/serialize.h"
26 changes by PROTOCOL_VERSION:
29 Base for writing changes here
34 Add TOCLIENT_CRAFTITEMDEF
36 Obsolete TOSERVER_CLICK_ACTIVEOBJECT
37 Obsolete TOSERVER_GROUND_ACTION
39 Make players to be handled mostly as ActiveObjects
41 Only non-cached textures are sent
44 Obsolete TOCLIENT_TOOLDEF
45 Obsolete TOCLIENT_CRAFTITEMDEF
46 Compress the contents of TOCLIENT_ITEMDEF and TOCLIENT_NODEDEF
48 Digging based on item groups
51 ContentFeatures and NodeDefManager use a different serialization
52 format; better for future version cross-compatibility
56 Version raised to force 'fly' and 'fast' privileges into effect.
57 Node metadata change (came in later; somewhat incompatible)
59 TileDef in ContentFeatures
62 TOCLIENT_INVENTORY_FORMSPEC
65 TOSERVER_INVENTORY_FIELDS
67 TOCLIENT_DETACHED_INVENTORY
69 InventoryList field "Width" (deserialization fails with old versions)
71 New messages for mesh and bone animation, as well as attachments
72 GENERIC_CMD_SET_ANIMATION
73 GENERIC_CMD_SET_BONE_POSITION
74 GENERIC_CMD_SET_ATTACHMENT
77 #define PROTOCOL_VERSION 14
79 #define PROTOCOL_ID 0x4f457403
81 #define PASSWORD_SIZE 28 // Maximum password length. Allows for
82 // base64-encoded SHA-1 (27+\0).
84 #define TEXTURENAME_ALLOWED_CHARS "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789_."
90 Server's reply to TOSERVER_INIT.
91 Sent second after connected.
94 [2] u8 deployed version
95 [3] v3s16 player's position + v3f(0,BS/2,0) floatToInt'd
96 [12] u64 map seed (new as of 2011-02-27)
98 NOTE: The position in here is deprecated; position is
99 explicitly sent afterwards
102 TOCLIENT_BLOCKDATA = 0x20, //TODO: Multiple blocks
103 TOCLIENT_ADDNODE = 0x21,
104 TOCLIENT_REMOVENODE = 0x22,
106 TOCLIENT_PLAYERPOS = 0x23, // Obsolete
109 // Followed by an arbitary number of these:
110 // Number is determined from packet length.
112 [N+2] v3s32 position*100
113 [N+2+12] v3s32 speed*100
114 [N+2+12+12] s32 pitch*100
115 [N+2+12+12+4] s32 yaw*100
118 TOCLIENT_PLAYERINFO = 0x24, // Obsolete
121 // Followed by an arbitary number of these:
122 // Number is determined from packet length.
127 TOCLIENT_OPT_BLOCK_NOT_FOUND = 0x25, // Obsolete
129 TOCLIENT_SECTORMETA = 0x26, // Obsolete
133 [3...] v2s16 pos + sector metadata
136 TOCLIENT_INVENTORY = 0x27,
139 [2] serialized inventory
142 TOCLIENT_OBJECTDATA = 0x28, // Obsolete
147 u16 number of player positions
160 TOCLIENT_TIME_OF_DAY = 0x29,
164 Added in a later version:
168 // (oops, there is some gap here)
170 TOCLIENT_CHAT_MESSAGE = 0x30,
177 TOCLIENT_ACTIVE_OBJECT_REMOVE_ADD = 0x31,
180 u16 count of removed objects
181 for all removed objects {
184 u16 count of added objects
185 for all added objects {
188 u32 initialization data length
189 string initialization data
193 TOCLIENT_ACTIVE_OBJECT_MESSAGES = 0x32,
210 TOCLIENT_MOVE_PLAYER = 0x34,
213 v3f1000 player position
218 TOCLIENT_ACCESS_DENIED = 0x35,
225 TOCLIENT_PLAYERITEM = 0x36, // Obsolete
228 u16 count of player items
229 for all player items {
231 u16 length of serialized item
232 string serialized item
236 TOCLIENT_DEATHSCREEN = 0x37,
239 u8 bool set camera point target
240 v3f1000 camera point target (to point the death cause or whatever)
243 TOCLIENT_MEDIA = 0x38,
246 u16 total number of texture bunches
247 u16 index of this bunch
248 u32 number of files in this bunch
257 TOCLIENT_TOOLDEF = 0x39,
260 u32 length of the next item
261 serialized ToolDefManager
264 TOCLIENT_NODEDEF = 0x3a,
267 u32 length of the next item
268 serialized NodeDefManager
271 TOCLIENT_CRAFTITEMDEF = 0x3b,
274 u32 length of the next item
275 serialized CraftiItemDefManager
278 TOCLIENT_ANNOUNCE_MEDIA = 0x3c,
286 u16 length of sha1_digest
291 TOCLIENT_ITEMDEF = 0x3d,
294 u32 length of next item
295 serialized ItemDefManager
298 TOCLIENT_PLAY_SOUND = 0x3f,
305 u8 type (0=local, 1=positional, 2=object)
306 s32[3] pos_nodes*10000
311 TOCLIENT_STOP_SOUND = 0x40,
317 TOCLIENT_PRIVILEGES = 0x41,
320 u16 number of privileges
326 TOCLIENT_INVENTORY_FORMSPEC = 0x42,
333 TOCLIENT_DETACHED_INVENTORY = 0x43,
338 [2] serialized inventory
346 Sent first after connected.
348 [0] u16 TOSERVER_INIT
349 [2] u8 SER_FMT_VER_HIGHEST
350 [3] u8[20] player_name
351 [23] u8[28] password (new in some version)
352 [51] u16 client network protocol version (new in some version)
355 TOSERVER_INIT2 = 0x11,
357 Sent as an ACK for TOCLIENT_INIT.
358 After this, the server can send data.
360 [0] u16 TOSERVER_INIT2
363 TOSERVER_GETBLOCK=0x20, // Obsolete
364 TOSERVER_ADDNODE = 0x21, // Obsolete
365 TOSERVER_REMOVENODE = 0x22, // Obsolete
367 TOSERVER_PLAYERPOS = 0x23,
370 [2] v3s32 position*100
371 [2+12] v3s32 speed*100
372 [2+12+12] s32 pitch*100
373 [2+12+12+4] s32 yaw*100
376 TOSERVER_GOTBLOCKS = 0x24,
385 TOSERVER_DELETEDBLOCKS = 0x25,
394 TOSERVER_ADDNODE_FROM_INVENTORY = 0x26, // Obsolete
401 TOSERVER_CLICK_OBJECT = 0x27, // Obsolete
405 [2] u8 button (0=left, 1=right)
411 TOSERVER_GROUND_ACTION = 0x28, // Obsolete
416 [3] v3s16 nodepos_undersurface
417 [9] v3s16 nodepos_abovesurface
420 0: start digging (from undersurface)
421 1: place block (to abovesurface)
422 2: stop digging (all parameters ignored)
426 TOSERVER_RELEASE = 0x29, // Obsolete
428 // (oops, there is some gap here)
430 TOSERVER_SIGNTEXT = 0x30, // Old signs, obsolete
439 TOSERVER_INVENTORY_ACTION = 0x31,
441 See InventoryAction in inventory.h
444 TOSERVER_CHAT_MESSAGE = 0x32,
451 TOSERVER_SIGNNODETEXT = 0x33, // obsolete
459 TOSERVER_CLICK_ACTIVEOBJECT = 0x34, // Obsolete
463 [2] u8 button (0=left, 1=right)
468 TOSERVER_DAMAGE = 0x35,
474 TOSERVER_PASSWORD=0x36,
476 Sent to change password.
478 [0] u16 TOSERVER_PASSWORD
479 [2] u8[28] old password
480 [30] u8[28] new password
483 TOSERVER_PLAYERITEM=0x37,
485 Sent to change selected item.
487 [0] u16 TOSERVER_PLAYERITEM
491 TOSERVER_RESPAWN=0x38,
496 TOSERVER_INTERACT = 0x39,
501 [5] u32 length of the next item
502 [9] serialized PointedThing
504 0: start digging (from undersurface) or use
505 1: stop digging (all parameters ignored)
507 3: place block or item (to abovesurface)
510 (Obsoletes TOSERVER_GROUND_ACTION and TOSERVER_CLICK_ACTIVEOBJECT.)
513 TOSERVER_REMOVED_SOUNDS = 0x3a,
520 TOSERVER_NODEMETA_FIELDS = 0x3b,
525 u8[len] form name (reserved for future use)
534 TOSERVER_INVENTORY_FIELDS = 0x3c,
538 u8[len] form name (reserved for future use)
547 TOSERVER_REQUEST_MEDIA = 0x40,
550 u16 number of files requested
559 inline SharedBuffer<u8> makePacket_TOCLIENT_TIME_OF_DAY(u16 time, float time_speed)
561 SharedBuffer<u8> data(2+2+4);
562 writeU16(&data[0], TOCLIENT_TIME_OF_DAY);
563 writeU16(&data[2], time);
564 writeF1000(&data[4], time_speed);