129 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			SourcePawn
		
	
	
	
	
	
			
		
		
	
	
			129 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			SourcePawn
		
	
	
	
	
	
// *************************************************************************
 | 
						|
//  This file is part of SourceBans++.
 | 
						|
//
 | 
						|
//  Copyright (C) 2014-2016 SourceBans++ Dev Team <https://github.com/sbpp>
 | 
						|
//
 | 
						|
//  SourceBans++ is free software: you can redistribute it and/or modify
 | 
						|
//  it under the terms of the GNU General Public License as published by
 | 
						|
//  the Free Software Foundation, per version 3 of the License.
 | 
						|
//
 | 
						|
//  SourceBans++ is distributed in the hope that it will be useful,
 | 
						|
//  but WITHOUT ANY WARRANTY; without even the implied warranty of
 | 
						|
//  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | 
						|
//  GNU General Public License for more details.
 | 
						|
//
 | 
						|
//  You should have received a copy of the GNU General Public License
 | 
						|
//  along with SourceBans++. If not, see <http://www.gnu.org/licenses/>.
 | 
						|
//
 | 
						|
//  This file based off work(s) covered by the following copyright(s):
 | 
						|
//
 | 
						|
//   SourceComms 0.9.266
 | 
						|
//   Copyright (C) 2013-2014 Alexandr Duplishchev
 | 
						|
//   Licensed under GNU GPL version 3, or later.
 | 
						|
//   Page: <https://forums.alliedmods.net/showthread.php?p=1883705> - <https://github.com/d-ai/SourceComms>
 | 
						|
//
 | 
						|
// *************************************************************************
 | 
						|
 | 
						|
#if defined _sourcecomms_included
 | 
						|
#endinput
 | 
						|
#endif
 | 
						|
#define _sourcecomms_included
 | 
						|
 | 
						|
/**
 | 
						|
 * @section Int definitions for punishments types.
 | 
						|
 */
 | 
						|
 | 
						|
#define TYPE_MUTE           1   /**< Voice Mute */
 | 
						|
#define TYPE_GAG            2   /**< Gag (text chat) */
 | 
						|
#define TYPE_SILENCE        3   /**< Silence (mute + gag) */
 | 
						|
#define TYPE_UNMUTE         4   /**< Voice Unmute*/
 | 
						|
#define TYPE_UNGAG          5   /**< Ungag*/
 | 
						|
#define TYPE_UNSILENCE      6   /**< Unsilence */
 | 
						|
#define TYPE_TEMP_UNMUTE    14  /**< Temp mute removed */
 | 
						|
#define TYPE_TEMP_UNGAG     15  /**< Temp gag removed */
 | 
						|
#define TYPE_TEMP_UNSILENCE 16  /**< Temp silence removed */
 | 
						|
 | 
						|
/* Punishments types */
 | 
						|
enum bType {
 | 
						|
	bNot = 0,  // Player chat or voice is not blocked
 | 
						|
	bSess,  // ... blocked for player session (until reconnect)
 | 
						|
	bTime,  // ... blocked for some time
 | 
						|
	bPerm // ... permanently blocked
 | 
						|
}
 | 
						|
 | 
						|
/**
 | 
						|
 * Sets a client's mute state.
 | 
						|
 *
 | 
						|
 * @param client		Client index.
 | 
						|
 * @param muteState		True to mute client, false to unmute.
 | 
						|
 * -------------------------------------Parameters below this line are used only for muteState=true-------------------------------------
 | 
						|
 * ----------------------------------for muteState=false these parameters are ignored (saveToDB=false)----------------------------------
 | 
						|
 * @param muteLength		Length of punishment in minutes. Value < 0 muting client for session. Permanent (0) is not allowed at this time.
 | 
						|
 * @param saveToDB		If true, punishment will be saved in database.
 | 
						|
 * @param reason		Reason for punishment.
 | 
						|
 * @return				True if this caused a change in mute state, false otherwise.
 | 
						|
 */
 | 
						|
native bool:SourceComms_SetClientMute(client, bool:muteState, muteLength = -1, bool:saveToDB = false, const String:reason[] = "Muted through natives");
 | 
						|
 | 
						|
/**
 | 
						|
 * Sets a client's gag state.
 | 
						|
 *
 | 
						|
 * @param client		Client index.
 | 
						|
 * @param gagState		True to gag client, false to ungag.
 | 
						|
 * --------------------------------------Parameters below this line are used only for gagState=true--------------------------------------
 | 
						|
 * -----------------------------------for gagState=false these parameters are ignored (saveToDB=false)-----------------------------------
 | 
						|
 * @param gagLength		Length of punishment in minutes. Value < 0 gagging client for session. Permanent (0) is not allowed at this time.
 | 
						|
 * @param saveToDB		If true, punishment will be saved in database.
 | 
						|
 * @param reason		Reason for punishment.
 | 
						|
 * @return				True if this caused a change in gag state, false otherwise.
 | 
						|
 */
 | 
						|
native bool:SourceComms_SetClientGag(client, bool:gagState, gagLength = -1, bool:saveToDB = false, const String:reason[] = "Gagged through natives");
 | 
						|
 | 
						|
/**
 | 
						|
 * Returns the client's mute type
 | 
						|
 *
 | 
						|
 * @param client	The client index of the player to check mute status
 | 
						|
 * @return          The client's current mute type index (see enum bType in the begin).
 | 
						|
 */
 | 
						|
native bType:SourceComms_GetClientMuteType(client);
 | 
						|
 | 
						|
 | 
						|
/**
 | 
						|
 * Returns the client's gag type
 | 
						|
 *
 | 
						|
 * @param client	The client index of the player to check gag status
 | 
						|
 * @return          The client's current gag type index (see enum bType in the begin).
 | 
						|
 */
 | 
						|
native bType:SourceComms_GetClientGagType(client);
 | 
						|
 | 
						|
/**
 | 
						|
 * Called when added communication block for player.
 | 
						|
 *
 | 
						|
 * @param client	The client index of the admin who is blocking the client.
 | 
						|
 * @param target	The client index of the player to blocked.
 | 
						|
 * @param time		The time to blocked the player for (in minutes, 0 = permanent).
 | 
						|
 * @param type		The type of block. See section "Int definitions for punishments types".
 | 
						|
 * @param reason	The reason to block the player.
 | 
						|
 */
 | 
						|
forward SourceComms_OnBlockAdded(client, target, time, type, String:reason[]);
 | 
						|
 | 
						|
public SharedPlugin:__pl_sourcecomms =
 | 
						|
{
 | 
						|
	name = "sourcecomms++",
 | 
						|
	file = "sbpp_comms.smx", 
 | 
						|
	#if defined REQUIRE_PLUGIN
 | 
						|
	required = 1
 | 
						|
	#else
 | 
						|
	required = 0
 | 
						|
	#endif
 | 
						|
};
 | 
						|
 | 
						|
public __pl_sourcecomms_SetNTVOptional()
 | 
						|
{
 | 
						|
	MarkNativeAsOptional("SourceComms_SetClientMute");
 | 
						|
	MarkNativeAsOptional("SourceComms_SetClientGag");
 | 
						|
	MarkNativeAsOptional("SourceComms_GetClientMuteType");
 | 
						|
	MarkNativeAsOptional("SourceComms_GetClientGagType");
 | 
						|
 | 
						|
}
 |