ReAimDetector 0.2.2

Статус
В этой теме нельзя размещать новые ответы.
Сообщения
45
Реакции
-3
Ошибка
[ReAimDetector] ad_set_cfg: invalid type 5, value 0
ОС
Linux
Билд
Protocol version 48
Exe version 1.1.2.7/Stdio (cstrike)
ReHLDS version: 3.4.0.654-dev
Build date: 12:09:21 May 22 2018 (1501)
Build from: https://github.com/dreamstalker/rehlds/commit/65c6ce5
ReGamedll
ReGameDLL version: 5.7.0.310-dev
Build date: 05:50:50 May 24 2018
Build from: https://github.com/s1lentq/ReGameDLL_CS/commit/8e3b6f4
Список метамодулей
[ 1] Reunion          RUN   -    reunion_mm_i386.so          v0.1.0.92       ini  Start Never
[ 2] ReAuthCheck RUN - reauthcheck_mm_i386.so v0.1.6 ini Start Never
[ 3] Rechecker RUN - rechecker_mm_i386.so v2.5 ini Chlvl ANY
[ 4] AMX Mod X RUN - amxmodx_mm_i386.so v1.8.3-Re ini Start ANY
[ 5] VoiceTranscoder RUN - vtc.so v2017RC3 ini ANY ANY
[ 6] ReSRDetector RUN - resrdetector_mm_i386.so v0.1.0 ini Chlvl ANY
[ 7] WHBlocker RUN - whblocker_mm_i386.so v1.5.695 ini Chlvl ANY
[ 8] ReSemiclip RUN - resemiclip_mm_i386.so v2.3.9 ini Chlvl ANY
[ 9] MySQL RUN - mysql_amxx_i386.so v1.8.3-Re pl4 ANY ANY
[10] ReAimDetector RUN - reaimdetector_amxx_i386.so v0.2.2 pl4 ANY Never
[11] Fun RUN - fun_amxx_i386.so v1.8.3-Re pl4 ANY ANY
[12] Engine RUN - engine_amxx_i386.so v1.8.3-Re pl4 ANY ANY
[13] FakeMeta RUN - fakemeta_amxx_i386.so v1.8.3-Re pl4 ANY ANY
[14] CStrike RUN - cstrike_amxx_i386.so v1.8.3-Re pl4 ANY ANY
[15] Ham Sandwich RUN - hamsandwich_amxx_i386.so v1.8.3-Re pl4 ANY ANY
[16] hackdetector RUN - hackdetector_amxx_i386.so v0.15.328.lite pl4 ANY ANY
[17] ReAPI RUN - reapi_amxx_i386.so v5.6.0.156-dev pl4 ANY Never
17 plugins, 17 running
Список плагинов
Currently loaded plugins:
name version author file status
[ 1] FreshBans 1.4.0b kanagava fresh_bans_140_ running
[ 2] AMXBans: Core Gm 1.6 Larte Team amxbans_core.am running
[ 3] AMXBans: Main Gm 1.6 Larte Team amxbans_main.am running
[ 4] Admin ESP 0.3 unnamed & miRror admin_esp.amxx running
[ 5] RC BaseChanger freesrv custom rc_basechanger. stopped
[ 6] ReAimDetector API 0.2.2 ReHLDS Team reaimdetector.a running
[ 7] Aliases checker 1.0.3 kanagava alias_detector- running
[ 8] Anti Fast Strafe 10.1 Proffi+Seroff fast_strafe_det running
[ 9] Fast Fix # 1.1 PRoSToTeM@ fast_fix_hashsi running
[ 10] Smoke FIX 0.1 many Smoke_FIX.amxx running
[ 11] Fix AutoBuy Bug 1.4 PomanoB / UFPS.T autobuyfix.amxx running
[ 12] Server Packeting Prote Version 1. StevenlAFl fullupdate.amxx running
[ 13] Anti Podelka HLTV 1.5B Seroff podelka.amxx running
[ 14] ChangeNameBlock 1.0 google blockname.amxx running
[ 15] Gag Me 2.3.0 Radius gag_me.amxx running
[ 16] AES: StatsX 0.5.9 [REA serfreeman1337/s aes_statsx_cstr running
[ 17] CSStatsX SQL 0.7.4 serfreeman1337 csstatsx_sql.am running
[ 18] [ReAPI] AWPoff 1.4.3 PAffAEJIkA :3 awp_off.amxx running
[ 19] Example AWPoff API 1.0 PAffAEJIkA :3 example_t.amxx running
[ 20] [Reapi] Block Advert 1.4 neygomon block_advert.am running
[ 21] Admin Commands 1.8.3-Re AMXX Dev Team admincmd.amxx running
[ 22] Admin Help 1.8.3-Re AMXX Dev Team adminhelp.amxx running
[ 23] Slots Reservation 1.8.3-Re AMXX Dev Team adminslots.amxx running
[ 24] Menus Front-End 1.8.2 AMXX Dev Team menufront.amxx running
[ 25] Commands Menu 1.8.3-Re AMXX Dev Team cmdmenu.amxx running
[ 26] Players Menu 1.8.3-Re AMXX Dev Team plmenu.amxx running
[ 27] Maps Menu 1.8.1.3746 AMXX Dev Team mapsmenu.amxx running
[ 28] Plugin Menu 1.8.3-Re AMXX Dev Team pluginmenu.amxx running
[ 29] Admin Chat 1.8.3-Re AMXX Dev Team adminchat.amxx running
[ 30] Anti Flood 1.8.3-Re AMXX Dev Team antiflood.amxx running
[ 31] Scrolling Message 1.8.3-Re AMXX Dev Team scrollmsg.amxx running
[ 32] Info. Messages 1.8.3-Re AMXX Dev Team imessage.amxx running
[ 33] Admin Votes 1.8.3-Re AMXX Dev Team adminvote.amxx running
[ 34] TimeLeft 1.8.3-Re AMXX Dev Team timeleft.amxx running
[ 35] Pause Plugins 1.8.3-Re AMXX Dev Team pausecfg.amxx running
[ 36] Stats Configuration 1.8.3-Re AMXX Dev Team statscfg.amxx running
[ 37] Restrict Weapons 1.8.3-Re AMXX Dev Team restmenu.amxx running
[ 38] CS Misc. Stats 1.8.3-Re AMXX Dev Team miscstats.amxx running
[ 39] CS Stats Logging 1.8.3-Re AMXX Dev Team stats_logging.a running
[ 40] FM ResetScore 0.1 neygomon resetscore.amxx running
[ 41] Admin Free Look 2.0 Jim admin_freelook. running
[ 42] Autoresponder/Advertis 0.5 MaximusBrood ad_manager.amxx running
[ 43] Rat Bomb 1.0 Seroff rat_bomb.amxx running
[ 44] [AMXX] ViP Gold 1.0 Flymic24 amxx_vip_gold.a running
[ 45] Team Balance Control 1.3.9 gyxoBka TeamBalanceCont running
[ 46] Counter-advertising ni Free AVOG block_names.amx running
[ 47] TOP VIP (Auto Set) 1.0a Leo_[BH] top_vip.amxx running
[ 48] Best Player 0.2b Subb98 best_player.amx running
[ 49] Lite Vampire 1.2 neygomon lite_vampire.am running
[ 50] Auto recording demo 2.0 IzI | Bonaqua (R amx_autodemorec running
[ 51] AFK Bomb Transfer 0.4 VEN afkbombtransfer running
[ 52] Ping Control 1.31 neygomon Ping_Control.am running
[ 53] Steam Bonus 1.2 Stimul steam_bonus.amx running
[ 54] aKicker 0.0 belik afkkicker.amxx running
[ 55] Bullet Damage 0.0.1 ConnorMcLeod bullet_damage.a running
[ 56] Fade Screen 20.15 LegenDa fade_screen[pin running
[ 57] VoTeBan Player Menu 4.9 Sutar voteban.amxx running
[ 58] BanIP Fakes 0.2 Safety1st banip_fakes.amx running
[ 59] UFPS Anti Advertising 2.7 UFPS.Team antiadvert.amxx running
[ 60] HLstatsX CE Ingame Plu 1.6.19 (HL psychonic hlstatsx_comman running
[ 61] Parachute 1.3 Fixed sector/underwoke Parachute_admin running
[ 62] AdminListen 2.3x /dev/ urandom adminlisten.amx running
[ 63] Multi Jump 05.05.2018 w0w multi_jump.amxx running
[ 64] Walls Creator 1.1 d3m37r4 walls_creator.a running
[ 65] [ReAPI] SF Level Skins 0.1 serfreeman1337 sf_level_skins. running
[ 66] Team Flash Control 1.4.1 Radius team_flash_cont running
[ 67] [ReAPI] Block 'Fire in 0.0.1 sergrib reapi_block_FIT running
[ 68] Auto Restart In X Roun 0.3 He3aBuCuM auto_res_in_x_r running
[ 69] Admin Prefixes 4.1 m0skVi4a ;] AdminPrefixes.a running
[ 70] Advanced Experience Sy 0.5.9 [REA serfreeman1337/s aes_main.amxx running
[ 71] AES: CStrike Addon 0.5.9 [REA serfreeman1337/s aes_exp_cstrike running
[ 72] AES: Informer 0.5.9 [REA serfreeman1337/s aes_informer.am running
[ 73] AES: Admin Tools 0.5.9 [REA serfreeman1337/s aes_exp_editor. running
[ 74] AES: Bonus System 0.5.9 Vega serfreeman1337/s aes_bonus_syste running
[ 75] AES: Bonus CSTRIKE 0.5.9 [REA serfreeman1337/s aes_bonus_cstri running
[ 76] AMXBans: Screens Gm 1.6 Larte Team amxbans_ssban.a running
76 plugins, 75 running
Исходный код
#include <amxmodx>
#include <reaimdetector>

#pragma semicolon 1

#if !defined MAX_PLAYERS
#define MAX_PLAYERS 32
#endif

#if defined client_disconnected
#define player_disconnect client_disconnected
#else
#define player_disconnect client_disconnect
#endif

#define ENABLE_LOG_FILE // Включить логирование
#define RELOAD_CMD ADMIN_CFG // Флаг доступа к команде перезагрузки конфига: reaim_reloadcfg
#define MENU_CMD ADMIN_BAN // Флаг доступа к Aim меню: say /aim

enum CfgType
{
AIM = 1,
SPREAD,
PUNISH,
SAVE,
OTHER
}

#if (AMXX_VERSION_NUM < 183)

enum
{
print_team_default = 0,
print_team_grey = -1,
print_team_red = -2,
print_team_blue = -3
};

#define replace_string replace_all

#endif

new Trie:g_tAimBotSteamWarns, Trie:g_tAimBotIpWarns;
new Trie:g_tNoSpreadSteamWarns, Trie:g_tNoSpreadIpWarns;

new g_iAimDetection, g_iAimSens, g_iAimMultiWarn, g_iAimNotify, g_iAimMaxWarns, g_iAimShotsReset, g_iAimKillsReset, g_iAimTimeReset;
new g_iSaveType, g_iAimSaveWarns, g_iSpreadSaveWarns;
new g_iSpreadDetection, g_iSpreadNotify, g_iSpreadMaxWarns;
new g_iAlertFlag;
new g_iSendProtectionWeapon;
new g_iCrashCheat;
new g_iBanTime[PunishType];
new g_szBanReason[PunishType][64];
new g_szBanString[PunishType][128];

#if defined ENABLE_LOG_FILE
new g_FilePath[64], g_LogDir[128];
#endif

public plugin_init()
{
register_plugin("ReAimDetector API", REAIMDETECTOR_VERSION, "ReHLDS Team");

register_concmd("reaim_reloadcfg", "ReloadCfg", RELOAD_CMD);

register_clcmd("say /aim", "AimMenu", MENU_CMD);
register_clcmd("say_team /aim", "AimMenu", MENU_CMD);

g_tAimBotSteamWarns = TrieCreate();
g_tAimBotIpWarns = TrieCreate();
g_tNoSpreadSteamWarns = TrieCreate();
g_tNoSpreadIpWarns = TrieCreate();
}

public plugin_end()
{

#if defined ENABLE_LOG_FILE
new Map[32], BufLog[64];
get_mapname(Map, charsmax(Map));
formatex(BufLog, charsmax(BufLog), "End Map [%s]", Map);
SaveLogFile(BufLog);
#endif

TrieClear(g_tAimBotSteamWarns);
TrieClear(g_tAimBotIpWarns);
TrieClear(g_tNoSpreadSteamWarns);
TrieClear(g_tNoSpreadIpWarns);
}

public client_putinserver(id)
{
switch(g_iSaveType)
{
case 1:
{
new szSteam[33], iWarns;
get_user_authid(id, szSteam, charsmax(szSteam));

#if defined ENABLE_LOG_FILE
new szBufLog[190], szAddress[17], szName[32];
get_user_ip(id, szAddress, charsmax(szAddress), 1);
get_user_name(id, szName, charsmax(szName));
#endif

if(TrieKeyExists(g_tAimBotSteamWarns, szSteam))
{
TrieGetCell(g_tAimBotSteamWarns, szSteam, iWarns);
TrieDeleteKey(g_tAimBotSteamWarns, szSteam);

ad_set_client(id, AimWarn, iWarns);

#if defined ENABLE_LOG_FILE
formatex(szBufLog, charsmax(szBufLog), "Aim Warn Recovered (Steam): ID [%d] Name [%s] Steam [%s] IP [%s] Warn [%d]", id, szName, szSteam, szAddress, iWarns);
SaveLogFile(szBufLog);
#endif

}

if(TrieKeyExists(g_tNoSpreadSteamWarns, szSteam))
{
TrieGetCell(g_tNoSpreadSteamWarns, szSteam, iWarns);
TrieDeleteKey(g_tNoSpreadSteamWarns, szSteam);

ad_set_client(id, NoSpreadWarn, iWarns);

#if defined ENABLE_LOG_FILE
formatex(szBufLog, charsmax(szBufLog), "NoSpread Warn Recovered (Steam): ID [%d] Name [%s] Steam [%s] IP [%s] Warn [%d]", id, szName, szSteam, szAddress, iWarns);
SaveLogFile(szBufLog);
#endif

}
}
case 2:
{
new szAddress[17], iWarns;
get_user_ip(id, szAddress, charsmax(szAddress), 1);

#if defined ENABLE_LOG_FILE
new szBufLog[190], szSteam[33], szName[32];
get_user_authid(id, szSteam, charsmax(szSteam));
get_user_name(id, szName, charsmax(szName));
#endif

if(TrieKeyExists(g_tAimBotIpWarns, szAddress))
{
TrieGetCell(g_tAimBotIpWarns, szAddress, iWarns);
TrieDeleteKey(g_tAimBotIpWarns, szAddress);

ad_set_client(id, AimWarn, iWarns);

#if defined ENABLE_LOG_FILE
formatex(szBufLog, charsmax(szBufLog), "Aim Warn Recovered (IP): ID [%d] Name [%s] Steam [%s] IP [%s] Warn [%d]", id, szName, szSteam, szAddress, iWarns);
SaveLogFile(szBufLog);
#endif

}

if(TrieKeyExists(g_tNoSpreadIpWarns, szAddress))
{
TrieGetCell(g_tNoSpreadIpWarns, szAddress, iWarns);
TrieDeleteKey(g_tNoSpreadIpWarns, szAddress);

ad_set_client(id, NoSpreadWarn, iWarns);

#if defined ENABLE_LOG_FILE
formatex(szBufLog, charsmax(szBufLog), "NoSpread Warn Recovered (IP): ID [%d] Name [%s] Steam [%s] IP [%s] Warn [%d]", id, szName, szSteam, szAddress, iWarns);
SaveLogFile(szBufLog);
#endif

}
}
case 3:
{
new szSteam[33], szAddress[17], iWarns;
get_user_authid(id, szSteam, charsmax(szSteam));
get_user_ip(id, szAddress, charsmax(szAddress), 1);

#if defined ENABLE_LOG_FILE
new szBufLog[190], szName[32];
get_user_name(id, szName, charsmax(szName));
#endif

new bool:IsExistsAim = false;
new bool:IsExistsSpread = false;

if(TrieKeyExists(g_tAimBotSteamWarns, szSteam))
{
IsExistsAim = true;

TrieGetCell(g_tAimBotSteamWarns, szSteam, iWarns);
TrieDeleteKey(g_tAimBotSteamWarns, szSteam);

ad_set_client(id, AimWarn, iWarns);

#if defined ENABLE_LOG_FILE
formatex(szBufLog, charsmax(szBufLog), "Aim Warn Recovered (Steam): ID [%d] Name [%s] Steam [%s] IP [%s] Warn [%d]", id, szName, szSteam, szAddress, iWarns);
SaveLogFile(szBufLog);
#endif

}

if(TrieKeyExists(g_tAimBotIpWarns, szAddress))
{
if(IsExistsAim)
{
TrieDeleteKey(g_tAimBotIpWarns, szAddress);
}
else
{
TrieGetCell(g_tAimBotIpWarns, szAddress, iWarns);
TrieDeleteKey(g_tAimBotIpWarns, szAddress);

ad_set_client(id, AimWarn, iWarns);

#if defined ENABLE_LOG_FILE
formatex(szBufLog, charsmax(szBufLog), "Aim Warn Recovered (IP): ID [%d] Name [%s] Steam [%s] IP [%s] Warn [%d]", id, szName, szSteam, szAddress, iWarns);
SaveLogFile(szBufLog);
#endif

}
}

if(TrieKeyExists(g_tNoSpreadSteamWarns, szSteam))
{
IsExistsSpread = true;

TrieGetCell(g_tNoSpreadSteamWarns, szSteam, iWarns);
TrieDeleteKey(g_tNoSpreadSteamWarns, szSteam);

ad_set_client(id, NoSpreadWarn, iWarns);

#if defined ENABLE_LOG_FILE
formatex(szBufLog, charsmax(szBufLog), "NoSpread Warn Recovered (Steam): ID [%d] Name [%s] Steam [%s] IP [%s] Warn [%d]", id, szName, szSteam, szAddress, iWarns);
SaveLogFile(szBufLog);
#endif

}

if(TrieKeyExists(g_tNoSpreadIpWarns, szAddress))
{
if(IsExistsSpread)
{
TrieDeleteKey(g_tNoSpreadIpWarns, szAddress);
}
else
{
TrieGetCell(g_tNoSpreadIpWarns, szAddress, iWarns);
TrieDeleteKey(g_tNoSpreadIpWarns, szAddress);

ad_set_client(id, NoSpreadWarn, iWarns);

#if defined ENABLE_LOG_FILE
formatex(szBufLog, charsmax(szBufLog), "NoSpread Warn Recovered (IP): ID [%d] Name [%s] Steam [%s] IP [%s] Warn [%d]", id, szName, szSteam, szAddress, iWarns);
SaveLogFile(szBufLog);
#endif

}
}
}
}
}

public player_disconnect(id)
{
switch(g_iSaveType)
{
case 1:
{
new szSteam[33];
get_user_authid(id, szSteam, charsmax(szSteam));

new iAimBotWarns = ad_get_client(id, AimWarn);
new iNoSpreadWarns = ad_get_client(id, NoSpreadWarn);

if(iAimBotWarns >= g_iAimSaveWarns)
{
TrieSetCell(g_tAimBotSteamWarns, szSteam, iAimBotWarns);
}

if(iNoSpreadWarns >= g_iSpreadSaveWarns)
{
TrieSetCell(g_tNoSpreadSteamWarns, szSteam, iNoSpreadWarns);
}
}
case 2:
{
new szAddress[17];
get_user_ip(id, szAddress, charsmax(szAddress), 1);

new iAimBotWarns = ad_get_client(id, AimWarn);
new iNoSpreadWarns = ad_get_client(id, NoSpreadWarn);

if(iAimBotWarns >= g_iAimSaveWarns)
{
TrieSetCell(g_tAimBotIpWarns, szAddress, iAimBotWarns);
}

if(iNoSpreadWarns >= g_iSpreadSaveWarns)
{
TrieSetCell(g_tNoSpreadIpWarns, szAddress, iNoSpreadWarns);
}
}
case 3:
{
new szSteam[33], szAddress[17];
get_user_authid(id, szSteam, charsmax(szSteam));
get_user_ip(id, szAddress, charsmax(szAddress), 1);

new iAimBotWarns = ad_get_client(id, AimWarn);
new iNoSpreadWarns = ad_get_client(id, NoSpreadWarn);

if(iAimBotWarns >= g_iAimSaveWarns)
{
TrieSetCell(g_tAimBotSteamWarns, szSteam, iAimBotWarns);
TrieSetCell(g_tAimBotIpWarns, szAddress, iAimBotWarns);
}

if(iNoSpreadWarns >= g_iSpreadSaveWarns)
{
TrieSetCell(g_tNoSpreadSteamWarns, szSteam, iNoSpreadWarns);
TrieSetCell(g_tNoSpreadIpWarns, szAddress, iNoSpreadWarns);
}
}
}
}

public ReloadCfg(id, level, cid)
{
if(~get_user_flags(id) & level) {
return PLUGIN_CONTINUE;
}

ReadCfg();

client_print(id, print_console, "[Aim Detector]: Reload Cfg.");

return PLUGIN_HANDLED;
}

public AimMenu(id, level)
{
if(~get_user_flags(id) & level) {
return PLUGIN_CONTINUE;
}

static iPlayers[32], iNum, i, iPlayer;
get_players(iPlayers, iNum, "ch");

new szName[32], szInfo[3], szTempString[96];
new iMenu = menu_create("\wAim Detector Меню", "AimMenuHandler");

new bool:bFindPlayer = false;

for(i = 0; i < iNum; i++)
{
iPlayer = iPlayers[i];

new iAimBotWarns = ad_get_client(iPlayer, AimWarn);
new iNoSpreadWarns = ad_get_client(iPlayer, NoSpreadWarn);

if(iAimBotWarns == 0 && iNoSpreadWarns == 0) {
continue;
}

bFindPlayer = true;

get_user_name(iPlayer, szName, charsmax(szName));

formatex(szTempString, charsmax(szTempString), "\w%s \r[\yAim\r: \w%d\r|\yNoSpread\r: \w%d\r]", szName, iAimBotWarns, iNoSpreadWarns);

num_to_str(iPlayer, szInfo, charsmax(szInfo));
menu_additem(iMenu, szTempString, szInfo);
}

if(bFindPlayer)
{
menu_setprop(iMenu, MPROP_NUMBER_COLOR, "\r");
menu_setprop(iMenu, MPROP_EXIT, MEXIT_ALL);
menu_setprop(iMenu, MPROP_EXITNAME, "Выход");
menu_setprop(iMenu, MPROP_NEXTNAME, "Далее");
menu_setprop(iMenu, MPROP_BACKNAME, "Назад");

menu_display(id, iMenu);
}
else
{
new szBufNotify[190];
formatex(szBufNotify, charsmax(szBufNotify), "^1[^4Aim Detector^1] ^3Список ^1в ^4меню ^3пустой^1.");
client_print_color(id, print_team_default, szBufNotify);
}

return PLUGIN_HANDLED;
}

public AimMenuHandler(id, menu, item)
{
if (item == MENU_EXIT)
{
menu_destroy(menu);
return PLUGIN_HANDLED;
}

new iAccess, szInfo[3], iCallback;
menu_item_getinfo(menu, item, iAccess, szInfo, charsmax(szInfo), .callback = iCallback);

new iPlayer = str_to_num(szInfo);

new iAimWarn = ad_get_client(iPlayer, AimWarn);
new iSpreadWarn = ad_get_client(iPlayer, NoSpreadWarn);

new szBufNotify[190], szName[32];
get_user_name(iPlayer, szName, charsmax(szName));

formatex(szBufNotify, charsmax(szBufNotify), "^1[^4Aim Detector^1] ^3Name ^1[^4 %s ^1] ^3AimWarn ^1[^4 %d ^1] ^3NoSpreadWarn ^1[^4 %d ^1]", szName, iAimWarn, iSpreadWarn);
client_print_color(id, print_team_default, szBufNotify);

return PLUGIN_HANDLED;
}

public ad_init(const Version[], const Map[])
{

#if defined ENABLE_LOG_FILE
get_localinfo("amxx_logs", g_FilePath, charsmax(g_FilePath));
formatex(g_LogDir, charsmax(g_LogDir), "%s/reaimdetector", g_FilePath);

if(!dir_exists(g_LogDir))
{
mkdir(g_LogDir);
}
#endif

ReadCfg();

#if defined ENABLE_LOG_FILE
new szBufLog[190];
formatex(szBufLog, charsmax(szBufLog), "Start Map [%s] AimSens [%d] AimMaxWarns [%d] NoSpreadNotifyWarns [%d] NoSpreadMaxWarns [%d]",
Map, ad_get_cfg(AimSens), g_iAimMaxWarns, ad_get_cfg(NoSpreadNotifyWarns), g_iSpreadMaxWarns);

SaveLogFile(szBufLog);
#endif

}

public ad_notify(const index, const PunishType:pType, const NotifyType:nType, const Kills, const Shots, const Warn)
{
new szBufNotify[190], szName[32];

#if defined ENABLE_LOG_FILE
new szBufLog[190], szAddress[22], szSteam[33];

get_user_ip(index, szAddress, charsmax(szAddress));
get_user_authid(index, szSteam, charsmax(szSteam));
#endif

get_user_name(index, szName, charsmax(szName));

if(pType == AIMBOT)
{
if(nType == WARNING && Warn > g_iAimNotify)
{
formatex(szBufNotify, charsmax(szBufNotify), "^1[^4Aim Detector^1] ^3Name ^1[^4 %s ^1] ^3Warn ^1[^4 %d ^1] ^3MaxWarn ^1[^4 %d ^1]", szName, Warn, g_iAimMaxWarns);
Send_Notify_Admins(index, szBufNotify);

#if defined ENABLE_LOG_FILE
formatex(szBufLog, charsmax(szBufLog), "Aim Warn Add: ID [%d] Name [%s] Steam [%s] IP [%s] Warn [%d]", index, szName, szSteam, szAddress, Warn);
SaveLogFile(szBufLog);
#endif

}
else if(nType == DETECT)
{
formatex(szBufNotify, charsmax(szBufNotify), "^1[^4Aim Detector^1] ^3Name ^1[^4 %s ^1] ^3Detected", szName);
Send_Notify_Admins(index, szBufNotify);

#if defined ENABLE_LOG_FILE
formatex(szBufLog, charsmax(szBufLog), "Aim Detected: ID [%d] Name [%s] Steam [%s] IP [%s] Warn [%d]", index, szName, szSteam, szAddress, Warn);
SaveLogFile(szBufLog);
#endif

ad_set_client(index, AimCheck, 0);

PunishPlayer(index, AIMBOT);
}
}
else if(pType == NOSPREAD)
{
if(nType == WARNING && Warn > g_iSpreadNotify)
{
formatex(szBufNotify, charsmax(szBufNotify), "^1[^4NoSpread Detector^1] ^3Name ^1[^4 %s ^1] ^3Warn ^1[^4 %d ^1]", szName, Warn, g_iSpreadMaxWarns);
Send_Notify_Admins(index, szBufNotify);

#if defined ENABLE_LOG_FILE
formatex(szBufLog, charsmax(szBufLog), "NoSpread Warn Add: ID [%d] Name [%s] Steam [%s] IP [%s] Warn [%d]", index, szName, szSteam, szAddress, Warn);
SaveLogFile(szBufLog);
#endif

}
else if(nType == DETECT)
{
formatex(szBufNotify, charsmax(szBufNotify), "^1[^4NoSpread Detector^1] ^3Name ^1[^4 %s ^1] ^3Detected", szName);
Send_Notify_Admins(index, szBufNotify);

#if defined ENABLE_LOG_FILE
formatex(szBufLog, charsmax(szBufLog), "NoSpread Detected: ID [%d] Name [%s] Steam [%s] IP [%s] Warn [%d]", index, szName, szSteam, szAddress, Warn);
SaveLogFile(szBufLog);
#endif

ad_set_client(index, NoSpreadCheck, 0);

PunishPlayer(index, NOSPREAD);
}
}
}

#if defined ENABLE_LOG_FILE
public ad_aim_reset_warn(const index, const ResetType:rType, const Kills, const Shots)
{
new szBufLog[190], szName[32], szAddress[22], szSteam[33];

get_user_name(index, szName, charsmax(szName));
get_user_ip(index, szAddress, charsmax(szAddress));
get_user_authid(index, szSteam, charsmax(szSteam));

switch(rType)
{
case KILLED:
{
formatex(szBufLog, charsmax(szBufLog), "Killed Reset: ID [%d] Name [%s] Steam [%s] IP [%s] Kills [%d] Shots [%d]", index, szName, szSteam, szAddress, Kills + 1, Shots);
SaveLogFile(szBufLog);
}
case SHOTS:
{
formatex(szBufLog, charsmax(szBufLog), "Shots Reset: ID [%d] Name [%s] Steam [%s] IP [%s] Kills [%d] Shots [%d]", index, szName, szSteam, szAddress, Kills, Shots + 1);
SaveLogFile(szBufLog);
}
case TIME:
{
formatex(szBufLog, charsmax(szBufLog), "Time Reset: ID [%d] Name [%s] Steam [%s] IP [%s] Kills [%d] Shots [%d]", index, szName, szSteam, szAddress, Kills, Shots);
SaveLogFile(szBufLog);
}
}
}
#endif

stock ReadCfg()
{
new szFilePath[64];
get_localinfo("amxx_configsdir", szFilePath, charsmax(szFilePath));
formatex(szFilePath, charsmax(szFilePath), "%s/reaimdetector.ini", szFilePath);

new FileHandle = fopen(szFilePath, "rt");

if(!FileHandle)
{
set_fail_state("Error load cfg.");
}

new szTemp[256], szKey[32], szValue[512], iSection;

while(!feof(FileHandle))
{
fgets(FileHandle, szTemp, charsmax(szTemp));
trim(szTemp);

if (szTemp[0] == '[')
{
iSection++;
continue;
}

if(!szTemp[0] || szTemp[0] == ';' || szTemp[0] == '/') {
continue;
}

strtok(szTemp, szKey, charsmax(szKey), szValue, charsmax(szValue), '=');
trim(szKey);
trim(szValue);

switch(iSection)
{
case AIM:
{
if(equal(szKey, "AIM_DETECTION"))
g_iAimDetection = str_to_num(szValue);

else if(equal(szKey, "SENS"))
g_iAimSens = str_to_num(szValue);

else if(equal(szKey, "MULTI_WARN"))
g_iAimMultiWarn = str_to_num(szValue);

else if(equal(szKey, "NOTIFY_WARNS"))
g_iAimNotify = str_to_num(szValue);

else if(equal(szKey, "MAX_WARNS"))
g_iAimMaxWarns = str_to_num(szValue);

else if(equal(szKey, "SHOTS_RESET"))
g_iAimShotsReset = str_to_num(szValue);

else if(equal(szKey, "KILLS_RESET"))
g_iAimKillsReset = str_to_num(szValue);

else if(equal(szKey, "TIME_RESET"))
g_iAimTimeReset = str_to_num(szValue);
}
case SPREAD:
{
if(equal(szKey, "NOSPREAD_DETECTION"))
g_iSpreadDetection = str_to_num(szValue);

else if(equal(szKey, "NOTIFY_WARNS"))
g_iSpreadNotify = str_to_num(szValue);

else if(equal(szKey, "MAX_WARNS"))
g_iSpreadMaxWarns = str_to_num(szValue);
}
case PUNISH:
{
if(equal(szKey, "REASON_AIMBOT"))
copy(g_szBanReason[AIMBOT], charsmax(g_szBanReason[]), szValue);

else if(equal(szKey, "BAN_TIME_AIMBOT"))
g_iBanTime[AIMBOT] = str_to_num(szValue);

else if(equal(szKey, "REASON_NOSPREAD"))
copy(g_szBanReason[NOSPREAD], charsmax(g_szBanReason[]), szValue);

else if(equal(szKey, "BAN_TIME_NOSPREAD"))
g_iBanTime[NOSPREAD] = str_to_num(szValue);

else if(equal(szKey, "PUNISH_AIMBOT"))
copy(g_szBanString[AIMBOT], charsmax(g_szBanString[]), szValue);

else if(equal(szKey, "PUNISH_NOSPREAD"))
copy(g_szBanString[NOSPREAD], charsmax(g_szBanString[]), szValue);

}
case SAVE:
{
if(equal(szKey, "TYPE"))
g_iSaveType = str_to_num(szValue);

else if(equal(szKey, "AIM_WARNS"))
g_iAimSaveWarns = str_to_num(szValue);

else if(equal(szKey, "NOSPREAD_WARNS"))
g_iSpreadSaveWarns = str_to_num(szValue);
}
case OTHER:
{
if(equal(szKey, "FLAG_ALERT"))
{
new szFlags[21];
copy(szFlags, charsmax(szFlags), szValue);

g_iAlertFlag = read_flags(szFlags);
}

else if(equal(szKey, "SEND_PROTECTION_WEAPON"))
g_iSendProtectionWeapon = str_to_num(szValue);

else if(equal(szKey, "CRASH_CHEAT"))
g_iCrashCheat = str_to_num(szValue);
}
}
}

fclose(FileHandle);

SetCfg();

return PLUGIN_CONTINUE;
}

stock SetCfg()
{
ad_set_cfg(AimDetection, g_iAimDetection);
ad_set_cfg(AimSens, g_iAimSens);
ad_set_cfg(AimMultiWarns, g_iAimMultiWarn);
ad_set_cfg(AimNotifyWarns, g_iAimNotify);
ad_set_cfg(AimMaxWarns, g_iAimMaxWarns);
ad_set_cfg(AimShotsReset, g_iAimShotsReset);
ad_set_cfg(AimKillsReset, g_iAimKillsReset);
ad_set_cfg(AimTimeReset, g_iAimTimeReset);
ad_set_cfg(NoSpreadDetection, g_iSpreadDetection);
ad_set_cfg(NoSpreadNotifyWarns, g_iSpreadNotify);
ad_set_cfg(NoSpreadMaxWarns, g_iSpreadMaxWarns);
ad_set_cfg(SendProtectionWeapon, g_iSendProtectionWeapon);
ad_set_cfg(CrashCheat, g_iCrashCheat);
}

stock PunishPlayer(id, PunishType:iType)
{
new szUserId[10], szSteam[33], szIp[17], szTime[10], szBanString[128];

formatex(szUserId, charsmax(szUserId), "#%d", get_user_userid(id));

get_user_authid(id, szSteam, charsmax(szSteam));
get_user_ip(id, szIp, charsmax(szIp), 1);

num_to_str(g_iBanTime[iType], szTime, charsmax(szTime));

copy(szBanString, charsmax(szBanString), g_szBanString[iType]);

replace_string(szBanString, charsmax(szBanString), "[userid]", szUserId);
replace_string(szBanString, charsmax(szBanString), "[steam]", szSteam);
replace_string(szBanString, charsmax(szBanString), "[ip]", szIp);
replace_string(szBanString, charsmax(szBanString), "[reason]", g_szBanReason[iType]);
replace_string(szBanString, charsmax(szBanString), "[time]", szTime);

server_cmd("%s", szBanString);
}

stock Send_Notify_Admins(const NotifyIndex, const Msg[])
{
new Players[MAX_PLAYERS], iNum, iReceiver;
get_players(Players, iNum, "ch");

for (new i = 0; i < iNum; ++i)
{
iReceiver = Players[i];

if(NotifyIndex == iReceiver || !(get_user_flags(iReceiver) & g_iAlertFlag)) {
continue;
}

client_print_color(iReceiver, print_team_default, Msg);
}
}

#if defined ENABLE_LOG_FILE
stock SaveLogFile(const LogText[])
{
new LogFileTime[32], LogTime[32], LogFile[128], LogMsg[190];

get_time("20%y.%m.%d", LogFileTime, charsmax(LogFileTime));
get_time("%H:%M:%S", LogTime, charsmax(LogTime));

formatex(LogFile, charsmax(LogFile), "%s/%s.log", g_LogDir, LogFileTime);
formatex(LogMsg, charsmax(LogMsg), "[%s] [%s] %s", LogFileTime, LogTime, LogText);

write_file(LogFile, LogMsg, -1);
}
#endif

#if (AMXX_VERSION_NUM < 183)
stock client_print_color(const id, const iSender, const input[], any:...)
{
static iSayText = 0;
if (!iSayText) {
iSayText = get_user_msgid("SayText");
}
new iReceiver, iNum = 1, Players[MAX_PLAYERS], Msg[190];
vformat(Msg, charsmax(Msg), input, 3);
if(id)
{
if(!is_user_connected(id)) {
return;
}
Players[0] = id;
} else {
get_players(Players, iNum, "ch");
}
for (new i = 0; i < iNum; i++)
{
iReceiver = Players[i];
message_begin(MSG_ONE, iSayText , _, iReceiver);
write_byte(iSender ? iSender : iReceiver);
write_string(Msg);
message_end();
}
}
#endif
Мучаю голову над этой ошибкой уже давно.
Инклуд реапи есть. Конфиг по дефолту. Разные Компиляторы перепробовал, всегда без ошибок компилит а потом в логах такое.
debug прописывал, тоже самое вылазит.
 
В этой теме было размещено решение! Перейти к решению.
Сообщения
2,143
Реакции
1,225
Помог
44 раз(а)
Конфиг ReAD пришлите.
И зачем Вам два одновременно работающий модуля: hackdetector и ReSRDetector?

Да и античиты я бы на Вашем месте выше FB в списке плагинов поставил.
 
Последнее редактирование:
Сообщения
2,752
Реакции
3,017
Помог
61 раз(а)
Minni, пихают что попало. Потом жалуются, что стрельба плохая ?.
 
Сообщения
45
Реакции
-3
Minni, Спасибо, что подсказали за hackdetector. Я совсем забыл выключить его. Спасибо за советы на счет античитов.
[AIMBOT]

; Включить Обнаружение AimBot (0 | 1)
AIM_DETECTION = 1

; Чувствительность Обнаружения AimBot (0 | 10)
SENS = 8

; Активация Выдачи Нескольких Предупреждений За Одну Проверку [Отключите для DeathMatch] (0 | 1)
MULTI_WARN = 1

; Предупреждений до Начала Оповещения Админов в Чате (0 | 50)
NOTIFY_WARNS = 3

; Предупреждений до Обнаружения AimBot (2 | 50)
MAX_WARNS = 5

; Сброс Предупреждений После N Чистых Выстрелов (5 | 1000)
SHOTS_RESET = 40

; Сброс Предупреждений После N Убийств Противников (10 | 500)
KILLS_RESET = 20

; Сброс Предупреждений После N Секунд с Последнего Предупреждения (30 | 1800)
TIME_RESET = 200

[NOSPREAD]

; Включить Обнаружение NoSpread (0 | 1)
NOSPREAD_DETECTION = 1

; Предупреждений до Начала Оповещения Админов в Чате (15 | 300)
NOTIFY_WARNS = 15

; Предупреждений до Обнаружения NoSpread (25 | 300)
MAX_WARNS = 40

[PUNISH]

; Причина Наказания за AimBot
REASON_AIMBOT = Aim Detected

; Время Назания за AimBot
BAN_TIME_AIMBOT = 43200

; Причина Наказания за NoSpread
REASON_NOSPREAD = NoSpread Detected

; Время Наказания за NoSpread
BAN_TIME_NOSPREAD = 43200

; Формирование Строки Команды Бана
; Параметры для Подстановки:
; [time] - Время бана
; [userid] - Userid игрока
; [steam] - SteamID игрока
; [ip] - IP игрока
; [reason] - Причина бана
; Строка Наказания за Обнаружение AimBot (Максимальная длина 127 символов)
PUNISH_AIMBOT = amx_ban [time] [userid] [reason]

; Строка Наказания за Обнаружение NoSpread (Максимальная длина 127 символов)
PUNISH_NOSPREAD = amx_ban [time] [userid] [reason]

[SAVE]

; Сохранение Предупреждений После Перезахода Игрока на Сервер (0 | 3)
; 0 - отключено | 1 - SteamID | 2 - IP | 3 - SteamID или IP
TYPE = 1

; Минимальное Количество Предупреждений для Сохранения за AimBot (2 | 50)
AIM_WARNS = 2

; Минимальное Количество Предупреждений для Сохранения за NoSpread (15 | 300)
NOSPREAD_WARNS = 15

[OTHER]

; Флаг(и) Админа, Который Будет Видеть Оповещения (Пример: abcde)
FLAG_ALERT = d

; Включить Защищенную Отправку Оружия (0 | 1)
SEND_PROTECTION_WEAPON = 0

; Включить Crash Читов (0 | 1)
CRASH_CHEAT = 0

wopox1337, не понял к чему это было сказано в этой теме. Тем более я на стрельбу не жаловался
 
Сообщения
2,143
Реакции
1,225
Помог
44 раз(а)
не понял к чему это было сказано в этой теме. Тем более я на стрельбу не жаловался
Это был сарказм в сторону двух работающих модулей, которые я выше упомянул.

Данная ошибка появляется произвольно или после выполнения каких-либо действий, например, перезагрузки конфига командой reaim_reloadcfg?
 
Сообщения
45
Реакции
-3
Minni, Сарказ правильный, просто не уследил, плагин вырубил давно, а за модуль забыл))
Ошибка появляется при запуске карты сразу в консоле.
 
Сообщения
2,143
Реакции
1,225
Помог
44 раз(а)
elf01, по какому пути находится конфиг и какая у него кодировка?
 
Сообщения
45
Реакции
-3
Minni, gamedir/cstrike/addons/amxmodx/configs/тут файл. Кодировка просто UTF-8. Стандартно указанная в файле темы.
Все как в описании проделано, он даже детектил и логи есть, но ошибка всеравно как-то волнует меня.
 
Сообщения
45
Реакции
-3
Minni, да. Желательно б и в и в теме файл то перекодировать.
 
Сообщения
271
Реакции
348
Помог
15 раз(а)
Скрытое содержимое для пользователей: elf01
 
Сообщения
2,143
Реакции
1,225
Помог
44 раз(а)
elf01, в архиве с ReAD данный конфиг уже с нужной кодировкой.
 
Статус
В этой теме нельзя размещать новые ответы.

Пользователи, просматривающие эту тему

Сейчас на форуме нет ни одного пользователя.
Сверху Снизу