Логи прямо в игре !

В теме 2 сообщения

Lelouch
Освоившийся

Вечер в хату уважаемые юзеры портала Pawno-Rus, это был мой первый форум по Павно,так что я очень ему блогадарен за хорошее начало.
Что-же,сегодня я хочу слить вам свою собственную систему с Логированием прямо в игре,делаю я это с "не  фиг(система дерётся за такое слово :c) делать",уже даже нету идей что ещё сделать в моде из такого не сложного.
Автор данной системы - Lelouch(Лелуш) | (Я)
Ну что-же,начнём.
У меня: Pawn.CMD + sscanf

 

Добавляем сток:

stock SendScripterMessage(color, string[])
{
	foreach(Player,i)
	{
	    //if(!FIX_IsPlayerConnected(i) || gPlayerLogged[i] == 0) continue;
		if(PlayerInfo[i][pScripter] > 0) SendClientMessage(i, color, string);
	}
	return true;
}

 

publics: LoginCallback(playerid)

	cache_get_field_content(0, "pScripter", maximum),		PlayerInfo[playerid][pScripter] = strval(maximum);

 

Команды на выдачу ПРАВ для чтения логов:

CMD:golog(playerid, params[])
{
	if(strcmp(PlayerInfo[playerid][pNames], "Maga_Volkov")) return true;
//	if(strcmp(PlayerInfo[playerid][pNames], "Alexei_Cheetov")) return true;
	if(PlayerInfo[playerid][pScripter] > 0) return SCM(playerid, -1, "{FFC700}У игрока уже есть права скриптера !");
	if(sscanf(params, "d", params[0])) return SendClientMessage(playerid, COLOR_WHITE, "Введите: /golog [ID]");
	if(!IsPlayerConnected(params[0])) return SendClientMessage(playerid, COLOR_WHITE, "Ошибка: Игрока не существует");
	PlayerInfo[params[0]][pScripter] = 1;
	format(stringer, sizeof(stringer), "[LOG] [SCRIPTER] {FF0000}Администратор %s[%d] выдал Log-Dostup игроку %s[%d]", PlayerInfo[playerid][pNames], playerid, PlayerInfo[params[0]][pNames], params[0]);
	SendScripterMessage(COLOR_REDD, stringer);
	UpdatePlayerData(params[0], "pScripter", PlayerInfo[params[0]][pScripter]);
	format(mysql_query_, sizeof(mysql_query_), "UPDATE `"TABLE_ACCOUNT"` SET `pScripter` = '1' WHERE `accounts`.`pID` = '%d'", PlayerInfo[params[0]][pID]);
	mysql_function_query(connects, mysql_query_, false, "", "");
	return true;
}
CMD:nolog(playerid, params[])
{
	if(strcmp(PlayerInfo[playerid][pNames], "Maga_Volkov")) return true;
//	if(strcmp(PlayerInfo[playerid][pNames], "Alexei_Cheetov")) return true;
	if(sscanf(params, "d", params[0])) return SendClientMessage(playerid, COLOR_WHITE, "Введите: /nolog [ID]");
	if(!IsPlayerConnected(params[0])) return SendClientMessage(playerid, COLOR_WHITE, "Ошибка: Игрока не существует");
	if(PlayerInfo[playerid][pScripter] < 0) return SCM(playerid, -1, "{FFC700}У игрока и так нету прав скриптера !");
	format(stringer, sizeof(stringer), "[LOG] [SCRIPTER] {FF0000}Администратор %s[%d] убрал Log-Dostup игроку %s[%d]", PlayerInfo[playerid][pNames], playerid, PlayerInfo[params[0]][pNames], params[0]);
	SendScripterMessage(COLOR_REDD, stringer);
	PlayerInfo[params[0]][pScripter] = 0;
	UpdatePlayerData(params[0], "pScripter", PlayerInfo[params[0]][pScripter]);
	format(mysql_query_, sizeof(mysql_query_), "UPDATE `"TABLE_ACCOUNT"` SET `pScripter` = '0' WHERE `accounts`.`pID` = '%d'", PlayerInfo[params[0]][pID]);
	mysql_function_query(connects, mysql_query_, false, "", "");
	return true;
}

Как можно понять - /nolog - убирает права читать логи

/golog - выдаёт право на чтение логов.

Теперь разберём их содержание.

Будем разбирать на примере команде /golog:

Форма: 1 (Строка) - ...(Функция)

 

1 - Проверка на имя,т.е если у игрока нету ника который там стоит - команда не будет у него работать.

2 - (забыл удалить)

3 - Пишем игроку что у  игрока уже есть права на чтение логов

