Merge branch 'master' of https://github.com/mc-server/MCServer
This commit is contained in:
commit
c13cffcd30
@ -1,6 +1,6 @@
|
|||||||
Many people have contributed to MCServer, and this list attempts to broadcast at least some of them.
|
Many people have contributed to MCServer, and this list attempts to broadcast at least some of them.
|
||||||
|
|
||||||
BasedDoge - Donated AlchemistVillage prefabs
|
BasedDoge (Donated AlchemistVillage prefabs)
|
||||||
bearbin (Alexander Harkness)
|
bearbin (Alexander Harkness)
|
||||||
derouinw
|
derouinw
|
||||||
Diusrex
|
Diusrex
|
||||||
@ -27,6 +27,6 @@ tonibm19
|
|||||||
UltraCoderRU
|
UltraCoderRU
|
||||||
worktycho
|
worktycho
|
||||||
xoft
|
xoft
|
||||||
Yeeeeezus - Donated AlchemistVillage prefabs
|
Yeeeeezus (Donated AlchemistVillage prefabs)
|
||||||
|
|
||||||
Please add yourself to this list if you contribute to MCServer.
|
Please add yourself to this list if you contribute to MCServer.
|
||||||
|
@ -523,13 +523,16 @@ end
|
|||||||
|
|
||||||
Functions =
|
Functions =
|
||||||
{
|
{
|
||||||
|
GenerateOfflineUUID = { Params = "Username", Return = "string", Notes = "(STATIC) Generates an UUID based on the player name provided. 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. Returns a 36-char UUID (with dashes)." },
|
||||||
GetLocale = { Params = "", Return = "Locale", Notes = "Returns the locale string that the client sends as part of the protocol handshake. Can be used to provide localized strings." },
|
GetLocale = { Params = "", Return = "Locale", Notes = "Returns the locale string that the client sends as part of the protocol handshake. Can be used to provide localized strings." },
|
||||||
GetPing = { Params = "", Return = "number", Notes = "Returns the ping time, in ms" },
|
GetPing = { Params = "", Return = "number", Notes = "Returns the ping time, in ms" },
|
||||||
GetPlayer = { Params = "", Return = "{{cPlayer|cPlayer}}", Notes = "Returns the player object connected to this client. Note that this may be nil, for example if the player object is not yet spawned." },
|
GetPlayer = { Params = "", Return = "{{cPlayer|cPlayer}}", Notes = "Returns the player object connected to this client. Note that this may be nil, for example if the player object is not yet spawned." },
|
||||||
GetUniqueID = { Params = "", Return = "number", Notes = "Returns the UniqueID of the client used to identify the client in the server" },
|
GetUniqueID = { Params = "", Return = "number", Notes = "Returns the UniqueID of the client used to identify the client in the server" },
|
||||||
|
GetUUID = { Params = "", Return = "string", Notes = "Returns the authentication-based UUID of the client. This UUID should be used to identify the player when persisting any player-related data." },
|
||||||
GetUsername = { Params = "", Return = "string", Notes = "Returns the username that the client has provided" },
|
GetUsername = { Params = "", Return = "string", Notes = "Returns the username that the client has provided" },
|
||||||
GetViewDistance = { Params = "", Return = "number", Notes = "Returns the viewdistance (number of chunks loaded for the player in each direction)" },
|
GetViewDistance = { Params = "", Return = "number", Notes = "Returns the viewdistance (number of chunks loaded for the player in each direction)" },
|
||||||
HasPluginChannel = { Params = "ChannelName", Return = "bool", Notes = "Returns true if the client has registered to receive messages on the specified plugin channel." },
|
HasPluginChannel = { Params = "ChannelName", Return = "bool", Notes = "Returns true if the client has registered to receive messages on the specified plugin channel." },
|
||||||
|
IsUUIDOnline = { Params = "UUID", Return = "bool", Notes = "(STATIC) 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."},
|
||||||
Kick = { Params = "Reason", Return = "", Notes = "Kicks the user with the specified reason" },
|
Kick = { Params = "Reason", Return = "", Notes = "Kicks the user with the specified reason" },
|
||||||
SendPluginMessage = { Params = "Channel, Message", Return = "", Notes = "Sends the plugin message on the specified channel." },
|
SendPluginMessage = { Params = "Channel, Message", Return = "", Notes = "Sends the plugin message on the specified channel." },
|
||||||
SetLocale = { Params = "Locale", Return = "", Notes = "Sets the locale that MCServer keeps on record. Initially the locale is initialized in protocol handshake, this function allows plugins to override the stored value (but only server-side and only until the user disconnects)." },
|
SetLocale = { Params = "Locale", Return = "", Notes = "Sets the locale that MCServer keeps on record. Initially the locale is initialized in protocol handshake, this function allows plugins to override the stored value (but only server-side and only until the user disconnects)." },
|
||||||
|
@ -232,6 +232,9 @@ AString cClientHandle::FormatMessageType(bool ShouldAppendChatPrefixes, eMessage
|
|||||||
|
|
||||||
AString cClientHandle::GenerateOfflineUUID(const AString & a_Username)
|
AString cClientHandle::GenerateOfflineUUID(const AString & a_Username)
|
||||||
{
|
{
|
||||||
|
// Online UUIDs are always version 4 (random)
|
||||||
|
// We use Version 3 (MD5 hash) UUIDs for the offline UUIDs
|
||||||
|
// This guarantees that they will never collide with an online UUID and can be distinguished.
|
||||||
// Proper format for a version 3 UUID is:
|
// Proper format for a version 3 UUID is:
|
||||||
// xxxxxxxx-xxxx-3xxx-yxxx-xxxxxxxxxxxx where x is any hexadecimal digit and y is one of 8, 9, A, or B
|
// xxxxxxxx-xxxx-3xxx-yxxx-xxxxxxxxxxxx where x is any hexadecimal digit and y is one of 8, 9, A, or B
|
||||||
|
|
||||||
@ -254,6 +257,32 @@ AString cClientHandle::GenerateOfflineUUID(const AString & a_Username)
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
bool cClientHandle::IsUUIDOnline(const AString & a_UUID)
|
||||||
|
{
|
||||||
|
// Online UUIDs are always version 4 (random)
|
||||||
|
// We use Version 3 (MD5 hash) UUIDs for the offline UUIDs
|
||||||
|
// This guarantees that they will never collide with an online UUID and can be distinguished.
|
||||||
|
// The version-specifying char is at pos #12 of raw UUID, pos #14 in dashed-UUID.
|
||||||
|
switch (a_UUID.size())
|
||||||
|
{
|
||||||
|
case 32:
|
||||||
|
{
|
||||||
|
// This is the UUID format without dashes, the version char is at pos #12:
|
||||||
|
return (a_UUID[12] == '4');
|
||||||
|
}
|
||||||
|
case 36:
|
||||||
|
{
|
||||||
|
// This is the UUID format with dashes, the version char is at pos #14:
|
||||||
|
return (a_UUID[14] == '4');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
void cClientHandle::Kick(const AString & a_Reason)
|
void cClientHandle::Kick(const AString & a_Reason)
|
||||||
{
|
{
|
||||||
if (m_State >= csAuthenticating) // Don't log pings
|
if (m_State >= csAuthenticating) // Don't log pings
|
||||||
|
@ -63,7 +63,7 @@ public:
|
|||||||
|
|
||||||
const AString & GetIPString(void) const { return m_IPString; }
|
const AString & GetIPString(void) const { return m_IPString; }
|
||||||
|
|
||||||
cPlayer* GetPlayer() { return m_Player; } // tolua_export
|
cPlayer * GetPlayer(void) { return m_Player; } // tolua_export
|
||||||
|
|
||||||
const AString & GetUUID(void) const { return m_UUID; } // tolua_export
|
const AString & GetUUID(void) const { return m_UUID; } // tolua_export
|
||||||
void SetUUID(const AString & a_UUID) { m_UUID = a_UUID; }
|
void SetUUID(const AString & a_UUID) { m_UUID = a_UUID; }
|
||||||
@ -76,9 +76,16 @@ public:
|
|||||||
|
|
||||||
/** Generates an UUID based on the player name provided.
|
/** Generates an UUID based on the player name provided.
|
||||||
This is used for the offline (non-auth) mode, when there's no UUID source.
|
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. */
|
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). */
|
||||||
static AString GenerateOfflineUUID(const AString & a_Username); // tolua_export
|
static AString GenerateOfflineUUID(const AString & a_Username); // tolua_export
|
||||||
|
|
||||||
|
/** 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
|
||||||
|
|
||||||
/** Formats the type of message with the proper color and prefix for sending to the client. **/
|
/** Formats the type of message with the proper color and prefix for sending to the client. **/
|
||||||
static AString FormatMessageType(bool ShouldAppendChatPrefixes, eMessageType a_ChatPrefix, const AString & a_AdditionalData);
|
static AString FormatMessageType(bool ShouldAppendChatPrefixes, eMessageType a_ChatPrefix, const AString & a_AdditionalData);
|
||||||
|
|
||||||
|
@ -348,6 +348,7 @@ void cIncrementalRedstoneSimulator::SimulateChunk(float a_Dt, int a_ChunkX, int
|
|||||||
case E_BLOCK_REDSTONE_REPEATER_ON:
|
case E_BLOCK_REDSTONE_REPEATER_ON:
|
||||||
{
|
{
|
||||||
HandleRedstoneRepeater(dataitr->x, dataitr->y, dataitr->z, dataitr->Data);
|
HandleRedstoneRepeater(dataitr->x, dataitr->y, dataitr->z, dataitr->Data);
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
case E_BLOCK_REDSTONE_TORCH_OFF:
|
case E_BLOCK_REDSTONE_TORCH_OFF:
|
||||||
case E_BLOCK_REDSTONE_TORCH_ON:
|
case E_BLOCK_REDSTONE_TORCH_ON:
|
||||||
@ -763,7 +764,7 @@ void cIncrementalRedstoneSimulator::HandleRedstoneRepeater(int a_RelBlockX, int
|
|||||||
|
|
||||||
void cIncrementalRedstoneSimulator::HandleRedstoneRepeaterDelays()
|
void cIncrementalRedstoneSimulator::HandleRedstoneRepeaterDelays()
|
||||||
{
|
{
|
||||||
for (RepeatersDelayList::iterator itr = m_RepeatersDelayList->begin(); itr != m_RepeatersDelayList->end(); itr++)
|
for (RepeatersDelayList::iterator itr = m_RepeatersDelayList->begin(); itr != m_RepeatersDelayList->end();)
|
||||||
{
|
{
|
||||||
|
|
||||||
if (itr->a_ElapsedTicks >= itr->a_DelayTicks) // Has the elapsed ticks reached the target ticks?
|
if (itr->a_ElapsedTicks >= itr->a_DelayTicks) // Has the elapsed ticks reached the target ticks?
|
||||||
@ -809,7 +810,7 @@ void cIncrementalRedstoneSimulator::HandleRedstoneRepeaterDelays()
|
|||||||
{
|
{
|
||||||
m_Chunk->SetBlock(RelBlockX, RelBlockY, RelBlockZ, E_BLOCK_REDSTONE_REPEATER_OFF, Meta);
|
m_Chunk->SetBlock(RelBlockX, RelBlockY, RelBlockZ, E_BLOCK_REDSTONE_REPEATER_OFF, Meta);
|
||||||
}
|
}
|
||||||
m_RepeatersDelayList->erase(itr);
|
itr = m_RepeatersDelayList->erase(itr);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -818,6 +819,7 @@ void cIncrementalRedstoneSimulator::HandleRedstoneRepeaterDelays()
|
|||||||
// I am confounded to say why. Perhaps optimisation failure.
|
// I am confounded to say why. Perhaps optimisation failure.
|
||||||
LOGD("Incremented a repeater @ {%i %i %i} | Elapsed ticks: %i | Target delay: %i", itr->a_RelBlockPos.x, itr->a_RelBlockPos.y, itr->a_RelBlockPos.z, itr->a_ElapsedTicks, itr->a_DelayTicks);
|
LOGD("Incremented a repeater @ {%i %i %i} | Elapsed ticks: %i | Target delay: %i", itr->a_RelBlockPos.x, itr->a_RelBlockPos.y, itr->a_RelBlockPos.z, itr->a_ElapsedTicks, itr->a_DelayTicks);
|
||||||
itr->a_ElapsedTicks++;
|
itr->a_ElapsedTicks++;
|
||||||
|
itr++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user