25.06.2013, 05:16
There's no need to check if they're logged in unless you force them to register before they can even play.
There are a LOT of things that can go wrong with weapon hax checks, spawning and lag just to name a few. I would definitely not automatically kick the player, instead send it to admin chat that the player might be hacking and include the server and client weapon / ammo information.
The SetTimer("MaticAntiWeaponHack", 10000, false); line should only have to go in your OnGameModeInit / OnFilterscriptInit, I don't see what putting it in the main AC function does for you other than remake the timer over and over every time it gets triggered. Which seems a bit wasteful.
You're doing a LOT more in SafeGivePlayerWeapon than you have to. I suggest you make a new boolrotected[MAX_PLAYERS] and set that to true in your SafeGivePlayerWeapon. After that, check if he's paused - if he is, wait for him to come back before doing you give him the weapon, otherwise protect him with protected to give him some time to sync.
Be aware that default ammunations in SAMP are all client-side. You should look around the forums for a scripted Ammunation filterscript and then whenever you give the player a gun with it, protect him. If you really want to keep the default ones (I don't recommend it), you will want to check if he's inside an ammunation and if he is, protect him from the weapon check.
This may also help you:
Good luck.
There are a LOT of things that can go wrong with weapon hax checks, spawning and lag just to name a few. I would definitely not automatically kick the player, instead send it to admin chat that the player might be hacking and include the server and client weapon / ammo information.
The SetTimer("MaticAntiWeaponHack", 10000, false); line should only have to go in your OnGameModeInit / OnFilterscriptInit, I don't see what putting it in the main AC function does for you other than remake the timer over and over every time it gets triggered. Which seems a bit wasteful.
You're doing a LOT more in SafeGivePlayerWeapon than you have to. I suggest you make a new boolrotected[MAX_PLAYERS] and set that to true in your SafeGivePlayerWeapon. After that, check if he's paused - if he is, wait for him to come back before doing you give him the weapon, otherwise protect him with protected to give him some time to sync.
Be aware that default ammunations in SAMP are all client-side. You should look around the forums for a scripted Ammunation filterscript and then whenever you give the player a gun with it, protect him. If you really want to keep the default ones (I don't recommend it), you will want to check if he's inside an ammunation and if he is, protect him from the weapon check.
This may also help you:
pawn Код:
for (new j = 0; j < 13; j++) {
new wep, ammo;
GetPlayerWeaponData(i, j, wep, ammo);
if (ammo == 0) continue;
if (((Wep[i][j] != wep) || (ammo[i][j] < ammo)) && wep != 46 && wep != 40 && !Protection{i}) { //46 = parachute, player gets it when he exits certain aircraft. 40 = detonator from satchels
new t[126];
format(t, sizeof(t), "%s[%i] - Possibly pulled a %s with %i ammo out of his ass", playerName(i), i, GetWeaponName(wep), (ammo - ammo[i][j]));
sendAdminChat(t);
}
//Save all his client-side weapon data to his server-side info here. even if he really is weapon hacking, you don't want the chat to get spammed.
WeponCheckDone[i] = 1;
}