4 - Пишем как правильно исп. команду

5 - Пишем в случае если игрок не на сервере - что его не существует.

6 - Выдаём сами права игроку (pScripter = 1)

7 - Уведомляем что ещё один челик попал к нам

(SendScripterMessage - сообщение в чате "логов")

8 - Тут у меня в моде идёт обновление инф. о игроке (pScripter обновляем челику)

9 - 10 = Сохраняем это всё дело в MySql

в MySql в таблице с Аккаунтами - заходим в Структуру Таблицы - создаём новую перемённую pScripter (Нач. Знач: 0)

11 - return true :]

 

Собственно /nolog так же только наобарот уже.

После всех этих махинации - пишем /golog [свой ID]

Получаем права,а теперь собственно вопрос: Как читать "логи" ?
Под "Логами" я имел ввиду действия игроков,к примеру у вас есть недоверие к своим игрокам/составу,и вы не хотите по каким-то причинам добавлять логирование в админ-чат какой-то команде.
Тогда пишет format(<string>, sizeof(<string), "[A] Игрок %s[%d] использовал команду ...", PlayerInfo[playerid][pNames], playerid);

SendScripterMessage(<COLOR>,<STRNG>);

playerid - ID Игрока

pNames - Имя игрока

*Добавил(забыл написать):

SCM - SendPlayerMessage
Я надеюсь суть понятная. Я лично у себя эту систему развил настолько что аж даже Чат для таких "чекеров логов" :D
Ну ладно,пожалуй скину пример "логирования" команды:

CMD:ska(playerid,params[])
{
    if(strcmp(PlayerInfo[playerid][pNames], "Maga_Volkov")) return true;
	new NameA[24], lvl;
	if(sscanf(params,"s[24]dd",NameA,lvl, params[2])) return SendClientMessage(playerid, COLOR_WHITE, "Введите: /ska [name] [уровень]");
	if(lvl > 100 || lvl < 0) return SendClientMessage(playerid,COLOR_WHITE,"Ошибка: Нельзя меньше 1 и больше 13");
	if(!FD(playerid) && (!strcmp(NameA, "Maga_Volkov"))) return SCM(playerid, -1, "Низя !!");
	new query[144];
	format(query, sizeof(query), "SELECT * FROM `accounts` WHERE `Name` = '%s' LIMIT 1", NameA);
	mysql_function_query(connects, query, true, "SetAdmin", "dds", playerid, lvl, NameA);
	format(stringer1, sizeof(stringer1), "{ffc700}[A] Скриптер {FF0000}%s[%d]{ffc700} назначил игрока {FF0000}%s{FFC700} на админку {FF0000}%d {ffc700}уровня !", PlayerInfo[playerid][pNames], playerid, NameA, lvl);
	SendScripterMessage(COLOR_LIGHTRED, stringer1); // log for scripter
	return true;
}

Как можно увидить по данному примеру,в конец команды стоит функция: SendScripterMessage(<COLOR>, <STRING>);

Что и отправляет сообщение в наш чат.

Данная система не протестирована на проекте с онлайном,ибо делаю я мод в соло.

Должно работать как по маслу,если что - пишите сюда. Посмотрим с чем вы столкнулись.

 

Просьба при размещении на других форумах и т.д указывать ВК Автора )) (НЕ реклама): vk.com/l0ve_an1me

Всем спасибо за внимание,всего наилучшего !)

Отредактировано пользователем Lelouch
Причина: Система банит слово :c | Дополнил текст где забыл дополнить .-.

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Для публикации сообщений создайте учётную запись или авторизуйтесь

Вы должны быть пользователем, чтобы оставить комментарий

Создать учетную запись

Зарегистрируйте новую учётную запись в нашем сообществе. Это очень просто!


Регистрация нового пользователя

Войти

Уже есть аккаунт? Войти в систему.


