Added cMojangAPI:GetUUIDFromPlayerName().
This is a simpler way to ask for a single name -> uuid conversion.
This commit is contained in:
parent
36d1972336
commit
003f18bd0f
@ -1630,6 +1630,7 @@ a_Player:OpenWindow(Window);
|
|||||||
Functions =
|
Functions =
|
||||||
{
|
{
|
||||||
AddPlayerNameToUUIDMapping = { Params = "PlayerName, UUID", Return = "", Notes = "Adds the specified PlayerName-to-UUID mapping into the cache, with current timestamp." },
|
AddPlayerNameToUUIDMapping = { Params = "PlayerName, UUID", Return = "", Notes = "Adds the specified PlayerName-to-UUID mapping into the cache, with current timestamp." },
|
||||||
|
GetUUIDFromPlayerName = { Params = "PlayerName, [UseOnlyCached]", Return = "UUID", Notes = "Returns the UUID that corresponds to the given playername, or an empty string on error. If UseOnlyCached is false (the default), queries the Mojang servers if the playername is not in the cache. <br /><b>WARNING</b>: Do NOT use this function with UseOnlyCached set to false while the server is running. Only use it when the server is starting up (inside the Initialize() method), otherwise you will lag the server severely." },
|
||||||
GetUUIDsFromPlayerNames = { Params = "PlayerNames, [UseOnlyCached]", Return = "table", Notes = "Returns a table that contains the map, 'PlayerName' -> 'UUID', for all valid playernames in the input array-table. PlayerNames not recognized will not be set in the returned map. If UseOnlyCached is false (the default), queries the Mojang servers for the results that are not in the cache. <br /><b>WARNING</b>: Do NOT use this function with UseOnlyCached set to false while the server is running. Only use it when the server is starting up (inside the Initialize() method), otherwise you will lag the server severely." },
|
GetUUIDsFromPlayerNames = { Params = "PlayerNames, [UseOnlyCached]", Return = "table", Notes = "Returns a table that contains the map, 'PlayerName' -> 'UUID', for all valid playernames in the input array-table. PlayerNames not recognized will not be set in the returned map. If UseOnlyCached is false (the default), queries the Mojang servers for the results that are not in the cache. <br /><b>WARNING</b>: Do NOT use this function with UseOnlyCached set to false while the server is running. Only use it when the server is starting up (inside the Initialize() method), otherwise you will lag the server severely." },
|
||||||
MakeUUIDDashed = { Params = "UUID", Return = "DashedUUID", Notes = "(STATIC) Converts the UUID to a dashed format (\"01234567-8901-2345-6789-012345678901\"). Accepts both dashed and short UUIDs. Logs a warning and returns an empty string if UUID format not recognized." },
|
MakeUUIDDashed = { Params = "UUID", Return = "DashedUUID", Notes = "(STATIC) Converts the UUID to a dashed format (\"01234567-8901-2345-6789-012345678901\"). Accepts both dashed and short UUIDs. Logs a warning and returns an empty string if UUID format not recognized." },
|
||||||
MakeUUIDShort = { Params = "UUID", Return = "ShortUUID", Notes = "(STATIC) Converts the UUID to a short format (without dashes, \"01234567890123456789012345678901\"). Accepts both dashed and short UUIDs. Logs a warning and returns an empty string if UUID format not recognized." },
|
MakeUUIDShort = { Params = "UUID", Return = "ShortUUID", Notes = "(STATIC) Converts the UUID to a short format (without dashes, \"01234567890123456789012345678901\"). Accepts both dashed and short UUIDs. Logs a warning and returns an empty string if UUID format not recognized." },
|
||||||
|
@ -129,6 +129,34 @@ void cMojangAPI::Start(cIniFile & a_SettingsIni)
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
AString cMojangAPI::GetUUIDFromPlayerName(const AString & a_PlayerName, bool a_UseOnlyCached)
|
||||||
|
{
|
||||||
|
// Convert the playername to lowercase:
|
||||||
|
AString lcPlayerName(a_PlayerName);
|
||||||
|
StrToLower(lcPlayerName);
|
||||||
|
|
||||||
|
// Request the cache to populate any names not yet contained:
|
||||||
|
if (!a_UseOnlyCached)
|
||||||
|
{
|
||||||
|
AStringVector PlayerNames;
|
||||||
|
PlayerNames.push_back(lcPlayerName);
|
||||||
|
CacheNamesToUUIDs(PlayerNames);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Retrieve from cache:
|
||||||
|
cNameToUUIDMap::const_iterator itr = m_NameToUUID.find(lcPlayerName);
|
||||||
|
if (itr == m_NameToUUID.end())
|
||||||
|
{
|
||||||
|
// No UUID found
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
return itr->second.m_PlayerName;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
AStringVector cMojangAPI::GetUUIDsFromPlayerNames(const AStringVector & a_PlayerNames, bool a_UseOnlyCached)
|
AStringVector cMojangAPI::GetUUIDsFromPlayerNames(const AStringVector & a_PlayerNames, bool a_UseOnlyCached)
|
||||||
{
|
{
|
||||||
// Convert all playernames to lowercase:
|
// Convert all playernames to lowercase:
|
||||||
|
@ -45,6 +45,13 @@ public:
|
|||||||
Note: only checks the string's length, not the actual content. */
|
Note: only checks the string's length, not the actual content. */
|
||||||
static AString MakeUUIDDashed(const AString & a_UUID);
|
static AString MakeUUIDDashed(const AString & a_UUID);
|
||||||
|
|
||||||
|
/** Converts a player name into a UUID.
|
||||||
|
The UUID will be empty on error.
|
||||||
|
If a_UseOnlyCached is true, the function only consults the cached values.
|
||||||
|
If a_UseOnlyCached is false and the name is not found in the cache, it is looked up online, which is a blocking
|
||||||
|
operation, do not use this in world-tick thread! */
|
||||||
|
AString GetUUIDFromPlayerName(const AString & a_PlayerName, bool a_UseOnlyCached = false);
|
||||||
|
|
||||||
// tolua_end
|
// tolua_end
|
||||||
|
|
||||||
/** Converts the player names into UUIDs.
|
/** Converts the player names into UUIDs.
|
||||||
|
Loading…
Reference in New Issue
Block a user