2010-11-29 19:13:04 +01:00
|
|
|
/*
|
|
|
|
Minetest-c55
|
|
|
|
Copyright (C) 2010 celeron55, Perttu Ahola <celeron55@gmail.com>
|
|
|
|
|
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU General Public License as published by
|
|
|
|
the Free Software Foundation; either version 2 of the License, or
|
|
|
|
(at your option) any later version.
|
|
|
|
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License along
|
|
|
|
with this program; if not, write to the Free Software Foundation, Inc.,
|
|
|
|
51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
|
|
*/
|
|
|
|
|
2010-11-27 00:02:21 +01:00
|
|
|
#ifndef CLIENTSERVER_HEADER
|
|
|
|
#define CLIENTSERVER_HEADER
|
|
|
|
|
2010-12-20 13:04:31 +01:00
|
|
|
#include "utility.h"
|
|
|
|
|
2011-11-15 00:00:16 +01:00
|
|
|
/*
|
|
|
|
changes by PROTOCOL_VERSION:
|
|
|
|
|
|
|
|
PROTOCOL_VERSION 3:
|
|
|
|
Base for writing changes here
|
|
|
|
PROTOCOL_VERSION 4:
|
2011-11-15 10:02:47 +01:00
|
|
|
Add TOCLIENT_TEXTURES
|
2011-11-15 22:58:56 +01:00
|
|
|
Add TOCLIENT_TOOLDEF
|
2011-11-15 19:32:56 +01:00
|
|
|
Add TOCLIENT_NODEDEF
|
2011-11-15 00:00:16 +01:00
|
|
|
*/
|
|
|
|
|
|
|
|
#define PROTOCOL_VERSION 4
|
2011-10-15 14:02:28 +02:00
|
|
|
|
2010-11-27 00:02:21 +01:00
|
|
|
#define PROTOCOL_ID 0x4f457403
|
|
|
|
|
2011-05-29 20:11:16 +02:00
|
|
|
#define PASSWORD_SIZE 28 // Maximum password length. Allows for
|
|
|
|
// base64-encoded SHA-1 (27+\0).
|
|
|
|
|
2010-11-27 00:02:21 +01:00
|
|
|
enum ToClientCommand
|
|
|
|
{
|
2010-11-27 16:18:34 +01:00
|
|
|
TOCLIENT_INIT = 0x10,
|
2010-11-27 00:02:21 +01:00
|
|
|
/*
|
|
|
|
Server's reply to TOSERVER_INIT.
|
|
|
|
Sent second after connected.
|
|
|
|
|
|
|
|
[0] u16 TOSERVER_INIT
|
|
|
|
[2] u8 deployed version
|
2011-04-21 18:35:17 +02:00
|
|
|
[3] v3s16 player's position + v3f(0,BS/2,0) floatToInt'd
|
2011-06-26 23:27:17 +02:00
|
|
|
[12] u64 map seed (new as of 2011-02-27)
|
2011-04-21 18:35:17 +02:00
|
|
|
|
|
|
|
NOTE: The position in here is deprecated; position is
|
|
|
|
explicitly sent afterwards
|
2010-11-27 00:02:21 +01:00
|
|
|
*/
|
|
|
|
|
2010-11-27 16:18:34 +01:00
|
|
|
TOCLIENT_BLOCKDATA = 0x20, //TODO: Multiple blocks
|
|
|
|
TOCLIENT_ADDNODE = 0x21,
|
|
|
|
TOCLIENT_REMOVENODE = 0x22,
|
2010-11-27 00:02:21 +01:00
|
|
|
|
2011-04-21 18:35:17 +02:00
|
|
|
TOCLIENT_PLAYERPOS = 0x23, // Obsolete
|
2010-11-27 00:02:21 +01:00
|
|
|
/*
|
|
|
|
[0] u16 command
|
|
|
|
// Followed by an arbitary number of these:
|
|
|
|
// Number is determined from packet length.
|
|
|
|
[N] u16 peer_id
|
|
|
|
[N+2] v3s32 position*100
|
|
|
|
[N+2+12] v3s32 speed*100
|
|
|
|
[N+2+12+12] s32 pitch*100
|
|
|
|
[N+2+12+12+4] s32 yaw*100
|
|
|
|
*/
|
|
|
|
|
2010-11-27 16:18:34 +01:00
|
|
|
TOCLIENT_PLAYERINFO = 0x24,
|
2010-11-27 00:02:21 +01:00
|
|
|
/*
|
|
|
|
[0] u16 command
|
|
|
|
// Followed by an arbitary number of these:
|
|
|
|
// Number is determined from packet length.
|
|
|
|
[N] u16 peer_id
|
|
|
|
[N] char[20] name
|
|
|
|
*/
|
|
|
|
|
2011-04-21 18:35:17 +02:00
|
|
|
TOCLIENT_OPT_BLOCK_NOT_FOUND = 0x25, // Obsolete
|
2010-11-27 00:02:21 +01:00
|
|
|
|
2011-04-21 18:35:17 +02:00
|
|
|
TOCLIENT_SECTORMETA = 0x26, // Obsolete
|
2010-11-27 00:02:21 +01:00
|
|
|
/*
|
|
|
|
[0] u16 command
|
|
|
|
[2] u8 sector count
|
|
|
|
[3...] v2s16 pos + sector metadata
|
|
|
|
*/
|
|
|
|
|
2010-11-27 16:18:34 +01:00
|
|
|
TOCLIENT_INVENTORY = 0x27,
|
2010-11-27 00:02:21 +01:00
|
|
|
/*
|
|
|
|
[0] u16 command
|
|
|
|
[2] serialized inventory
|
|
|
|
*/
|
|
|
|
|
2010-11-27 16:18:34 +01:00
|
|
|
TOCLIENT_OBJECTDATA = 0x28,
|
2010-11-27 00:02:21 +01:00
|
|
|
/*
|
|
|
|
Sent as unreliable.
|
|
|
|
|
|
|
|
u16 command
|
|
|
|
u16 number of player positions
|
|
|
|
for each player:
|
2011-08-22 21:04:46 +02:00
|
|
|
u16 peer_id
|
2010-11-27 00:02:21 +01:00
|
|
|
v3s32 position*100
|
|
|
|
v3s32 speed*100
|
|
|
|
s32 pitch*100
|
|
|
|
s32 yaw*100
|
|
|
|
u16 count of blocks
|
|
|
|
for each block:
|
|
|
|
v3s16 blockpos
|
|
|
|
block objects
|
|
|
|
*/
|
2010-12-20 13:04:31 +01:00
|
|
|
|
|
|
|
TOCLIENT_TIME_OF_DAY = 0x29,
|
|
|
|
/*
|
|
|
|
u16 command
|
|
|
|
u16 time (0-23999)
|
|
|
|
*/
|
2010-12-23 21:35:53 +01:00
|
|
|
|
2011-11-15 19:32:56 +01:00
|
|
|
// (oops, there is some gap here)
|
|
|
|
|
2010-12-23 21:35:53 +01:00
|
|
|
TOCLIENT_CHAT_MESSAGE = 0x30,
|
|
|
|
/*
|
|
|
|
u16 command
|
|
|
|
u16 length
|
|
|
|
wstring message
|
|
|
|
*/
|
|
|
|
|
2011-02-20 23:45:14 +01:00
|
|
|
TOCLIENT_ACTIVE_OBJECT_REMOVE_ADD = 0x31,
|
|
|
|
/*
|
|
|
|
u16 command
|
|
|
|
u16 count of removed objects
|
|
|
|
for all removed objects {
|
|
|
|
u16 id
|
|
|
|
}
|
|
|
|
u16 count of added objects
|
|
|
|
for all added objects {
|
|
|
|
u16 id
|
|
|
|
u8 type
|
2011-08-22 21:04:46 +02:00
|
|
|
u32 initialization data length
|
2011-02-21 15:10:36 +01:00
|
|
|
string initialization data
|
2011-02-20 23:45:14 +01:00
|
|
|
}
|
|
|
|
*/
|
|
|
|
|
|
|
|
TOCLIENT_ACTIVE_OBJECT_MESSAGES = 0x32,
|
|
|
|
/*
|
|
|
|
u16 command
|
|
|
|
for all objects
|
|
|
|
{
|
|
|
|
u16 id
|
|
|
|
u16 message length
|
|
|
|
string message
|
|
|
|
}
|
|
|
|
*/
|
|
|
|
|
2011-04-21 18:35:17 +02:00
|
|
|
TOCLIENT_HP = 0x33,
|
|
|
|
/*
|
|
|
|
u16 command
|
|
|
|
u8 hp
|
|
|
|
*/
|
|
|
|
|
|
|
|
TOCLIENT_MOVE_PLAYER = 0x34,
|
|
|
|
/*
|
|
|
|
u16 command
|
|
|
|
v3f1000 player position
|
|
|
|
f1000 player pitch
|
|
|
|
f1000 player yaw
|
|
|
|
*/
|
2011-05-20 21:28:03 +02:00
|
|
|
|
|
|
|
TOCLIENT_ACCESS_DENIED = 0x35,
|
|
|
|
/*
|
|
|
|
u16 command
|
2011-05-29 20:11:16 +02:00
|
|
|
u16 reason_length
|
|
|
|
wstring reason
|
2011-05-20 21:28:03 +02:00
|
|
|
*/
|
2011-08-11 07:02:57 +02:00
|
|
|
|
|
|
|
TOCLIENT_PLAYERITEM = 0x36,
|
|
|
|
/*
|
|
|
|
u16 command
|
2011-08-25 21:31:28 +02:00
|
|
|
u16 count of player items
|
|
|
|
for all player items {
|
|
|
|
u16 peer id
|
|
|
|
u16 length of serialized item
|
|
|
|
string serialized item
|
|
|
|
}
|
2011-08-11 07:02:57 +02:00
|
|
|
*/
|
2011-10-15 13:46:59 +02:00
|
|
|
|
|
|
|
TOCLIENT_DEATHSCREEN = 0x37,
|
|
|
|
/*
|
|
|
|
u16 command
|
|
|
|
u8 bool set camera point target
|
|
|
|
v3f1000 camera point target (to point the death cause or whatever)
|
|
|
|
*/
|
2011-11-15 00:00:16 +01:00
|
|
|
|
2011-11-15 22:58:56 +01:00
|
|
|
TOCLIENT_TEXTURES = 0x38,
|
2011-11-15 10:02:47 +01:00
|
|
|
/*
|
|
|
|
u16 command
|
2011-11-15 22:58:56 +01:00
|
|
|
u16 total number of texture bunches
|
|
|
|
u16 index of this bunch
|
|
|
|
u32 number of textures in this bunch
|
2011-11-15 10:02:47 +01:00
|
|
|
for each texture {
|
|
|
|
u16 length of name
|
|
|
|
string name
|
|
|
|
u32 length of data
|
|
|
|
data
|
|
|
|
}
|
|
|
|
*/
|
|
|
|
|
2011-11-15 22:58:56 +01:00
|
|
|
TOCLIENT_TOOLDEF = 0x39,
|
2011-11-15 19:32:56 +01:00
|
|
|
/*
|
|
|
|
u16 command
|
|
|
|
u32 length of the next item
|
2011-11-15 22:58:56 +01:00
|
|
|
serialized ToolDefManager
|
2011-11-15 19:32:56 +01:00
|
|
|
*/
|
|
|
|
|
2011-11-15 22:58:56 +01:00
|
|
|
TOCLIENT_NODEDEF = 0x3a,
|
2011-11-15 00:00:16 +01:00
|
|
|
/*
|
|
|
|
u16 command
|
2011-11-15 22:58:56 +01:00
|
|
|
u32 length of the next item
|
|
|
|
serialized NodeDefManager
|
2011-11-15 00:00:16 +01:00
|
|
|
*/
|
2010-11-27 00:02:21 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
enum ToServerCommand
|
|
|
|
{
|
|
|
|
TOSERVER_INIT=0x10,
|
|
|
|
/*
|
|
|
|
Sent first after connected.
|
|
|
|
|
|
|
|
[0] u16 TOSERVER_INIT
|
|
|
|
[2] u8 SER_FMT_VER_HIGHEST
|
|
|
|
[3] u8[20] player_name
|
2011-07-30 19:02:17 +02:00
|
|
|
[23] u8[28] password (new in some version)
|
|
|
|
[51] u16 client network protocol version (new in some version)
|
2010-11-27 00:02:21 +01:00
|
|
|
*/
|
|
|
|
|
2010-11-27 16:18:34 +01:00
|
|
|
TOSERVER_INIT2 = 0x11,
|
2010-11-27 00:02:21 +01:00
|
|
|
/*
|
|
|
|
Sent as an ACK for TOCLIENT_INIT.
|
|
|
|
After this, the server can send data.
|
|
|
|
|
|
|
|
[0] u16 TOSERVER_INIT2
|
|
|
|
*/
|
|
|
|
|
2011-04-21 18:35:17 +02:00
|
|
|
TOSERVER_GETBLOCK=0x20, // Obsolete
|
|
|
|
TOSERVER_ADDNODE = 0x21, // Obsolete
|
|
|
|
TOSERVER_REMOVENODE = 0x22, // Obsolete
|
2010-11-27 00:02:21 +01:00
|
|
|
|
2010-11-27 16:18:34 +01:00
|
|
|
TOSERVER_PLAYERPOS = 0x23,
|
2010-11-27 00:02:21 +01:00
|
|
|
/*
|
|
|
|
[0] u16 command
|
|
|
|
[2] v3s32 position*100
|
|
|
|
[2+12] v3s32 speed*100
|
|
|
|
[2+12+12] s32 pitch*100
|
|
|
|
[2+12+12+4] s32 yaw*100
|
|
|
|
*/
|
|
|
|
|
2010-11-27 16:18:34 +01:00
|
|
|
TOSERVER_GOTBLOCKS = 0x24,
|
2010-11-27 00:02:21 +01:00
|
|
|
/*
|
|
|
|
[0] u16 command
|
|
|
|
[2] u8 count
|
|
|
|
[3] v3s16 pos_0
|
|
|
|
[3+6] v3s16 pos_1
|
|
|
|
...
|
|
|
|
*/
|
|
|
|
|
2010-11-27 16:18:34 +01:00
|
|
|
TOSERVER_DELETEDBLOCKS = 0x25,
|
2010-11-27 00:02:21 +01:00
|
|
|
/*
|
|
|
|
[0] u16 command
|
|
|
|
[2] u8 count
|
|
|
|
[3] v3s16 pos_0
|
|
|
|
[3+6] v3s16 pos_1
|
|
|
|
...
|
|
|
|
*/
|
|
|
|
|
2011-04-21 18:35:17 +02:00
|
|
|
TOSERVER_ADDNODE_FROM_INVENTORY = 0x26, // Obsolete
|
2010-11-27 00:02:21 +01:00
|
|
|
/*
|
|
|
|
[0] u16 command
|
|
|
|
[2] v3s16 pos
|
|
|
|
[8] u16 i
|
|
|
|
*/
|
|
|
|
|
2010-11-27 16:18:34 +01:00
|
|
|
TOSERVER_CLICK_OBJECT = 0x27,
|
2010-11-27 00:02:21 +01:00
|
|
|
/*
|
|
|
|
length: 13
|
|
|
|
[0] u16 command
|
|
|
|
[2] u8 button (0=left, 1=right)
|
|
|
|
[3] v3s16 blockpos
|
|
|
|
[9] s16 id
|
|
|
|
[11] u16 item
|
|
|
|
*/
|
|
|
|
|
2010-12-18 12:10:37 +01:00
|
|
|
TOSERVER_GROUND_ACTION = 0x28,
|
2010-11-27 00:02:21 +01:00
|
|
|
/*
|
|
|
|
length: 17
|
|
|
|
[0] u16 command
|
2010-12-18 12:10:37 +01:00
|
|
|
[2] u8 action
|
2010-11-27 00:02:21 +01:00
|
|
|
[3] v3s16 nodepos_undersurface
|
|
|
|
[9] v3s16 nodepos_abovesurface
|
|
|
|
[15] u16 item
|
2010-12-18 12:10:37 +01:00
|
|
|
actions:
|
|
|
|
0: start digging (from undersurface)
|
|
|
|
1: place block (to abovesurface)
|
|
|
|
2: stop digging (all parameters ignored)
|
2010-12-23 21:35:53 +01:00
|
|
|
3: digging completed
|
2010-11-27 00:02:21 +01:00
|
|
|
*/
|
|
|
|
|
2011-04-21 18:35:17 +02:00
|
|
|
TOSERVER_RELEASE = 0x29, // Obsolete
|
2010-11-27 00:02:21 +01:00
|
|
|
|
2011-11-15 19:32:56 +01:00
|
|
|
// (oops, there is some gap here)
|
|
|
|
|
2011-04-21 18:35:17 +02:00
|
|
|
TOSERVER_SIGNTEXT = 0x30, // Old signs
|
2010-11-27 00:02:21 +01:00
|
|
|
/*
|
|
|
|
u16 command
|
|
|
|
v3s16 blockpos
|
|
|
|
s16 id
|
|
|
|
u16 textlen
|
|
|
|
textdata
|
|
|
|
*/
|
2010-12-22 15:30:23 +01:00
|
|
|
|
|
|
|
TOSERVER_INVENTORY_ACTION = 0x31,
|
|
|
|
/*
|
|
|
|
See InventoryAction in inventory.h
|
|
|
|
*/
|
2010-12-23 21:35:53 +01:00
|
|
|
|
|
|
|
TOSERVER_CHAT_MESSAGE = 0x32,
|
|
|
|
/*
|
|
|
|
u16 command
|
|
|
|
u16 length
|
|
|
|
wstring message
|
|
|
|
*/
|
|
|
|
|
2011-04-04 04:12:33 +02:00
|
|
|
TOSERVER_SIGNNODETEXT = 0x33,
|
|
|
|
/*
|
|
|
|
u16 command
|
|
|
|
v3s16 p
|
|
|
|
u16 textlen
|
|
|
|
textdata
|
|
|
|
*/
|
|
|
|
|
2011-04-10 03:15:10 +02:00
|
|
|
TOSERVER_CLICK_ACTIVEOBJECT = 0x34,
|
|
|
|
/*
|
|
|
|
length: 7
|
|
|
|
[0] u16 command
|
|
|
|
[2] u8 button (0=left, 1=right)
|
|
|
|
[3] u16 id
|
|
|
|
[5] u16 item
|
|
|
|
*/
|
2011-04-21 18:35:17 +02:00
|
|
|
|
|
|
|
TOSERVER_DAMAGE = 0x35,
|
|
|
|
/*
|
|
|
|
u16 command
|
|
|
|
u8 amount
|
|
|
|
*/
|
2011-05-22 22:09:12 +02:00
|
|
|
|
|
|
|
TOSERVER_PASSWORD=0x36,
|
|
|
|
/*
|
|
|
|
Sent to change password.
|
|
|
|
|
|
|
|
[0] u16 TOSERVER_PASSWORD
|
|
|
|
[2] u8[28] old password
|
|
|
|
[30] u8[28] new password
|
|
|
|
*/
|
|
|
|
|
2011-08-10 21:43:40 +02:00
|
|
|
TOSERVER_PLAYERITEM=0x37,
|
|
|
|
/*
|
|
|
|
Sent to change selected item.
|
|
|
|
|
|
|
|
[0] u16 TOSERVER_PLAYERITEM
|
|
|
|
[2] u16 item
|
|
|
|
*/
|
2011-10-15 13:46:59 +02:00
|
|
|
|
|
|
|
TOSERVER_RESPAWN=0x38,
|
|
|
|
/*
|
|
|
|
u16 TOSERVER_RESPAWN
|
|
|
|
*/
|
2010-11-27 00:02:21 +01:00
|
|
|
};
|
|
|
|
|
2010-12-20 13:04:31 +01:00
|
|
|
inline SharedBuffer<u8> makePacket_TOCLIENT_TIME_OF_DAY(u16 time)
|
|
|
|
{
|
|
|
|
SharedBuffer<u8> data(2+2);
|
|
|
|
writeU16(&data[0], TOCLIENT_TIME_OF_DAY);
|
|
|
|
writeU16(&data[2], time);
|
|
|
|
return data;
|
|
|
|
}
|
2010-11-27 00:02:21 +01:00
|
|
|
|
|
|
|
#endif
|
|
|
|
|