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 General Public License as published by
7 the Free Software Foundation; either version 2 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 General Public License for more details.
15 You should have received a copy of the GNU 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
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 #define PROTOCOL_VERSION 6
46 #define PROTOCOL_ID 0x4f457403
48 #define PASSWORD_SIZE 28 // Maximum password length. Allows for
49 // base64-encoded SHA-1 (27+\0).
51 #define TEXTURENAME_ALLOWED_CHARS "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789_."
57 Server's reply to TOSERVER_INIT.
58 Sent second after connected.
61 [2] u8 deployed version
62 [3] v3s16 player's position + v3f(0,BS/2,0) floatToInt'd
63 [12] u64 map seed (new as of 2011-02-27)
65 NOTE: The position in here is deprecated; position is
66 explicitly sent afterwards
69 TOCLIENT_BLOCKDATA = 0x20, //TODO: Multiple blocks
70 TOCLIENT_ADDNODE = 0x21,
71 TOCLIENT_REMOVENODE = 0x22,
73 TOCLIENT_PLAYERPOS = 0x23, // Obsolete
76 // Followed by an arbitary number of these:
77 // Number is determined from packet length.
79 [N+2] v3s32 position*100
80 [N+2+12] v3s32 speed*100
81 [N+2+12+12] s32 pitch*100
82 [N+2+12+12+4] s32 yaw*100
85 TOCLIENT_PLAYERINFO = 0x24, // Obsolete
88 // Followed by an arbitary number of these:
89 // Number is determined from packet length.
94 TOCLIENT_OPT_BLOCK_NOT_FOUND = 0x25, // Obsolete
96 TOCLIENT_SECTORMETA = 0x26, // Obsolete
100 [3...] v2s16 pos + sector metadata
103 TOCLIENT_INVENTORY = 0x27,
106 [2] serialized inventory
109 TOCLIENT_OBJECTDATA = 0x28, // Obsolete
114 u16 number of player positions
127 TOCLIENT_TIME_OF_DAY = 0x29,
133 // (oops, there is some gap here)
135 TOCLIENT_CHAT_MESSAGE = 0x30,
142 TOCLIENT_ACTIVE_OBJECT_REMOVE_ADD = 0x31,
145 u16 count of removed objects
146 for all removed objects {
149 u16 count of added objects
150 for all added objects {
153 u32 initialization data length
154 string initialization data
158 TOCLIENT_ACTIVE_OBJECT_MESSAGES = 0x32,
175 TOCLIENT_MOVE_PLAYER = 0x34,
178 v3f1000 player position
183 TOCLIENT_ACCESS_DENIED = 0x35,
190 TOCLIENT_PLAYERITEM = 0x36,
193 u16 count of player items
194 for all player items {
196 u16 length of serialized item
197 string serialized item
201 TOCLIENT_DEATHSCREEN = 0x37,
204 u8 bool set camera point target
205 v3f1000 camera point target (to point the death cause or whatever)
208 TOCLIENT_TEXTURES = 0x38,
211 u16 total number of texture bunches
212 u16 index of this bunch
213 u32 number of textures in this bunch
222 TOCLIENT_TOOLDEF = 0x39,
225 u32 length of the next item
226 serialized ToolDefManager
229 TOCLIENT_NODEDEF = 0x3a,
232 u32 length of the next item
233 serialized NodeDefManager
236 TOCLIENT_CRAFTITEMDEF = 0x3b,
239 u32 length of the next item
240 serialized CraftiItemDefManager
243 TOCLIENT_ANNOUNCE_TEXTURES = 0x3c,
247 u32 number of textures
251 u16 length of sha1_digest
261 Sent first after connected.
263 [0] u16 TOSERVER_INIT
264 [2] u8 SER_FMT_VER_HIGHEST
265 [3] u8[20] player_name
266 [23] u8[28] password (new in some version)
267 [51] u16 client network protocol version (new in some version)
270 TOSERVER_INIT2 = 0x11,
272 Sent as an ACK for TOCLIENT_INIT.
273 After this, the server can send data.
275 [0] u16 TOSERVER_INIT2
278 TOSERVER_GETBLOCK=0x20, // Obsolete
279 TOSERVER_ADDNODE = 0x21, // Obsolete
280 TOSERVER_REMOVENODE = 0x22, // Obsolete
282 TOSERVER_PLAYERPOS = 0x23,
285 [2] v3s32 position*100
286 [2+12] v3s32 speed*100
287 [2+12+12] s32 pitch*100
288 [2+12+12+4] s32 yaw*100
291 TOSERVER_GOTBLOCKS = 0x24,
300 TOSERVER_DELETEDBLOCKS = 0x25,
309 TOSERVER_ADDNODE_FROM_INVENTORY = 0x26, // Obsolete
316 TOSERVER_CLICK_OBJECT = 0x27, // Obsolete
320 [2] u8 button (0=left, 1=right)
326 TOSERVER_GROUND_ACTION = 0x28, // Obsolete
331 [3] v3s16 nodepos_undersurface
332 [9] v3s16 nodepos_abovesurface
335 0: start digging (from undersurface)
336 1: place block (to abovesurface)
337 2: stop digging (all parameters ignored)
341 TOSERVER_RELEASE = 0x29, // Obsolete
343 // (oops, there is some gap here)
345 TOSERVER_SIGNTEXT = 0x30, // Old signs, obsolete
354 TOSERVER_INVENTORY_ACTION = 0x31,
356 See InventoryAction in inventory.h
359 TOSERVER_CHAT_MESSAGE = 0x32,
366 TOSERVER_SIGNNODETEXT = 0x33,
374 TOSERVER_CLICK_ACTIVEOBJECT = 0x34, // Obsolete
378 [2] u8 button (0=left, 1=right)
383 TOSERVER_DAMAGE = 0x35,
389 TOSERVER_PASSWORD=0x36,
391 Sent to change password.
393 [0] u16 TOSERVER_PASSWORD
394 [2] u8[28] old password
395 [30] u8[28] new password
398 TOSERVER_PLAYERITEM=0x37,
400 Sent to change selected item.
402 [0] u16 TOSERVER_PLAYERITEM
406 TOSERVER_RESPAWN=0x38,
411 TOSERVER_INTERACT = 0x39,
416 [5] u32 length of the next item
417 [9] serialized PointedThing
419 0: start digging (from undersurface) or use
420 1: stop digging (all parameters ignored)
422 3: place block or item (to abovesurface)
425 (Obsoletes TOSERVER_GROUND_ACTION and TOSERVER_CLICK_ACTIVEOBJECT.)
428 TOSERVER_REQUEST_TEXTURES = 0x40,
432 u16 number of textures requested
441 inline SharedBuffer<u8> makePacket_TOCLIENT_TIME_OF_DAY(u16 time)
443 SharedBuffer<u8> data(2+2);
444 writeU16(&data[0], TOCLIENT_TIME_OF_DAY);
445 writeU16(&data[2], time);