removed the other forum integration, just updated the normal one to use 1.11 sourcemod syntax
This commit is contained in:
		
							parent
							
								
									2abc67625c
								
							
						
					
					
						commit
						3e16e1a3c5
					
				| @ -9,6 +9,7 @@ | |||||||
| #include <SteamWorks> | #include <SteamWorks> | ||||||
| #include <unloze> | #include <unloze> | ||||||
| #include <UNLOZE.secret> //#define UNLOZE_APIKEY here | #include <UNLOZE.secret> //#define UNLOZE_APIKEY here | ||||||
|  | #include <cstrike> | ||||||
| 
 | 
 | ||||||
| #pragma newdecls required | #pragma newdecls required | ||||||
| 
 | 
 | ||||||
| @ -37,6 +38,7 @@ public Plugin myinfo = | |||||||
| //---------------------------------------------------------------------------------------------------- | //---------------------------------------------------------------------------------------------------- | ||||||
| public void OnPluginStart() | public void OnPluginStart() | ||||||
| { | { | ||||||
|  | 
 | ||||||
| 	/* Late load */ | 	/* Late load */ | ||||||
| 	for(int client = 1; client <= MaxClients; client++) | 	for(int client = 1; client <= MaxClients; client++) | ||||||
| 	{ | 	{ | ||||||
| @ -87,6 +89,7 @@ public Action OnRebuildAdminCachePost(Handle hTimer) | |||||||
| 		if(G_bResponsePassed[client] && G_bPreAdminChecked[client]) | 		if(G_bResponsePassed[client] && G_bPreAdminChecked[client]) | ||||||
| 			ApplyGroupFlags(client); | 			ApplyGroupFlags(client); | ||||||
| 	} | 	} | ||||||
|  |     return Plugin_Handled; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| //---------------------------------------------------------------------------------------------------- | //---------------------------------------------------------------------------------------------------- | ||||||
| @ -148,7 +151,7 @@ public int OnClientAuthorized_OnTransferComplete(Handle hRequest, bool bFailure, | |||||||
| 	if (!client) //Player disconnected. | 	if (!client) //Player disconnected. | ||||||
| 	{ | 	{ | ||||||
| 		delete hRequest; | 		delete hRequest; | ||||||
| 		return; | 		return 0; | ||||||
| 	} | 	} | ||||||
| 	 | 	 | ||||||
| 	if (bFailure || !bSuccessful || eStatusCode != k_EHTTPStatusCode200OK) | 	if (bFailure || !bSuccessful || eStatusCode != k_EHTTPStatusCode200OK) | ||||||
| @ -159,10 +162,11 @@ public int OnClientAuthorized_OnTransferComplete(Handle hRequest, bool bFailure, | |||||||
| 			NotifyPostAdminCheck(client); | 			NotifyPostAdminCheck(client); | ||||||
| 
 | 
 | ||||||
| 		delete hRequest; | 		delete hRequest; | ||||||
| 		return; | 		return 0; | ||||||
| 	} | 	} | ||||||
| 	 | 	 | ||||||
| 	SteamWorks_GetHTTPResponseBodyCallback(hRequest, OnClientAuthorized_OnTransferResponse, iSerial); | 	SteamWorks_GetHTTPResponseBodyCallback(hRequest, OnClientAuthorized_OnTransferResponse, iSerial); | ||||||
|  |     return 0; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| //---------------------------------------------------------------------------------------------------- | //---------------------------------------------------------------------------------------------------- | ||||||
| @ -175,7 +179,7 @@ public int OnClientAuthorized_OnTransferResponse(char[] sData, int iSerial) | |||||||
| 	int client = GetClientFromSerial(iSerial); | 	int client = GetClientFromSerial(iSerial); | ||||||
| 
 | 
 | ||||||
| 	if (!client) //Player disconnected. | 	if (!client) //Player disconnected. | ||||||
| 		return; | 		return 0; | ||||||
| 
 | 
 | ||||||
| 	TrimString(sData); | 	TrimString(sData); | ||||||
| 	StripQuotes(sData); | 	StripQuotes(sData); | ||||||
| @ -197,6 +201,7 @@ public int OnClientAuthorized_OnTransferResponse(char[] sData, int iSerial) | |||||||
| 	} | 	} | ||||||
| 	else | 	else | ||||||
| 		G_bResponseFailed[client] = true; //users with just a forum name did not pass the VIP check! so the response "failed" (but we store their forum name for later!) | 		G_bResponseFailed[client] = true; //users with just a forum name did not pass the VIP check! so the response "failed" (but we store their forum name for later!) | ||||||
|  |     return 0; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| //---------------------------------------------------------------------------------------------------- | //---------------------------------------------------------------------------------------------------- | ||||||
| @ -240,6 +245,7 @@ stock void ApplyGroupFlags(int client) | |||||||
| 		SetUserAdmin(client, AdmID, true); | 		SetUserAdmin(client, AdmID, true); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
|     if ((GrpID = FindAdmGroup(G_sGroup[client])) != INVALID_GROUP_ID) |     if ((GrpID = FindAdmGroup(G_sGroup[client])) != INVALID_GROUP_ID) | ||||||
| 	{ | 	{ | ||||||
| 		if (AdminInheritGroup(AdmID, GrpID)) | 		if (AdminInheritGroup(AdmID, GrpID)) | ||||||
| @ -259,6 +265,7 @@ public int Native_GetClientForumName(Handle plugin, int numParams) | |||||||
| 	int client = GetNativeCell(1); | 	int client = GetNativeCell(1); | ||||||
| 	 | 	 | ||||||
| 	SetNativeString(2, G_sName[client], len+1); | 	SetNativeString(2, G_sName[client], len+1); | ||||||
|  |     return 0; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @ -270,8 +277,8 @@ public int Native_AsyncHasSteamIDReservedSlot(Handle plugin, int numParams) | |||||||
| 	char sSteamID32[32]; | 	char sSteamID32[32]; | ||||||
| 	GetNativeString(1, sSteamID32, sizeof(sSteamID32)); | 	GetNativeString(1, sSteamID32, sizeof(sSteamID32)); | ||||||
| 
 | 
 | ||||||
| 	AsyncHasSteamIDReservedSlotCallbackFunc callback; | 	Function callback; //https://github.com/alliedmodders/sourcepawn/issues/778 | ||||||
| 	callback = GetNativeCell(2); | 	callback = GetNativeFunction(2); | ||||||
| 
 | 
 | ||||||
| 	any data; | 	any data; | ||||||
| 	data = GetNativeCell(3); | 	data = GetNativeCell(3); | ||||||
| @ -296,6 +303,7 @@ public int Native_AsyncHasSteamIDReservedSlot(Handle plugin, int numParams) | |||||||
| 	{ | 	{ | ||||||
| 		delete hRequest; | 		delete hRequest; | ||||||
| 	} | 	} | ||||||
|  |     return 0; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| //---------------------------------------------------------------------------------------------------- | //---------------------------------------------------------------------------------------------------- | ||||||
| @ -309,10 +317,11 @@ public int Native_AsyncHasSteamIDReservedSlot_OnTransferComplete(Handle hRequest | |||||||
| 		Native_AsyncHasSteamIDReservedSlot_OnTransferResponse(sData, hDataPack); | 		Native_AsyncHasSteamIDReservedSlot_OnTransferResponse(sData, hDataPack); | ||||||
| 
 | 
 | ||||||
| 		delete hRequest; | 		delete hRequest; | ||||||
| 		return; | 		return 0; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	SteamWorks_GetHTTPResponseBodyCallback(hRequest, Native_AsyncHasSteamIDReservedSlot_OnTransferResponse, hDataPack); | 	SteamWorks_GetHTTPResponseBodyCallback(hRequest, Native_AsyncHasSteamIDReservedSlot_OnTransferResponse, hDataPack); | ||||||
|  |     return 0; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| //---------------------------------------------------------------------------------------------------- | //---------------------------------------------------------------------------------------------------- | ||||||
| @ -325,8 +334,8 @@ public int Native_AsyncHasSteamIDReservedSlot_OnTransferResponse(char[] sData, D | |||||||
| 	char sSteamID32[32]; | 	char sSteamID32[32]; | ||||||
| 	hDataPack.ReadString(sSteamID32, sizeof(sSteamID32)); | 	hDataPack.ReadString(sSteamID32, sizeof(sSteamID32)); | ||||||
| 
 | 
 | ||||||
| 	AsyncHasSteamIDReservedSlotCallbackFunc callback; | 	Function callback; | ||||||
| 	callback = view_as<AsyncHasSteamIDReservedSlotCallbackFunc>(hDataPack.ReadFunction()); | 	callback = hDataPack.ReadFunction(); | ||||||
| 
 | 
 | ||||||
| 	Handle plugin; | 	Handle plugin; | ||||||
| 	plugin = hDataPack.ReadCell(); | 	plugin = hDataPack.ReadCell(); | ||||||
| @ -354,7 +363,7 @@ public int Native_AsyncHasSteamIDReservedSlot_OnTransferResponse(char[] sData, D | |||||||
| 	Call_Finish(); | 	Call_Finish(); | ||||||
| 
 | 
 | ||||||
| 	delete hDataPack; | 	delete hDataPack; | ||||||
| 	return; | 	return 0; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| //---------------------------------------------------------------------------------------------------- | //---------------------------------------------------------------------------------------------------- | ||||||
| @ -384,3 +393,11 @@ stock bool SteamID32toSteamID64(const char[] sSteamID32, char[] sSteamID64, int | |||||||
| 
 | 
 | ||||||
| 	return true; | 	return true; | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | stock bool IsValidClient(int client) | ||||||
|  | { | ||||||
|  |     if (client > 0 && client <= MaxClients && IsClientConnected(client) && IsClientInGame(client)) | ||||||
|  |         return true; | ||||||
|  |     return false; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | |||||||
| @ -1,422 +0,0 @@ | |||||||
| //==================================================================================================== |  | ||||||
| // |  | ||||||
| // Name: UNLOZE Forum Integration. |  | ||||||
| // Author: .George & zaCade (Original by Botox) |  | ||||||
| // Description: Handles forum access ingame. |  | ||||||
| // |  | ||||||
| //==================================================================================================== |  | ||||||
| #include <sourcemod> |  | ||||||
| #include <SteamWorks> |  | ||||||
| #include <unloze> |  | ||||||
| #include <UNLOZE.secret> //#define UNLOZE_APIKEY here |  | ||||||
| #include <cstrike> |  | ||||||
| #include <BotTargeting> |  | ||||||
| 
 |  | ||||||
| #pragma newdecls required |  | ||||||
| 
 |  | ||||||
| /* STRINGS */ |  | ||||||
| char G_sGroup[MAXPLAYERS+1][64]; |  | ||||||
| char G_sName[MAXPLAYERS+1][32]; |  | ||||||
| 
 |  | ||||||
| /* BOOLS */ |  | ||||||
| bool G_bPreAdminChecked[MAXPLAYERS+1]; |  | ||||||
| bool G_bResponseFailed[MAXPLAYERS+1]; |  | ||||||
| bool G_bResponsePassed[MAXPLAYERS+1]; |  | ||||||
| 
 |  | ||||||
| //---------------------------------------------------------------------------------------------------- |  | ||||||
| // Purpose: |  | ||||||
| //---------------------------------------------------------------------------------------------------- |  | ||||||
| public Plugin myinfo = |  | ||||||
| { |  | ||||||
| 	name		 = "UNLOZE Forum Integration", |  | ||||||
| 	author	   = ".George & zaCade (Original by Botox)", |  | ||||||
| 	description  = "Handles forum access ingame", |  | ||||||
| 	version	  = "1.2.1" |  | ||||||
| }; |  | ||||||
| 
 |  | ||||||
| //---------------------------------------------------------------------------------------------------- |  | ||||||
| // Purpose: Late load |  | ||||||
| //---------------------------------------------------------------------------------------------------- |  | ||||||
| public void OnPluginStart() |  | ||||||
| { |  | ||||||
| 
 |  | ||||||
| 	/* Late load */ |  | ||||||
| 	for(int client = 1; client <= MaxClients; client++) |  | ||||||
| 	{ |  | ||||||
| 		if(IsClientConnected(client)) |  | ||||||
| 			OnClientConnected(client); |  | ||||||
| 
 |  | ||||||
| 		if(IsClientAuthorized(client) && !IsFakeClient(client)) |  | ||||||
| 		{ |  | ||||||
| 			char sSteamID32[32]; |  | ||||||
| 			if(GetClientAuthId(client, AuthId_Steam2, sSteamID32, sizeof(sSteamID32))) |  | ||||||
| 				OnClientAuthorized(client, sSteamID32); |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| //---------------------------------------------------------------------------------------------------- |  | ||||||
| // Purpose: |  | ||||||
| //---------------------------------------------------------------------------------------------------- |  | ||||||
| public APLRes AskPluginLoad2(Handle myself, bool late, char[] error, int err_max) |  | ||||||
| { |  | ||||||
| 	CreateNative("AsyncHasSteamIDReservedSlot", Native_AsyncHasSteamIDReservedSlot); |  | ||||||
| 	CreateNative("GetClientForumName", Native_GetClientForumName); |  | ||||||
| 
 |  | ||||||
| 	RegPluginLibrary("UNLOZE_ForumIntegration"); |  | ||||||
| 
 |  | ||||||
| 	return APLRes_Success; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| //---------------------------------------------------------------------------------------------------- |  | ||||||
| // Purpose: |  | ||||||
| //---------------------------------------------------------------------------------------------------- |  | ||||||
| public void OnRebuildAdminCache(AdminCachePart part) |  | ||||||
| { |  | ||||||
| 	if (part != AdminCache_Admins) |  | ||||||
| 		return; |  | ||||||
| 
 |  | ||||||
| 	CreateTimer(1.0, OnRebuildAdminCachePost, INVALID_HANDLE, TIMER_FLAG_NO_MAPCHANGE); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| //---------------------------------------------------------------------------------------------------- |  | ||||||
| // Purpose: |  | ||||||
| //---------------------------------------------------------------------------------------------------- |  | ||||||
| public Action OnRebuildAdminCachePost(Handle hTimer) |  | ||||||
| { |  | ||||||
| 	for (int client = 1; client <= MaxClients; client++) |  | ||||||
| 	{ |  | ||||||
| 		if(G_bResponsePassed[client] && G_bPreAdminChecked[client]) |  | ||||||
| 			ApplyGroupFlags(client); |  | ||||||
| 	} |  | ||||||
|     return Plugin_Handled; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| //---------------------------------------------------------------------------------------------------- |  | ||||||
| // Purpose: |  | ||||||
| //---------------------------------------------------------------------------------------------------- |  | ||||||
| public void OnClientConnected(int client) |  | ||||||
| { |  | ||||||
| 	G_bPreAdminChecked[client] = false; |  | ||||||
| 	G_bResponseFailed[client] = false; |  | ||||||
| 	G_bResponsePassed[client] = false; |  | ||||||
| 
 |  | ||||||
| 	G_sGroup[client][0] = 0; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| //---------------------------------------------------------------------------------------------------- |  | ||||||
| // Purpose: |  | ||||||
| //---------------------------------------------------------------------------------------------------- |  | ||||||
| public void OnClientDisconnect(int client) |  | ||||||
| { |  | ||||||
| 	G_bPreAdminChecked[client] = false; |  | ||||||
| 	G_bResponseFailed[client] = false; |  | ||||||
| 	G_bResponsePassed[client] = false; |  | ||||||
| 
 |  | ||||||
| 	G_sGroup[client][0] = 0; |  | ||||||
| 	G_sName[client][0] = 0; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| //---------------------------------------------------------------------------------------------------- |  | ||||||
| // Purpose: |  | ||||||
| //---------------------------------------------------------------------------------------------------- |  | ||||||
| public void OnClientAuthorized(int client, const char[] sSteamID32) |  | ||||||
| { |  | ||||||
| 	if (IsFakeClient(client)) |  | ||||||
| 		return; |  | ||||||
| 	char sSteamID64[32]; |  | ||||||
| 	SteamID32toSteamID64(sSteamID32, sSteamID64, sizeof(sSteamID64)); |  | ||||||
| 
 |  | ||||||
| 	char sRequest[256]; |  | ||||||
| 	FormatEx(sRequest, sizeof(sRequest), "https://unloze.com/api/private_api.php?api_key=%s&steam_id=%s", UNLOZE_APIKEY, sSteamID64); |  | ||||||
| 
 |  | ||||||
| 	int iSerial = GetClientSerial(client); |  | ||||||
| 	Handle hRequest = SteamWorks_CreateHTTPRequest(k_EHTTPMethodGET, sRequest); |  | ||||||
| 	if (!hRequest || |  | ||||||
| 		!SteamWorks_SetHTTPCallbacks(hRequest, OnClientAuthorized_OnTransferComplete) || |  | ||||||
| 		!SteamWorks_SetHTTPRequestContextValue(hRequest, iSerial) || |  | ||||||
| 		!SteamWorks_SendHTTPRequest(hRequest)) |  | ||||||
| 	{ |  | ||||||
| 		delete hRequest; |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| //---------------------------------------------------------------------------------------------------- |  | ||||||
| // Purpose: |  | ||||||
| //---------------------------------------------------------------------------------------------------- |  | ||||||
| public int OnClientAuthorized_OnTransferComplete(Handle hRequest, bool bFailure, bool bSuccessful, EHTTPStatusCode eStatusCode, int iSerial) |  | ||||||
| { |  | ||||||
| 	int client = GetClientFromSerial(iSerial); |  | ||||||
| 
 |  | ||||||
| 	if (!client) //Player disconnected. |  | ||||||
| 	{ |  | ||||||
| 		delete hRequest; |  | ||||||
| 		return 0; |  | ||||||
| 	} |  | ||||||
| 	 |  | ||||||
| 	if (bFailure || !bSuccessful || eStatusCode != k_EHTTPStatusCode200OK) |  | ||||||
| 	{ |  | ||||||
| 		G_bResponseFailed[client] = true; |  | ||||||
| 
 |  | ||||||
| 		if (G_bPreAdminChecked[client]) |  | ||||||
| 			NotifyPostAdminCheck(client); |  | ||||||
| 
 |  | ||||||
| 		delete hRequest; |  | ||||||
| 		return 0; |  | ||||||
| 	} |  | ||||||
| 	 |  | ||||||
| 	SteamWorks_GetHTTPResponseBodyCallback(hRequest, OnClientAuthorized_OnTransferResponse, iSerial); |  | ||||||
|     return 0; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| //---------------------------------------------------------------------------------------------------- |  | ||||||
| // Purpose: |  | ||||||
| //---------------------------------------------------------------------------------------------------- |  | ||||||
| public int OnClientAuthorized_OnTransferResponse(char[] sData, int iSerial) |  | ||||||
| { |  | ||||||
| 	char splitData[2][32]; |  | ||||||
| 	 |  | ||||||
| 	int client = GetClientFromSerial(iSerial); |  | ||||||
| 
 |  | ||||||
| 	if (!client) //Player disconnected. |  | ||||||
| 		return 0; |  | ||||||
| 
 |  | ||||||
| 	TrimString(sData); |  | ||||||
| 	StripQuotes(sData); |  | ||||||
|      |  | ||||||
| 	ExplodeString(sData, "\r\n", splitData, 2, sizeof(splitData[])); |  | ||||||
| 
 |  | ||||||
| 	if(strlen(splitData[1]) > 0) |  | ||||||
| 		strcopy(G_sName[client], sizeof(G_sName[]), splitData[1]); |  | ||||||
| 
 |  | ||||||
|     int not_counted_players = 0; |  | ||||||
|     for (int i = 0; i < MaxClients; i++) |  | ||||||
|     { |  | ||||||
|         if (IsValidClient(i) && (IsClientAutismBot(i) || IsFakeClient(i))) |  | ||||||
|         { |  | ||||||
|             not_counted_players++; |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|     int clientCount = GetClientCount(false) - not_counted_players; |  | ||||||
|     if (clientCount <= 13) |  | ||||||
|     { |  | ||||||
|         //if less than some amount of players just give free vip.  |  | ||||||
| 		strcopy(G_sGroup[client], sizeof(G_sGroup[]), "Game-Donator"); |  | ||||||
| 		G_bResponsePassed[client] = true; |  | ||||||
| 		 |  | ||||||
| 		if (G_bPreAdminChecked[client]) |  | ||||||
| 			NotifyPostAdminCheck(client); |  | ||||||
|          |  | ||||||
|     } |  | ||||||
| 	else if(!StrEqual(splitData[0], "NOGROUP")) |  | ||||||
| 	{ |  | ||||||
| 		strcopy(G_sGroup[client], sizeof(G_sGroup[]), splitData[0]); |  | ||||||
| 		 |  | ||||||
| 		G_bResponsePassed[client] = true; |  | ||||||
| 		 |  | ||||||
| 		if (G_bPreAdminChecked[client]) |  | ||||||
| 			NotifyPostAdminCheck(client); |  | ||||||
| 	} |  | ||||||
| 	else |  | ||||||
| 		G_bResponseFailed[client] = true; //users with just a forum name did not pass the VIP check! so the response "failed" (but we store their forum name for later!) |  | ||||||
|     return 0; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| //---------------------------------------------------------------------------------------------------- |  | ||||||
| // Purpose: |  | ||||||
| //---------------------------------------------------------------------------------------------------- |  | ||||||
| public Action OnClientPreAdminCheck(int client) |  | ||||||
| { |  | ||||||
| 	G_bPreAdminChecked[client] = true; |  | ||||||
| 
 |  | ||||||
| 	if (G_bResponsePassed[client] || G_bResponseFailed[client]) |  | ||||||
| 		return Plugin_Continue; |  | ||||||
| 
 |  | ||||||
| 	RunAdminCacheChecks(client); |  | ||||||
| 	return Plugin_Handled; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| //---------------------------------------------------------------------------------------------------- |  | ||||||
| // Purpose: |  | ||||||
| //---------------------------------------------------------------------------------------------------- |  | ||||||
| public void OnClientPostAdminFilter(int client) |  | ||||||
| { |  | ||||||
| 	ApplyGroupFlags(client); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| //---------------------------------------------------------------------------------------------------- |  | ||||||
| // Purpose: |  | ||||||
| //---------------------------------------------------------------------------------------------------- |  | ||||||
| stock void ApplyGroupFlags(int client) |  | ||||||
| { |  | ||||||
| 	if (!G_bResponsePassed[client]) |  | ||||||
| 		return; |  | ||||||
| 
 |  | ||||||
| 	AdminId AdmID; |  | ||||||
| 	GroupId GrpID; |  | ||||||
| 
 |  | ||||||
| 	if ((AdmID = GetUserAdmin(client)) == INVALID_ADMIN_ID) |  | ||||||
| 	{ |  | ||||||
| 		LogMessage("Creating new admin for %L", client); |  | ||||||
| 
 |  | ||||||
| 		AdmID = CreateAdmin(); |  | ||||||
| 		SetUserAdmin(client, AdmID, true); |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
|     if ((GrpID = FindAdmGroup(G_sGroup[client])) != INVALID_GROUP_ID) |  | ||||||
| 	{ |  | ||||||
| 		if (AdminInheritGroup(AdmID, GrpID)) |  | ||||||
| 		{ |  | ||||||
| 			LogMessage("%L added to group %s", client, G_sGroup[client]); |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
| 	else |  | ||||||
| 	{ |  | ||||||
| 		LogMessage("%L group not found %s", client, G_sGroup[client]); |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| public int Native_GetClientForumName(Handle plugin, int numParams) |  | ||||||
| { |  | ||||||
| 	int len = GetNativeCell(2); |  | ||||||
| 	int client = GetNativeCell(1); |  | ||||||
| 	 |  | ||||||
| 	SetNativeString(2, G_sName[client], len+1); |  | ||||||
|     return 0; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| //---------------------------------------------------------------------------------------------------- |  | ||||||
| // Purpose: |  | ||||||
| //---------------------------------------------------------------------------------------------------- |  | ||||||
| public int Native_AsyncHasSteamIDReservedSlot(Handle plugin, int numParams) |  | ||||||
| { |  | ||||||
| 	char sSteamID32[32]; |  | ||||||
| 	GetNativeString(1, sSteamID32, sizeof(sSteamID32)); |  | ||||||
| 
 |  | ||||||
| 	Function callback; //https://github.com/alliedmodders/sourcepawn/issues/778 |  | ||||||
| 	callback = GetNativeFunction(2); |  | ||||||
| 
 |  | ||||||
| 	any data; |  | ||||||
| 	data = GetNativeCell(3); |  | ||||||
| 
 |  | ||||||
| 	char sSteamID64[32]; |  | ||||||
| 	SteamID32toSteamID64(sSteamID32, sSteamID64, sizeof(sSteamID64)); |  | ||||||
| 
 |  | ||||||
| 	char sRequest[256]; |  | ||||||
| 	FormatEx(sRequest, sizeof(sRequest), "https://unloze.com/api/private_api.php?api_key=%s&steam_id=%s", UNLOZE_APIKEY, sSteamID64); |  | ||||||
| 
 |  | ||||||
| 	DataPack hDataPack = new DataPack(); |  | ||||||
| 	hDataPack.WriteString(sSteamID32); |  | ||||||
| 	hDataPack.WriteFunction(callback); |  | ||||||
| 	hDataPack.WriteCell(plugin); |  | ||||||
| 	hDataPack.WriteCell(data); |  | ||||||
| 
 |  | ||||||
| 	Handle hRequest = SteamWorks_CreateHTTPRequest(k_EHTTPMethodGET, sRequest); |  | ||||||
| 	if (!hRequest || |  | ||||||
| 		!SteamWorks_SetHTTPCallbacks(hRequest, Native_AsyncHasSteamIDReservedSlot_OnTransferComplete) || |  | ||||||
| 		!SteamWorks_SetHTTPRequestContextValue(hRequest, hDataPack) || |  | ||||||
| 		!SteamWorks_SendHTTPRequest(hRequest)) |  | ||||||
| 	{ |  | ||||||
| 		delete hRequest; |  | ||||||
| 	} |  | ||||||
|     return 0; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| //---------------------------------------------------------------------------------------------------- |  | ||||||
| // Purpose: |  | ||||||
| //---------------------------------------------------------------------------------------------------- |  | ||||||
| public int Native_AsyncHasSteamIDReservedSlot_OnTransferComplete(Handle hRequest, bool bFailure, bool bSuccessful, EHTTPStatusCode eStatusCode, DataPack hDataPack) |  | ||||||
| { |  | ||||||
| 	if (bFailure || !bSuccessful || eStatusCode != k_EHTTPStatusCode200OK) |  | ||||||
| 	{ |  | ||||||
| 		char sData[32] = "NOGROUP"; |  | ||||||
| 		Native_AsyncHasSteamIDReservedSlot_OnTransferResponse(sData, hDataPack); |  | ||||||
| 
 |  | ||||||
| 		delete hRequest; |  | ||||||
| 		return 0; |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	SteamWorks_GetHTTPResponseBodyCallback(hRequest, Native_AsyncHasSteamIDReservedSlot_OnTransferResponse, hDataPack); |  | ||||||
|     return 0; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| //---------------------------------------------------------------------------------------------------- |  | ||||||
| // Purpose: |  | ||||||
| //---------------------------------------------------------------------------------------------------- |  | ||||||
| public int Native_AsyncHasSteamIDReservedSlot_OnTransferResponse(char[] sData, DataPack hDataPack) |  | ||||||
| { |  | ||||||
| 	hDataPack.Reset(); |  | ||||||
| 
 |  | ||||||
| 	char sSteamID32[32]; |  | ||||||
| 	hDataPack.ReadString(sSteamID32, sizeof(sSteamID32)); |  | ||||||
| 
 |  | ||||||
| 	Function callback; |  | ||||||
| 	callback = hDataPack.ReadFunction(); |  | ||||||
| 
 |  | ||||||
| 	Handle plugin; |  | ||||||
| 	plugin = hDataPack.ReadCell(); |  | ||||||
| 
 |  | ||||||
| 	any data; |  | ||||||
| 	data = hDataPack.ReadCell(); |  | ||||||
| 
 |  | ||||||
| 	static char splitData[32]; |  | ||||||
| 
 |  | ||||||
| 	TrimString(sData); |  | ||||||
| 	StripQuotes(sData); |  | ||||||
| 	 |  | ||||||
| 	SplitString(sData, "\r\n", splitData, sizeof(splitData)); |  | ||||||
| 
 |  | ||||||
| 	int result; |  | ||||||
| 	if (StrEqual(splitData, "Game-Donator", false)) |  | ||||||
| 		result = 1; |  | ||||||
| 	else |  | ||||||
| 		result = 0; |  | ||||||
| 
 |  | ||||||
| 	Call_StartFunction(plugin, callback); |  | ||||||
| 	Call_PushString(sSteamID32); |  | ||||||
| 	Call_PushCell(result); |  | ||||||
| 	Call_PushCell(data); |  | ||||||
| 	Call_Finish(); |  | ||||||
| 
 |  | ||||||
| 	delete hDataPack; |  | ||||||
| 	return 0; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| //---------------------------------------------------------------------------------------------------- |  | ||||||
| // Purpose: |  | ||||||
| //---------------------------------------------------------------------------------------------------- |  | ||||||
| stock bool SteamID32toSteamID64(const char[] sSteamID32, char[] sSteamID64, int iSize) |  | ||||||
| { |  | ||||||
| 	if (strlen(sSteamID32) < 11 || strncmp(sSteamID32[0], "STEAM_", 6)) |  | ||||||
| 	{ |  | ||||||
| 		sSteamID64[0] = 0; |  | ||||||
| 		return false; |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	int iUpper = 765611979; |  | ||||||
| 	int isSteam64ID = StringToInt(sSteamID32[10]) * 2 + 60265728 + sSteamID32[8] - 48; |  | ||||||
| 
 |  | ||||||
| 	int iDiv = isSteam64ID / 100000000; |  | ||||||
| 	int iIdx = 9 - (iDiv ? (iDiv / 10 + 1) : 0); |  | ||||||
| 
 |  | ||||||
| 	iUpper += iDiv; |  | ||||||
| 
 |  | ||||||
| 	IntToString(isSteam64ID, sSteamID64[iIdx], iSize - iIdx); |  | ||||||
| 	iIdx = sSteamID64[9]; |  | ||||||
| 
 |  | ||||||
| 	IntToString(iUpper, sSteamID64, iSize); |  | ||||||
| 	sSteamID64[9] = iIdx; |  | ||||||
| 
 |  | ||||||
| 	return true; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| stock bool IsValidClient(int client) |  | ||||||
| { |  | ||||||
|     if (client > 0 && client <= MaxClients && IsClientConnected(client) && IsClientInGame(client)) |  | ||||||
|         return true; |  | ||||||
|     return false; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
		Loading…
	
		Reference in New Issue
	
	Block a user