2013-09-16 14:16:05 -04:00
2012-06-14 09:06:06 -04:00
// cClientHandle.h
// Interfaces to the cClientHandle class representing a client connected to this server. The client need not be a player yet
# pragma once
# ifndef CCLIENTHANDLE_H_INCLUDED
# define CCLIENTHANDLE_H_INCLUDED
2012-08-26 12:20:08 -04:00
# include "Defines.h"
2014-03-11 10:01:17 -04:00
# include "Vector3.h"
2012-09-23 17:23:33 -04:00
# include "OSSupport/SocketThreads.h"
2012-06-14 09:06:06 -04:00
# include "ChunkDef.h"
2012-08-17 06:18:07 -04:00
# include "ByteBuffer.h"
2014-01-21 08:58:17 -05:00
# include "Scoreboard.h"
2014-02-18 13:50:08 -05:00
# include "Map.h"
2014-04-12 08:58:46 -04:00
# include "Enchantments.h"
2014-04-13 16:15:10 -04:00
# include "UI/SlotArea.h"
2012-06-14 09:06:06 -04:00
2012-08-27 13:31:16 -04:00
class cChunkDataSerializer ;
2012-08-19 07:51:17 -04:00
class cInventory ;
2012-08-27 13:31:16 -04:00
class cMonster ;
2012-08-19 17:14:45 -04:00
class cPawn ;
2013-11-25 15:43:43 -05:00
class cExpOrb ;
2014-02-17 19:16:03 -05:00
class cPainting ;
2012-08-24 03:58:26 -04:00
class cPickup ;
2012-08-27 13:31:16 -04:00
class cPlayer ;
class cProtocol ;
class cWindow ;
2012-12-26 04:12:00 -05:00
class cFallingBlock ;
2013-01-11 23:46:01 -05:00
class cItemHandler ;
2013-08-14 04:24:34 -04:00
class cWorld ;
2014-02-15 17:16:44 -05:00
class cCompositeChat ;
2014-05-11 07:57:06 -04:00
class cStatManager ;
2012-06-14 09:06:06 -04:00
2012-12-24 17:09:01 -05:00
2012-06-14 09:06:06 -04:00
class cClientHandle : // tolua_export
public cSocketThreads : : cCallback
{ // tolua_export
public :
2012-09-29 09:41:47 -04:00
# if defined(ANDROID_NDK)
static const int DEFAULT_VIEW_DISTANCE = 4 ; // The default ViewDistance (used when no value is set in Settings.ini)
# else
2013-09-16 14:07:33 -04:00
static const int DEFAULT_VIEW_DISTANCE = 10 ;
2012-09-29 09:41:47 -04:00
# endif
2013-09-16 14:07:33 -04:00
static const int MAX_VIEW_DISTANCE = 15 ;
2013-09-14 15:34:26 -04:00
static const int MIN_VIEW_DISTANCE = 3 ;
2013-06-18 15:32:31 -04:00
2012-09-25 04:23:19 -04:00
cClientHandle ( const cSocket * a_Socket , int a_ViewDistance ) ;
virtual ~ cClientHandle ( ) ;
2012-06-14 09:06:06 -04:00
2012-09-25 04:23:19 -04:00
const AString & GetIPString ( void ) const { return m_IPString ; }
2012-06-14 09:06:06 -04:00
2014-06-21 16:13:35 -04:00
cPlayer * GetPlayer ( void ) { return m_Player ; } // tolua_export
2012-06-14 09:06:06 -04:00
2014-04-13 07:04:56 -04:00
const AString & GetUUID ( void ) const { return m_UUID ; } // tolua_export
2014-04-14 14:21:00 -04:00
void SetUUID ( const AString & a_UUID ) { m_UUID = a_UUID ; }
2014-04-14 16:52:59 -04:00
/** Generates an UUID based on the username stored for this client, and stores it in the m_UUID member.
This is used for the offline ( non - auth ) mode , when there ' s no UUID source .
Each username generates a unique and constant UUID , so that when the player reconnects with the same name , their UUID is the same .
Internally calls the GenerateOfflineUUID static function . */
void GenerateOfflineUUID ( void ) ;
2014-04-14 14:21:00 -04:00
/** Generates an UUID based on the player name provided.
This is used for the offline ( non - auth ) mode , when there ' s no UUID source .
2014-06-21 16:13:35 -04:00
Each username generates a unique and constant UUID , so that when the player reconnects with the same name , their UUID is the same .
Returns a 36 - char UUID ( with dashes ) . */
2014-04-14 16:52:59 -04:00
static AString GenerateOfflineUUID ( const AString & a_Username ) ; // tolua_export
2014-04-24 20:24:39 -04:00
2014-06-21 16:13:35 -04:00
/** Returns true if the UUID is generated by online auth, false if it is an offline-generated UUID.
We use Version - 3 UUIDs for offline UUIDs , online UUIDs are Version - 4 , thus we can tell them apart .
Accepts both 32 - char and 36 - char UUIDs ( with and without dashes ) .
If the string given is not a valid UUID , returns false . */
static bool IsUUIDOnline ( const AString & a_UUID ) ; // tolua_export
2014-04-26 12:21:49 -04:00
/** Formats the type of message with the proper color and prefix for sending to the client. **/
2014-05-19 16:16:29 -04:00
static AString FormatMessageType ( bool ShouldAppendChatPrefixes , eMessageType a_ChatPrefix , const AString & a_AdditionalData ) ;
2014-04-26 12:21:49 -04:00
2014-05-19 16:16:29 -04:00
static AString FormatChatPrefix ( bool ShouldAppendChatPrefixes , AString a_ChatPrefixS , AString m_Color1 , AString m_Color2 ) ;
2014-04-13 07:04:56 -04:00
2013-01-11 23:46:01 -05:00
void Kick ( const AString & a_Reason ) ; // tolua_export
2014-04-13 07:04:56 -04:00
void Authenticate ( const AString & a_Name , const AString & a_UUID ) ; // Called by cAuthenticator when the user passes authentication
2012-06-14 09:06:06 -04:00
void StreamChunks ( void ) ;
// Removes the client from all chunks. Used when switching worlds or destroying the player
void RemoveFromAllChunks ( void ) ;
2012-11-11 09:00:58 -05:00
inline bool IsLoggedIn ( void ) const { return ( m_State > = csAuthenticating ) ; }
2012-06-14 09:06:06 -04:00
2014-02-20 17:24:39 -05:00
/** Called while the client is being ticked from the world via its cPlayer object */
2012-06-14 09:06:06 -04:00
void Tick ( float a_Dt ) ;
2013-12-16 04:41:35 -05:00
2014-02-20 17:24:39 -05:00
/** Called while the client is being ticked from the cServer object */
2013-12-16 04:41:35 -05:00
void ServerTick ( float a_Dt ) ;
2012-06-14 09:06:06 -04:00
2012-11-11 09:00:58 -05:00
void Destroy ( void ) ;
2012-06-14 09:06:06 -04:00
2012-11-11 09:00:58 -05:00
bool IsPlaying ( void ) const { return ( m_State = = csPlaying ) ; }
bool IsDestroyed ( void ) const { return ( m_State = = csDestroyed ) ; }
bool IsDestroying ( void ) const { return ( m_State = = csDestroying ) ; }
2012-06-14 09:06:06 -04:00
2013-07-07 09:06:06 -04:00
// The following functions send the various packets:
// (Please keep these alpha-sorted)
2013-07-30 16:48:59 -04:00
void SendAttachEntity ( const cEntity & a_Entity , const cEntity * a_Vehicle ) ;
void SendBlockAction ( int a_BlockX , int a_BlockY , int a_BlockZ , char a_Byte1 , char a_Byte2 , BLOCKTYPE a_BlockType ) ;
void SendBlockBreakAnim ( int a_EntityID , int a_BlockX , int a_BlockY , int a_BlockZ , char a_Stage ) ;
void SendBlockChange ( int a_BlockX , int a_BlockY , int a_BlockZ , BLOCKTYPE a_BlockType , NIBBLETYPE a_BlockMeta ) ; // tolua_export
void SendBlockChanges ( int a_ChunkX , int a_ChunkZ , const sSetBlockVector & a_Changes ) ;
2014-02-15 17:16:44 -05:00
void SendChat ( const AString & a_Message , eMessageType a_ChatPrefix , const AString & a_AdditionalData = " " ) ;
void SendChat ( const cCompositeChat & a_Message ) ;
2013-07-30 16:48:59 -04:00
void SendChunkData ( int a_ChunkX , int a_ChunkZ , cChunkDataSerializer & a_Serializer ) ;
2014-06-27 14:56:29 -04:00
void SendCollectEntity ( const cEntity & a_Entity , const cPlayer & a_Player ) ;
2013-07-30 16:48:59 -04:00
void SendDestroyEntity ( const cEntity & a_Entity ) ;
void SendDisconnect ( const AString & a_Reason ) ;
void SendEditSign ( int a_BlockX , int a_BlockY , int a_BlockZ ) ;
2013-12-14 12:19:56 -05:00
void SendEntityEffect ( const cEntity & a_Entity , int a_EffectID , int a_Amplifier , short a_Duration ) ;
2013-07-30 16:48:59 -04:00
void SendEntityEquipment ( const cEntity & a_Entity , short a_SlotNum , const cItem & a_Item ) ;
void SendEntityHeadLook ( const cEntity & a_Entity ) ;
void SendEntityLook ( const cEntity & a_Entity ) ;
void SendEntityMetadata ( const cEntity & a_Entity ) ;
void SendEntityProperties ( const cEntity & a_Entity ) ;
void SendEntityRelMove ( const cEntity & a_Entity , char a_RelX , char a_RelY , char a_RelZ ) ;
void SendEntityRelMoveLook ( const cEntity & a_Entity , char a_RelX , char a_RelY , char a_RelZ ) ;
void SendEntityStatus ( const cEntity & a_Entity , char a_Status ) ;
void SendEntityVelocity ( const cEntity & a_Entity ) ;
void SendExplosion ( double a_BlockX , double a_BlockY , double a_BlockZ , float a_Radius , const cVector3iArray & a_BlocksAffected , const Vector3d & a_PlayerMotion ) ;
void SendGameMode ( eGameMode a_GameMode ) ;
void SendHealth ( void ) ;
void SendInventorySlot ( char a_WindowID , short a_SlotNum , const cItem & a_Item ) ;
2014-02-13 14:36:24 -05:00
void SendMapColumn ( int a_ID , int a_X , int a_Y , const Byte * a_Colors , unsigned int a_Length ) ;
2014-02-18 13:50:08 -05:00
void SendMapDecorators ( int a_ID , const cMapDecoratorList & a_Decorators ) ;
2014-02-13 14:36:24 -05:00
void SendMapInfo ( int a_ID , unsigned int a_Scale ) ;
2014-02-17 19:16:03 -05:00
void SendPaintingSpawn ( const cPainting & a_Painting ) ;
2013-07-30 16:48:59 -04:00
void SendPickupSpawn ( const cPickup & a_Pickup ) ;
2013-12-06 18:47:07 -05:00
void SendEntityAnimation ( const cEntity & a_Entity , char a_Animation ) ;
2013-12-22 08:45:25 -05:00
void SendParticleEffect ( const AString & a_ParticleName , float a_SrcX , float a_SrcY , float a_SrcZ , float a_OffsetX , float a_OffsetY , float a_OffsetZ , float a_ParticleData , int a_ParticleAmmount ) ;
2013-12-15 08:48:17 -05:00
void SendPlayerAbilities ( void ) ;
2013-07-30 16:48:59 -04:00
void SendPlayerListItem ( const cPlayer & a_Player , bool a_IsOnline ) ;
void SendPlayerMaxSpeed ( void ) ; ///< Informs the client of the maximum player speed (1.6.1+)
void SendPlayerMoveLook ( void ) ;
void SendPlayerPosition ( void ) ;
void SendPlayerSpawn ( const cPlayer & a_Player ) ;
2014-01-09 05:39:42 -05:00
void SendPluginMessage ( const AString & a_Channel , const AString & a_Message ) ; // Exported in ManualBindings.cpp
2013-12-14 12:19:56 -05:00
void SendRemoveEntityEffect ( const cEntity & a_Entity , int a_EffectID ) ;
2014-06-29 17:44:01 -04:00
void SendRespawn ( const cWorld & a_World , bool a_ShouldIgnoreDimensionChecks = false ) ;
2013-11-15 10:32:04 -05:00
void SendExperience ( void ) ;
2013-11-25 15:43:43 -05:00
void SendExperienceOrb ( const cExpOrb & a_ExpOrb ) ;
2014-01-21 08:58:17 -05:00
void SendScoreboardObjective ( const AString & a_Name , const AString & a_DisplayName , Byte a_Mode ) ;
void SendScoreUpdate ( const AString & a_Objective , const AString & a_Player , cObjective : : Score a_Score , Byte a_Mode ) ;
void SendDisplayObjective ( const AString & a_Objective , cScoreboard : : eDisplaySlot a_Display ) ;
2013-07-30 16:48:59 -04:00
void SendSoundEffect ( const AString & a_SoundName , int a_SrcX , int a_SrcY , int a_SrcZ , float a_Volume , float a_Pitch ) ; // a_Src coords are Block * 8
void SendSoundParticleEffect ( int a_EffectID , int a_SrcX , int a_SrcY , int a_SrcZ , int a_Data ) ;
void SendSpawnFallingBlock ( const cFallingBlock & a_FallingBlock ) ;
void SendSpawnMob ( const cMonster & a_Mob ) ;
void SendSpawnObject ( const cEntity & a_Entity , char a_ObjectType , int a_ObjectData , Byte a_Yaw , Byte a_Pitch ) ;
2013-09-09 05:13:14 -04:00
void SendSpawnVehicle ( const cEntity & a_Vehicle , char a_VehicleType , char a_VehicleSubType = 0 ) ;
2014-05-11 07:57:06 -04:00
void SendStatistics ( const cStatManager & a_Manager ) ;
2013-07-30 16:48:59 -04:00
void SendTabCompletionResults ( const AStringVector & a_Results ) ;
void SendTeleportEntity ( const cEntity & a_Entity ) ;
void SendThunderbolt ( int a_BlockX , int a_BlockY , int a_BlockZ ) ;
void SendTimeUpdate ( Int64 a_WorldAge , Int64 a_TimeOfDay ) ;
void SendUnloadChunk ( int a_ChunkX , int a_ChunkZ ) ;
2014-01-19 14:42:25 -05:00
void SendUpdateBlockEntity ( cBlockEntity & a_BlockEntity ) ;
2013-07-30 16:48:59 -04:00
void SendUpdateSign ( int a_BlockX , int a_BlockY , int a_BlockZ , const AString & a_Line1 , const AString & a_Line2 , const AString & a_Line3 , const AString & a_Line4 ) ;
void SendUseBed ( const cEntity & a_Entity , int a_BlockX , int a_BlockY , int a_BlockZ ) ;
void SendWeather ( eWeather a_Weather ) ;
2013-11-08 15:32:14 -05:00
void SendWholeInventory ( const cWindow & a_Window ) ;
void SendWindowClose ( const cWindow & a_Window ) ;
void SendWindowOpen ( const cWindow & a_Window ) ;
2013-08-18 07:26:37 -04:00
void SendWindowProperty ( const cWindow & a_Window , int a_Property , int a_Value ) ;
2012-06-14 09:06:06 -04:00
2014-02-20 17:24:39 -05:00
// tolua_begin
const AString & GetUsername ( void ) const ;
void SetUsername ( const AString & a_Username ) ;
2012-06-14 09:06:06 -04:00
2014-02-20 17:24:39 -05:00
inline short GetPing ( void ) const { return m_Ping ; }
2012-06-14 09:06:06 -04:00
2014-02-20 17:24:39 -05:00
void SetViewDistance ( int a_ViewDistance ) ;
int GetViewDistance ( void ) const { return m_ViewDistance ; }
2014-02-16 07:26:07 -05:00
2014-02-20 17:24:39 -05:00
void SetLocale ( AString & a_Locale ) { m_Locale = a_Locale ; }
AString GetLocale ( void ) const { return m_Locale ; }
2012-06-14 09:06:06 -04:00
2014-02-20 17:24:39 -05:00
int GetUniqueID ( void ) const { return m_UniqueID ; }
2012-06-14 09:06:06 -04:00
2014-02-20 17:24:39 -05:00
bool HasPluginChannel ( const AString & a_PluginChannel ) ;
// tolua_end
/** Returns true if the client wants the chunk specified to be sent (in m_ChunksToSend) */
2012-06-14 09:06:06 -04:00
bool WantsSendChunk ( int a_ChunkX , int a_ChunkY , int a_ChunkZ ) ;
2014-02-20 17:24:39 -05:00
/** Adds the chunk specified to the list of chunks wanted for sending (m_ChunksToSend) */
2012-06-14 09:06:06 -04:00
void AddWantedChunk ( int a_ChunkX , int a_ChunkZ ) ;
2012-08-27 13:31:16 -04:00
// Calls that cProtocol descendants use to report state:
void PacketBufferFull ( void ) ;
2013-12-12 17:05:23 -05:00
void PacketUnknown ( UInt32 a_PacketType ) ;
2012-08-27 13:31:16 -04:00
void PacketError ( unsigned char a_PacketType ) ;
2012-06-14 09:06:06 -04:00
2012-08-27 13:31:16 -04:00
// Calls that cProtocol descendants use for handling packets:
2013-08-01 03:46:01 -04:00
void HandleAnimation ( char a_Animation ) ;
void HandleChat ( const AString & a_Message ) ;
2012-08-27 13:31:16 -04:00
void HandleCreativeInventory ( short a_SlotNum , const cItem & a_HeldItem ) ;
2013-08-01 03:46:01 -04:00
void HandleDisconnect ( const AString & a_Reason ) ;
2014-03-08 11:55:53 -05:00
void HandleEntityCrouch ( int a_EntityID , bool a_IsCrouching ) ;
void HandleEntityLeaveBed ( int a_EntityID ) ;
void HandleEntitySprinting ( int a_EntityID , bool a_IsSprinting ) ;
2014-01-13 14:32:15 -05:00
/** Called when the protocol handshake has been received (for protocol versions that support it;
otherwise the first instant when a username is received ) .
Returns true if the player is to be let in , false if they were disconnected
*/
2013-08-01 03:46:01 -04:00
bool HandleHandshake ( const AString & a_Username ) ;
2014-01-13 14:32:15 -05:00
2013-08-01 03:46:01 -04:00
void HandleKeepAlive ( int a_KeepAliveID ) ;
2014-02-04 13:59:05 -05:00
void HandleLeftClick ( int a_BlockX , int a_BlockY , int a_BlockZ , eBlockFace a_BlockFace , char a_Status ) ;
2013-08-01 03:46:01 -04:00
void HandlePing ( void ) ;
2013-12-15 09:11:59 -05:00
void HandlePlayerAbilities ( bool a_CanFly , bool a_IsFlying , float FlyingSpeed , float WalkingSpeed ) ;
2012-08-27 13:31:16 -04:00
void HandlePlayerLook ( float a_Rotation , float a_Pitch , bool a_IsOnGround ) ;
2014-05-26 10:38:14 -04:00
void HandlePlayerMoveLook ( double a_PosX , double a_PosY , double a_PosZ , double a_Stance , float a_Rotation , float a_Pitch , bool a_IsOnGround ) ; // While m_bPositionConfirmed (normal gameplay)
2013-08-01 03:46:01 -04:00
void HandlePlayerPos ( double a_PosX , double a_PosY , double a_PosZ , double a_Stance , bool a_IsOnGround ) ;
2014-01-07 11:47:05 -05:00
void HandlePluginMessage ( const AString & a_Channel , const AString & a_Message ) ;
2013-08-01 03:46:01 -04:00
void HandleRespawn ( void ) ;
2014-02-04 13:59:05 -05:00
void HandleRightClick ( int a_BlockX , int a_BlockY , int a_BlockZ , eBlockFace a_BlockFace , int a_CursorX , int a_CursorY , int a_CursorZ , const cItem & a_HeldItem ) ;
2012-08-27 13:31:16 -04:00
void HandleSlotSelected ( short a_SlotNum ) ;
2013-09-05 18:04:49 -04:00
void HandleSteerVehicle ( float Forward , float Sideways ) ;
2013-08-01 03:46:01 -04:00
void HandleTabCompletion ( const AString & a_Text ) ;
2012-08-27 13:31:16 -04:00
void HandleUpdateSign (
int a_BlockX , int a_BlockY , int a_BlockZ ,
const AString & a_Line1 , const AString & a_Line2 ,
const AString & a_Line3 , const AString & a_Line4
) ;
2013-07-05 17:11:06 -04:00
void HandleUnmount ( void ) ;
2013-08-01 03:46:01 -04:00
void HandleUseEntity ( int a_TargetEntityID , bool a_IsLeftClick ) ;
void HandleWindowClick ( char a_WindowID , short a_SlotNum , eClickAction a_ClickAction , const cItem & a_HeldItem ) ;
void HandleWindowClose ( char a_WindowID ) ;
2012-08-30 04:19:19 -04:00
/** Called when the protocol has finished logging the user in.
Return true to allow the user in ; false to kick them .
*/
bool HandleLogin ( int a_ProtocolVersion , const AString & a_Username ) ;
2014-04-04 04:13:25 -04:00
void SendData ( const char * a_Data , size_t a_Size ) ;
2013-07-03 03:47:35 -04:00
2014-06-06 16:31:16 -04:00
/** Called when the player moves into a different world.
2014-06-08 15:58:08 -04:00
Sends an UnloadChunk packet for each loaded chunk and resets the streamed chunks . */
void RemoveFromWorld ( void ) ;
2013-08-14 04:24:34 -04:00
2014-04-12 08:58:46 -04:00
/** Called when the player will enchant a Item */
2014-04-07 14:13:45 -04:00
void HandleEnchantItem ( Byte & WindowID , Byte & Enchantment ) ;
2014-03-31 15:34:11 -04:00
private :
2014-02-20 17:24:39 -05:00
/** Handles the block placing packet when it is a real block placement (not block-using, item-using or eating) */
2014-02-04 13:59:05 -05:00
void HandlePlaceBlock ( int a_BlockX , int a_BlockY , int a_BlockZ , eBlockFace a_BlockFace , int a_CursorX , int a_CursorY , int a_CursorZ , cItemHandler & a_ItemHandler ) ;
2012-06-14 09:06:06 -04:00
2014-02-20 17:24:39 -05:00
/** The type used for storing the names of registered plugin channels. */
typedef std : : set < AString > cChannels ;
2012-06-14 09:06:06 -04:00
int m_ViewDistance ; // Number of chunks the player can see in each direction; 4 is the minimum ( http://wiki.vg/Protocol_FAQ#.E2.80.A6all_connecting_clients_spasm_and_jerk_uncontrollably.21 )
static const int GENERATEDISTANCE = 2 ; // Server generates this many chunks AHEAD of player sight. 2 is the minimum, since foliage is generated 1 step behind chunk terrain generation
2012-09-25 04:23:19 -04:00
AString m_IPString ;
2012-06-14 09:06:06 -04:00
AString m_Username ;
AString m_Password ;
cCriticalSection m_CSChunkLists ;
cChunkCoordsList m_LoadedChunks ; // Chunks that the player belongs to
cChunkCoordsList m_ChunksToSend ; // Chunks that need to be sent to the player (queued because they weren't generated yet or there's not enough time to send them)
2012-08-27 13:31:16 -04:00
cProtocol * m_Protocol ;
2013-08-13 16:45:29 -04:00
cCriticalSection m_CSIncomingData ;
AString m_IncomingData ;
2012-08-27 13:31:16 -04:00
cCriticalSection m_CSOutgoingData ;
cByteBuffer m_OutgoingData ;
2013-08-13 16:45:29 -04:00
AString m_OutgoingDataOverflow ; ///< For data that didn't fit into the m_OutgoingData ringbuffer temporarily
2012-06-14 09:06:06 -04:00
Vector3d m_ConfirmPosition ;
cPlayer * m_Player ;
2013-01-05 14:05:15 -05:00
2013-04-13 17:02:10 -04:00
bool m_HasSentDC ; ///< True if a D/C packet has been sent in either direction
2012-06-14 09:06:06 -04:00
// Chunk position when the last StreamChunks() was called; used to avoid re-streaming while in the same chunk
int m_LastStreamedChunkX ;
int m_LastStreamedChunkZ ;
2014-02-20 17:24:39 -05:00
/** Seconds since the last packet data was received (updated in Tick(), reset in DataReceived()) */
2012-11-01 17:38:20 -04:00
float m_TimeSinceLastPacket ;
2012-06-14 09:06:06 -04:00
short m_Ping ;
int m_PingID ;
long long m_PingStartTime ;
long long m_LastPingTime ;
static const unsigned short PING_TIME_MS = 1000 ; //minecraft sends 1 per 20 ticks (1 second or every 1000 ms)
2012-09-25 05:54:36 -04:00
// Values required for block dig animation
2013-01-11 23:46:01 -05:00
int m_BlockDigAnimStage ; // Current stage of the animation; -1 if not digging
2012-09-25 05:54:36 -04:00
int m_BlockDigAnimSpeed ; // Current speed of the animation (units ???)
2013-01-11 23:46:01 -05:00
int m_BlockDigAnimX ;
int m_BlockDigAnimY ;
int m_BlockDigAnimZ ;
2012-06-14 09:06:06 -04:00
2013-01-11 23:46:01 -05:00
// To avoid dig/aim bug in the client, store the last position given in a DIG_START packet and compare to that when processing the DIG_FINISH packet:
bool m_HasStartedDigging ;
int m_LastDigBlockX ;
int m_LastDigBlockY ;
int m_LastDigBlockZ ;
2013-08-20 16:27:29 -04:00
2014-02-20 17:24:39 -05:00
/** Used while csDestroyedWaiting for counting the ticks until the connection is closed */
2013-08-20 16:27:29 -04:00
int m_TicksSinceDestruction ;
2012-11-12 06:10:01 -05:00
2012-06-14 09:06:06 -04:00
enum eState
{
2013-08-13 16:45:29 -04:00
csConnected , ///< The client has just connected, waiting for their handshake / login
csAuthenticating , ///< The client has logged in, waiting for external authentication
csAuthenticated , ///< The client has been authenticated, will start streaming chunks in the next tick
csDownloadingWorld , ///< The client is waiting for chunks, we're waiting for the loader to provide and send them
csConfirmingPos , ///< The client has been sent the position packet, waiting for them to repeat the position back
csPlaying , ///< Normal gameplay
csDestroying , ///< The client is being destroyed, don't queue any more packets / don't add to chunks
2013-08-20 16:27:29 -04:00
csDestroyedWaiting , ///< The client has been destroyed, but is still kept so that the Kick packet is delivered (#31)
2013-08-13 16:45:29 -04:00
csDestroyed , ///< The client has been destroyed, the destructor is to be called from the owner thread
2012-06-14 09:06:06 -04:00
2012-11-11 09:00:58 -05:00
// TODO: Add Kicking here as well
2012-06-14 09:06:06 -04:00
} ;
eState m_State ;
2013-08-13 16:45:29 -04:00
2014-02-20 17:24:39 -05:00
/** m_State needs to be locked in the Destroy() function so that the destruction code doesn't run twice on two different threads */
2013-08-13 16:45:29 -04:00
cCriticalSection m_CSDestroyingState ;
2012-06-14 09:06:06 -04:00
2014-02-20 17:24:39 -05:00
/** If set to true during csDownloadingWorld, the tick thread calls CheckIfWorldDownloaded() */
2012-08-31 12:26:03 -04:00
bool m_ShouldCheckDownloaded ;
2012-06-14 09:06:06 -04:00
2014-02-04 18:40:58 -05:00
/** Number of explosions sent this tick */
int m_NumExplosionsThisTick ;
2014-03-01 16:24:36 -05:00
/** Number of place or break interactions this tick */
int m_NumBlockChangeInteractionsThisTick ;
2013-06-18 15:32:31 -04:00
2013-07-28 13:15:03 -04:00
static int s_ClientCount ;
int m_UniqueID ;
2014-04-13 07:04:56 -04:00
AString m_UUID ;
2013-07-03 03:47:35 -04:00
2014-02-20 17:24:39 -05:00
/** Set to true when the chunk where the player is is sent to the client. Used for spawning the player */
2013-09-08 12:36:06 -04:00
bool m_HasSentPlayerChunk ;
2014-02-16 07:26:07 -05:00
2014-02-20 17:24:39 -05:00
/** Client Settings */
2014-02-16 07:26:07 -05:00
AString m_Locale ;
2014-02-20 17:24:39 -05:00
/** The plugin channels that the client has registered. */
cChannels m_PluginChannels ;
2013-06-18 15:32:31 -04:00
2014-02-20 17:24:39 -05:00
/** Returns true if the rate block interactions is within a reasonable limit (bot protection) */
2012-06-14 09:06:06 -04:00
bool CheckBlockInteractionsRate ( void ) ;
2014-02-20 17:24:39 -05:00
/** Adds a single chunk to be streamed to the client; used by StreamChunks() */
2013-04-13 17:02:10 -04:00
void StreamChunk ( int a_ChunkX , int a_ChunkZ ) ;
2012-06-14 09:06:06 -04:00
2014-02-20 17:24:39 -05:00
/** Handles the DIG_STARTED dig packet: */
2014-02-04 13:59:05 -05:00
void HandleBlockDigStarted ( int a_BlockX , int a_BlockY , int a_BlockZ , eBlockFace a_BlockFace , BLOCKTYPE a_OldBlock , NIBBLETYPE a_OldMeta ) ;
2013-01-11 23:46:01 -05:00
2014-02-20 17:24:39 -05:00
/** Handles the DIG_FINISHED dig packet: */
2014-02-04 13:59:05 -05:00
void HandleBlockDigFinished ( int a_BlockX , int a_BlockY , int a_BlockZ , eBlockFace a_BlockFace , BLOCKTYPE a_OldBlock , NIBBLETYPE a_OldMeta ) ;
2014-01-18 12:58:46 -05:00
2014-05-11 05:56:15 -04:00
/** The clients will receive a finished dig animation */
void FinishDigAnimation ( ) ;
2014-05-09 17:10:02 -04:00
2014-02-20 17:24:39 -05:00
/** Converts the protocol-formatted channel list (NUL-separated) into a proper string vector. */
AStringVector BreakApartPluginChannels ( const AString & a_PluginChannels ) ;
/** Adds all of the channels to the list of current plugin channels. Handles duplicates gracefully. */
void RegisterPluginChannels ( const AStringVector & a_ChannelList ) ;
/** Removes all of the channels from the list of current plugin channels. Ignores channels that are not found. */
void UnregisterPluginChannels ( const AStringVector & a_ChannelList ) ;
/** Handles the "MC|AdvCdm" plugin message */
2014-05-01 17:03:23 -04:00
void HandleCommandBlockMessage ( const char * a_Data , size_t a_Length ) ;
2014-04-30 19:25:04 -04:00
/** Handles the "MC|ItemName" plugin message */
void HandleAnvilItemName ( const char * a_Data , size_t a_Length ) ;
2013-07-03 03:47:35 -04:00
2012-06-14 09:06:06 -04:00
// cSocketThreads::cCallback overrides:
2014-05-01 09:08:15 -04:00
virtual bool DataReceived ( const char * a_Data , size_t a_Size ) override ; // Data is received from the client
2012-06-14 09:06:06 -04:00
virtual void GetOutgoingData ( AString & a_Data ) override ; // Data can be sent to client
virtual void SocketClosed ( void ) override ; // The socket has been closed for any reason
} ; // tolua_export
# endif // CCLIENTHANDLE_H_INCLUDED