Войти

  • Последние посетители   0 пользователей онлайн

    Ни одного зарегистрированного пользователя не просматривает данную страницу

  • Похожий контент

    • Андрей Лазарев
      От Андрей Лазарев
      ROSTOV-HOST.RU - Современный Хостинг Игровых Серверов по невероятно низким ценам и удобной панелью управления 

      — Защита от DDoS-атак 
      — Бесплатная техническая поддержка 
      — Доступ в панель управления и личный кабинет 
      — Переустановка игрового сервера в любое время суток 
      — Редактирование конфигурационных файлов игрового сервера 
      — FTP доступ к файлам игрового сервера 
      — Мониторинг процессов 
      — Изменение количества слотов игрового сервера 
      — Система управления счетами и оплаты услуг 
      — Локальная MySQL база данных 
      — Автоустановка модов
      — Смена (версии / игры) сразу в панели управления


      Цены: с помесячной оплатой
      — GTA: SAMP              - 1слот / 0.40копп.
      — GTA: CRMP              - 1слот / 0.40копп.
      — GTA: MTA                 - 1слот / 0.80копп.
      — GTA: United MP       - 1слот / 0.80копп.
      — MineCraft: PE           - 1слот / 3.00копп.
      — MineCraft                  - 1слот / 5.00копп.
      — Counter Strike 1.6    - 1слот / 4.00копп.
       
      Цены: плати один раз пользуйся до скончания веков
      — 1 200 руб / SA:MP 0.3е/ CR:MP 0.3е/ МТА /    500 слотов
      — 1 800 руб / SA:MP 0.3.7/ CR:MP 0.3.7/ МТА /    1000 слотов
       

      Сайт: https://rostov-host.ru
      Группа в VK: https://vk.com/rostov_host
       
       
    • 9at0z
      От 9at0z
      Flatgame.ru - Хостинг игровых серверов. Gta SAMP: 0.50коп/слот Gta СRMP: 0.50коп/слот MTA: 0.50коп/слот Minecraft: 5руб/слот Counter Stire 1.6: 7руб/слот Все сервера с автоусновкой модов, которые есть доступны. Обширная панель управления сервером. Тестовый периуд 3 дня. И очень много чего интересного!

    • FanVan
      От FanVan

       
      Дешевый хостинг серверов SAMP, CRMP, Minecraft: Java & Bedrock Edition
       
      Помогаем запуститься начинающим проектам без больших вложений.
      Сделаем так, чтобы твои затраты на хостинг уменьшились без потери качества.
       
      Размещаем серверы в Хельсинках, Финляндия на процессоре частотой до 4.8 ГГц и NVMe диске.
      У нас нет красивого сайта, покупка услуг производится через бота в ЛС группы, а управление сервером -- посредством панели Pterodactyl.
      Мы не ограничиваем тебя слотами: все тарифы -- это маленькие компьютеры, ты волен сам устанавливать максимальное количество игроков, без повышения стоимости.
       
      К нам обращаются, когда хостинг начинает съедать большую часть бюджета из-за того, что хостер захотел выпендриться и добавил бесполезный функционал. Но лучше обратиться еще в начале, чтобы уменьшить затраты на хостинг и вложить как можно больше в рекламу.
       
      Никто не идеален, ничто не идеально: мы не можем помочь
      если у тебя высоконагруженный проект если тебе требуется защита от DDOS если тебе нужен пинг -1 если тебе важна автоустановка модов  
      Но ты можешь написать нам в тех. поддержку и, возможно, мы подберем более мощный тариф на отдельном сервере персонально для тебя по цене ниже, чем у других.
       
      Мы стремимся сделать создание сервера доступным каждому. Если остались вопросы или хочешь протестировать оборудование, напиши нам в ЛС группы.
    • Groos
      От Groos

      Качественный игровой хостинг серверов SAMP, CRMP, MTA
       
       
      О нашем хостинге
      - SafePlay - Наш хостинг богат инструментами и различными дополнениями для управления серверами, готовыми сборками модов для автоматической установки серверов SAMP, Нашей панелью управления справиться как и профи, так и новичок. Наши отличные и отзывчивые специалисты(администрация) рады помочь Вам в любую трудную минуту (в том числе по игровой сборке мода,  UCP-сайта или Форумом). Наш хостинг использует надежное и качественное оборудование. Минимальным ping по всей России. Открытая характеристика и статистика хостинга.
        Что мы предлагаем?        - На нашем проекте SafePlay Вы можете создать сервер по справедливым ценам:
      SAMP (LITE) - 0,50 руб/ слот SAMP (VIP) - 1 руб/ слот CRMP - 1 руб / слот MTA - 1 руб / слот
        Ритуал открытия
      - Официальное открытие нашего игрового хостинга: 01.08.2021! В связи с этим, на нашем хостинге присутствует(временная функция) тестирование игрового хостинга (с периодом 15 дней). Для того чтобы активировать данный сервер, Вам достаточно пройти процедуру регистрации >> в разделе "Сервера" >> Заказать сервер "San Andreas: Multiplayers" (за 1 рубль, который вам выдается при регистрации аккаунта). 
        Выслушаем всех!
      - В данной теме, хотелось бы прочитать отзывы, критики а так же пожелания независимых экспертов или бета-тестировщиков. Рады будем любому комментарию, заранее спасибо за внимание, команда администрации SafePlay