Allow BindIdentity and FindAdminByIdentity to take more SteamID formats for steam auth type
This commit is contained in:
		
							parent
							
								
									ec46e12c50
								
							
						
					
					
						commit
						892edd9650
					
				@ -218,6 +218,8 @@ class SMConfig(object):
 | 
				
			|||||||
        '_CRT_NONSTDC_NO_DEPRECATE',
 | 
					        '_CRT_NONSTDC_NO_DEPRECATE',
 | 
				
			||||||
        '_ITERATOR_DEBUG_LEVEL=0',
 | 
					        '_ITERATOR_DEBUG_LEVEL=0',
 | 
				
			||||||
      ]
 | 
					      ]
 | 
				
			||||||
 | 
					      if cxx.version < 1800:
 | 
				
			||||||
 | 
					        cxx.defines += 'strtoull=_strtoui64'
 | 
				
			||||||
      cxx.cflags += [
 | 
					      cxx.cflags += [
 | 
				
			||||||
        '/W3',
 | 
					        '/W3',
 | 
				
			||||||
      ]
 | 
					      ]
 | 
				
			||||||
 | 
				
			|||||||
@ -1056,6 +1056,58 @@ bool AdminCache::GetMethodIndex(const char *name, unsigned int *_index)
 | 
				
			|||||||
	return false;
 | 
						return false;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/*
 | 
				
			||||||
 | 
					 * Converts Steam2 id, Steam3 id, or SteamId64 to unified, legacy
 | 
				
			||||||
 | 
					 * admin identity format. (account id part of Steam2 format)
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					bool AdminCache::GetUnifiedSteamIdentity(const char *ident, char *out, size_t maxlen)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						int len = strlen(ident);
 | 
				
			||||||
 | 
						/* If the id was a steam id strip off the STEAM_*: part */
 | 
				
			||||||
 | 
						if (len >= 11 && !strncmp(ident, "STEAM_", 6) && ident[8] != '_')
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							// non-bot/lan Steam2 Id
 | 
				
			||||||
 | 
							snprintf(out, maxlen, "%s", ident[8]);
 | 
				
			||||||
 | 
							return true;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						else if (len >= 7 && !strncmp(ident, "[U:", 3) && ident[len-1] == ']')
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							// Steam3 Id
 | 
				
			||||||
 | 
							uint32_t accountId = strtoul(&ident[5], nullptr, 10);
 | 
				
			||||||
 | 
							snprintf(out, maxlen, "%u:%u", accountId & 1, accountId >> 1);
 | 
				
			||||||
 | 
							return true;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						else
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
							// some constants from steamclientpublic.h
 | 
				
			||||||
 | 
							static const uint32_t k_EAccountTypeIndividual = 1;
 | 
				
			||||||
 | 
							static const int k_EUniverseInvalid = 0;
 | 
				
			||||||
 | 
							static const int k_EUniverseMax = 5;
 | 
				
			||||||
 | 
							static const unsigned int k_unSteamUserWebInstance	= 4;
 | 
				
			||||||
 | 
							
 | 
				
			||||||
 | 
							uint64_t steamId = strtoull(ident, nullptr, 10);
 | 
				
			||||||
 | 
							if (steamId > 0)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								// Make some attempt at being sure it's a valid id rather than other number,
 | 
				
			||||||
 | 
								// even though we're only going to use the lower 32 bits.
 | 
				
			||||||
 | 
								uint32_t accountId = steamId & 0xFFFFFFFF;
 | 
				
			||||||
 | 
								uint32_t accountType = (steamId >> 52) & 0xF;
 | 
				
			||||||
 | 
								int universe = steamId >> 56;
 | 
				
			||||||
 | 
								uint32_t accountInstance = (steamId >> 32) & 0xFFFFF;
 | 
				
			||||||
 | 
								if (accountId > 0
 | 
				
			||||||
 | 
									&& universe > k_EUniverseInvalid && universe < k_EUniverseMax
 | 
				
			||||||
 | 
									&& accountType == k_EAccountTypeIndividual && accountInstance <= k_unSteamUserWebInstance
 | 
				
			||||||
 | 
									)
 | 
				
			||||||
 | 
								{
 | 
				
			||||||
 | 
									snprintf(out, maxlen, "%u:%u", accountId & 1, accountId >> 1);
 | 
				
			||||||
 | 
									return true;
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						return false;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
bool AdminCache::BindAdminIdentity(AdminId id, const char *auth, const char *ident)
 | 
					bool AdminCache::BindAdminIdentity(AdminId id, const char *auth, const char *ident)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	if (ident[0] == '\0')
 | 
						if (ident[0] == '\0')
 | 
				
			||||||
@ -1073,10 +1125,14 @@ bool AdminCache::BindAdminIdentity(AdminId id, const char *auth, const char *ide
 | 
				
			|||||||
	if (!m_AuthTables.retrieve(auth, &method))
 | 
						if (!m_AuthTables.retrieve(auth, &method))
 | 
				
			||||||
		return false;
 | 
							return false;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	/* If the id was a steam id strip off the STEAM_*: part */
 | 
						/* If the auth type is steam, the id could be in a number of formats. Unify it. */
 | 
				
			||||||
	if (strcmp(auth, "steam") == 0 && strncmp(ident, "STEAM_", 6) == 0)
 | 
						char steamIdent[16];
 | 
				
			||||||
 | 
						if (strcmp(auth, "steam") == 0)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
		ident += 8;
 | 
							if (!GetUnifiedSteamIdentity(ident, steamIdent, sizeof(steamIdent)))
 | 
				
			||||||
 | 
								return false;
 | 
				
			||||||
 | 
							
 | 
				
			||||||
 | 
							ident = steamIdent;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (method->identities.contains(ident))
 | 
						if (method->identities.contains(ident))
 | 
				
			||||||
@ -1097,10 +1153,14 @@ AdminId AdminCache::FindAdminByIdentity(const char *auth, const char *identity)
 | 
				
			|||||||
	if (!m_AuthTables.retrieve(auth, &method))
 | 
						if (!m_AuthTables.retrieve(auth, &method))
 | 
				
			||||||
		return INVALID_ADMIN_ID;
 | 
							return INVALID_ADMIN_ID;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	/* If the id was a steam id strip off the STEAM_*: part */
 | 
						/* If the auth type is steam, the id could be in a number of formats. Unify it. */
 | 
				
			||||||
	if (strcmp(auth, "steam") == 0 && strncmp(identity, "STEAM_", 6) == 0)
 | 
						char steamIdent[16];
 | 
				
			||||||
 | 
						if (strcmp(auth, "steam") == 0)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
		identity += 8;
 | 
							if (!GetUnifiedSteamIdentity(identity, steamIdent, sizeof(steamIdent)))
 | 
				
			||||||
 | 
								return INVALID_ADMIN_ID;
 | 
				
			||||||
 | 
							
 | 
				
			||||||
 | 
							identity = steamIdent;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	AdminId id;
 | 
						AdminId id;
 | 
				
			||||||
 | 
				
			|||||||
@ -198,6 +198,7 @@ private:
 | 
				
			|||||||
	bool GetMethodIndex(const char *name, unsigned int *_index);
 | 
						bool GetMethodIndex(const char *name, unsigned int *_index);
 | 
				
			||||||
	const char *GetMethodName(unsigned int index);
 | 
						const char *GetMethodName(unsigned int index);
 | 
				
			||||||
	void NameFlag(const char *str, AdminFlag flag);
 | 
						void NameFlag(const char *str, AdminFlag flag);
 | 
				
			||||||
 | 
						bool GetUnifiedSteamIdentity(const char *ident, char *out, size_t maxlen);
 | 
				
			||||||
public:
 | 
					public:
 | 
				
			||||||
	typedef StringHashMap<FlagBits> FlagMap;
 | 
						typedef StringHashMap<FlagBits> FlagMap;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -356,7 +356,7 @@ native GetAdminUsername(AdminId:id, String:name[], maxlength);
 | 
				
			|||||||
 * @param auth			Auth method to use, predefined or from RegisterAuthIdentType().
 | 
					 * @param auth			Auth method to use, predefined or from RegisterAuthIdentType().
 | 
				
			||||||
 * @param ident			String containing the arbitrary, unique identity.
 | 
					 * @param ident			String containing the arbitrary, unique identity.
 | 
				
			||||||
 * @return				True on success, false if the auth method was not found,
 | 
					 * @return				True on success, false if the auth method was not found,
 | 
				
			||||||
 *						or ident was already taken.
 | 
					 *						ident was already taken, or ident invalid for auth method.
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
native bool:BindAdminIdentity(AdminId:id, const String:auth[], const String:ident[]);
 | 
					native bool:BindAdminIdentity(AdminId:id, const String:auth[], const String:ident[]);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
		Loading…
	
		Reference in New Issue
	
	Block a user