NoAdminTools: improve sm_checkadmins
This commit is contained in:
		
							parent
							
								
									536aa10823
								
							
						
					
					
						commit
						76c8f2044a
					
				| @ -15,6 +15,7 @@ float g_fSelfExtendsDelay; | ||||
| 
 | ||||
| bool g_bSelfExtends[MAXPLAYERS + 1] = { false, ...}; | ||||
| bool g_bSelfExtendsAllowed; | ||||
| bool g_bActiveAdmin[MAXPLAYERS + 1] = { false, ...}; | ||||
| int g_iSelfExtends; | ||||
| 
 | ||||
| ConVar g_cvarTimeLimit; | ||||
| @ -24,7 +25,7 @@ public Plugin myinfo = | ||||
| 	name = "No Admin Tools", | ||||
| 	author = "Dogan", | ||||
| 	description = "Make it possible for the server to do several things when there is no active admin online", | ||||
| 	version = "1.0.0", | ||||
| 	version = "1.1.0", | ||||
| 	url = "" | ||||
| }; | ||||
| 
 | ||||
| @ -76,24 +77,29 @@ public void Cvar_SelfExtendsDelay(ConVar convar, const char[] oldValue, const ch | ||||
| 	g_fSelfExtendsDelay = convar.FloatValue; | ||||
| } | ||||
| 
 | ||||
| public bool ActiveAdminPresent() | ||||
| public bool ActiveAdmin(int client) | ||||
| { | ||||
|     for(int i = 1; i <= MaxClients; i++) | ||||
|     { | ||||
|         if(IsValidClient(i) && CheckCommandAccess(i, "", ADMFLAG_GENERIC) && (GetClientIdleTime(i) < g_iAdminAFKTime)) | ||||
| 			return true; | ||||
|     } | ||||
|     return false; | ||||
| 	if(GetClientIdleTime(client) < g_iAdminAFKTime) | ||||
| 		return true; | ||||
| 
 | ||||
| 	return false; | ||||
| } | ||||
| 
 | ||||
| public void OnClientDisconnect(int client) | ||||
| { | ||||
| 	g_bSelfExtends[client] = false; | ||||
| 	g_bActiveAdmin[client] = false; | ||||
| 
 | ||||
| 	CheckRatio(); | ||||
| } | ||||
| 
 | ||||
| public void OnClientPutInServer(int client) | ||||
| public void OnClientPostAdminCheck(int client) | ||||
| { | ||||
| 	if(CheckCommandAccess(client, "", ADMFLAG_GENERIC) && IsValidClient(client)) | ||||
| 	{ | ||||
| 		g_bActiveAdmin[client] = true; | ||||
| 	} | ||||
| 
 | ||||
| 	CheckRatio(); | ||||
| } | ||||
| 
 | ||||
| @ -120,22 +126,67 @@ public Action Timer_DelaySelfExtend(Handle timer) | ||||
| 
 | ||||
| public Action Command_DisplayActiveAdmins(int client, int args) | ||||
| { | ||||
| 	if(ActiveAdminPresent()) | ||||
| 		ReplyToCommand(client, "[SM] There are active Admins online."); | ||||
| 	for(int i = 1; i <= MaxClients; i++) | ||||
| 		if(CheckCommandAccess(i, "", ADMFLAG_GENERIC) && IsValidClient(i) && ActiveAdmin(i)) | ||||
| 			g_bActiveAdmin[i] = true; | ||||
| 
 | ||||
| 	char aBuf[1024]; | ||||
| 	char aBuf2[MAX_NAME_LENGTH]; | ||||
| 	char bBuf[1024]; | ||||
| 	char bBuf2[MAX_NAME_LENGTH]; | ||||
| 
 | ||||
| 	for(int i = 1; i <= MaxClients; i++) | ||||
| 	{ | ||||
| 		if(IsClientInGame(i) && !IsFakeClient(i)) | ||||
| 		{ | ||||
| 			if(g_bActiveAdmin[i]) | ||||
| 			{ | ||||
| 				GetClientName(i, aBuf2, sizeof(aBuf2)); | ||||
| 				StrCat(aBuf, sizeof(aBuf), aBuf2); | ||||
| 				StrCat(aBuf, sizeof(aBuf), ", "); | ||||
| 			} | ||||
| 
 | ||||
| 			if(!g_bActiveAdmin[i] && CheckCommandAccess(i, "", ADMFLAG_GENERIC) && IsValidClient(i)) | ||||
| 			{ | ||||
| 				GetClientName(i, bBuf2, sizeof(bBuf2)); | ||||
| 				StrCat(bBuf, sizeof(bBuf), bBuf2); | ||||
| 				StrCat(bBuf, sizeof(bBuf), ", "); | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	if(strlen(aBuf)) | ||||
| 	{ | ||||
| 		aBuf[strlen(aBuf) - 2] = 0; | ||||
| 		ReplyToCommand(client, "[SM] Active Admins online: %s", aBuf); | ||||
| 	} | ||||
| 	else | ||||
| 		ReplyToCommand(client, "[SM] There are no active Admins online."); | ||||
| 		ReplyToCommand(client, "[SM] Active Admins online: none"); | ||||
| 
 | ||||
| 	if(strlen(bBuf)) | ||||
| 	{ | ||||
| 		bBuf[strlen(bBuf) - 2] = 0; | ||||
| 		ReplyToCommand(client, "[SM] Inactive Admins online: %s", bBuf); | ||||
| 	} | ||||
| 	else | ||||
| 		ReplyToCommand(client, "[SM] Inactive Admins online: none"); | ||||
| 
 | ||||
| 	return Plugin_Handled; | ||||
| } | ||||
| 
 | ||||
| public Action Command_SelfExtend(int client, int args) | ||||
| { | ||||
| 	int iAdminActivity = 0; | ||||
| 	for(int i = 1; i <= MaxClients; i++) | ||||
| 		if(g_bActiveAdmin[i]) | ||||
| 			iAdminActivity++; | ||||
| 
 | ||||
| 	if(GetExtendsLeft() > 0) | ||||
| 	{ | ||||
| 		ReplyToCommand(client, "[SM] Not available because not all regular extends have been depleted."); | ||||
| 		return Plugin_Handled; | ||||
| 	} | ||||
| 	if(ActiveAdminPresent()) | ||||
| 	if(iAdminActivity > 0) | ||||
| 	{ | ||||
| 		ReplyToCommand(client, "[SM] Not available because there is atleast one active Admin who can extend. Please ask the Admins."); | ||||
| 		return Plugin_Handled; | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user