RU/banPlayer: Difference between revisions

From Multi Theft Auto: Wiki
Jump to navigation Jump to search
mNo edit summary
No edit summary
 
(15 intermediate revisions by 4 users not shown)
Line 1: Line 1:
__NOTOC__
__NOTOC__
{{DISPLAYTITLE:banPlayer}}
{{RU/Server function}}
{{RU/Server function}}
{{New feature|3|1.0|
{{RU/New feature/item|3|1.0||
Эта функция дает бан игроку по IP, [[RU/Serial|серийному коду]] или имени.
Эта функция дает бан игроку по IP, [[RU/Serial|серийному коду]] или имени.
}}
{{Deprecated_feature|3|1.0|
This function will ban the specified player from the server by IP.
}}
}}


==Синтаксис==  
==Синтаксис==  
{{New feature|3|1.0|
{{RU/New feature/item|3|1.0||
<syntaxhighlight lang="lua">
<syntaxhighlight lang="lua">
ban banPlayer ( player bannedPlayer, [ bool IP = true, bool Username = false, bool Serial = false,  
ban banPlayer ( player bannedPlayer, [ bool IP = true, bool Username = false, bool Serial = false,  
Line 18: Line 13:
}}
}}


{{Deprecated_feature|3|1.0|
<syntaxhighlight lang="lua">
bool banPlayer ( player bannedPlayer , [ element responsibleElement, string reason ] )       
</syntaxhighlight>
}}
{{RU/OOP||[[RU/Element/Player|player]]:ban||}}
{{RU/OOP||[[RU/Element/Player|player]]:ban||}}
===Обязательные аргументы===  
===Обязательные аргументы===  
Line 29: Line 19:
===Необязательные аргументы===  
===Необязательные аргументы===  
{{RU/OptionalArg}}  
{{RU/OptionalArg}}  
{{New feature|3|1.0|
{{RU/New feature\item|3|1.0||
*'''IP:''' Забанить игрока по IP?
*'''IP:''' Забанить игрока по IP?
*'''Username:''' Забанить игрока по имени?
*'''Username:''' Забанить игрока по имени?
*'''Serial:''' Забанить игрока по серийному коду?
*'''Serial:''' Забанить игрока по серийному коду?


:'''Note:''' Что бы забанить игрока по имени или серийному коду, ''verifyserials'' должна быть включена в серверном файле конфигурации.
:'''Примечание:''' Чтобы забанить игрока по имени или серийному коду, ''verifyserials'' должна быть включена в серверном файле конфигурации.


}}
}}
Line 42: Line 32:


===Возвращения===
===Возвращения===
{{Deprecated_feature|3|1.0|
Возвращает ''true'' если игрок успешно забанен, ''false''если даны неправильные аргументы.
}}


{{New feature|3|1.0|
{{RU/New feature/item|3|1.0||
Возращает элемент [[RU/Ban|бана]], если игрок удалось успешно забанить, или ''false'' если неудалось.
Возращает элемент [[RU/Ban|бана]], если игрок успешно забанен, или ''false'' в противном случае.
}}
}}



Latest revision as of 21:42, 14 June 2021

Эта функция дает бан игроку по IP, серийному коду или имени.

Синтаксис

ban banPlayer ( player bannedPlayer, [ bool IP = true, bool Username = false, bool Serial = false, 
player responsiblePlayer = nil, string reason = nil, int seconds = 0 ] )

Синтаксис ООП Помогите! Я не понимаю, что это!

Метод: player:ban(...)

Обязательные аргументы

  • bannedPlayer: Игрок, который должен быть забанен сервером.

Необязательные аргументы

Примечание. При использовании необязательных аргументов Вам может потребоваться предоставить все аргументы перед тем аргументом, который Вы хотите использовать. Для более подробной информации ознакомьтесь с необязательными аргументами. Template:RU/New feature\item

  • responsibleElement: Элемент, который отвечает за бан игрока. Это может быть игрок или корневой элемент ( getRootElement() ).
  • reason: Причина, по которой игрок будет забанен.
  • seconds: Количество секунд для бана игрока. Может быть 0, для бесконечного бана.

Возвращения

Возращает элемент бана, если игрок успешно забанен, или false в противном случае.

Пример

Этот пример банит кого-нибудь, если он имеет ACL права.

--Добавляем командный заголовок "ban"
-- Пример с игроком
function banPlayerCommand ( theClient, commandName, bannedName, reason )

	--Показываем ошибку если нет необходимых прав
	if ( hasObjectPermissionTo ( theClient, "function.banPlayer" ) ) then
		--Получаем элемент игрока из имени
		local bannedPlayer = getPlayerFromNick ( bannedName )

		--Баним игрока
		banPlayer ( bannedPlayer, theClient, reason )
		outputChatBox ( "ban: " .. bannedName .. " успешно забанен", theClient )

	else
		outputChatBox ( "ban: У вас недостаточно на это прав", theClient )
	end

end
addCommandHandler ( "ban", banPlayerCommand )

--Пример функции с корневым элементом. Здесь вы должны передавать элемент игрока в функцию.
function banCheater(theCheater)
	banPlayer(theCheater, getRootElement(), "Вы забанены за читерство.")
end

Это пример файрвола аккаунтов игроков, работающего по серийному коду, во время их входа.

Firewall = 
{
    [ 'AccountName' ] = 'SerialPlayer',
    [ '3ash8' ] = '9C9F3B55D9D7BB7135FF274D3BF444E4',
    [ 'test5' ] = '1D6F76CF8D7193792D13789849498452',
}
 
addEventHandler ( 'onPlayerLogin', getRootElement ( ),
    function ( _, theCurrentAccount )
    local Serial = Firewall[getAccountName(theCurrentAccount)]
        if ( Serial ) then
            if Serial ~= getPlayerSerial ( source ) then
                banPlayer ( source, false, false, true, getRootElement ( ), 'причина бана' )
            end
        end
    end
)

Смотрите также

Серверные функции

  • addBanблокирует доступ по серийному номеру, IP адресу и / или нику
  • banPlayerблокирует указанного игрока по серийному номеру, IP адресу и / или нику
  • getBanAdminвозвращает ник администратора, ответственного за указанную блокировку
  • getBanIPвозвращает заблокированный IP адрес для указанной блокировки
  • getBanNickвозвращает ник заблокированного игрока для указанной блокировки
  • getBanReasonвозвращает причину выдачи для указанной блокировки
  • getBansвозвращает таблицу выданных блокировок
  • getBanSerialвозвращает заблокированный серийный номер для указанной блокировки
  • getBanTimeвозвращает время в секундах, прошедшее от 1.01.1970 до момента выдачи указанной блокировки
  • getBanUsernameвозвращает ник заблокированного игрока для указанной блокировки (устарела)
  • getUnbanTimeвозвращает время в секундах, прошедшее от 1.01.1970 до момента снятия указанной блокировки
  • isBanпроверка значение на соответствие типу ban
  • kickPlayerисключает указанного игрока из игры
  • setBanAdminизменяет никнейм ответственного за блокировку администратора
  • setBanNickизменяет никнейм игрока для указанной блокировки
  • setBanReasonизменяет причину указанной блокировки
  • setUnbanTimeизменяет время разблокировки для указанного игрока
  • removeBanудаляет указанную блокировку
  • reloadBansобновление данных о выданных блокировках из файла banlist.xml