Weishaypt

Фикс читов при помощи плагина Pawn.RakNet

В теме 1 сообщение

Вступление

Здравствуйте, Уважаемые пользователи форума. В прошедшем 2018 года появилось не мало читов, которые отправляют невалидные данные в пакет или RPC. Из-за которых происходит краш или другие вредительские действия. В сегодняш я приведу примеры фикса этих читов с использованием плагина Pawn.Raknet.

Скачать плагин Pawn.RakNet

Автор плагина: urShadow

Адаптировал для 0.3e: H-U-N-T-E-R

Скачать плагин с серверов форума: https://pawno-rus.ru/files/file/500-pawnraknet-for-crmp-03e/

 

Onfoot Crasher

Этот крашер отправляет невалидные данные в пакет AimSync. Вследствие чего у игроков, которые находятся в стриме читера происходит краш.

Чтобы этого не происходило нам достаточно проверять данные и производить десинхронизацию. Подключите плагин к вашему моду и добавьте этот код в конец вашего мода. Так же стоит учесть, что ID пакетов и RPC в CRMP и SAMP отличаются, поэтому в конце урока приведу список ID пакетов и RPC для CR-MP 0.3e

const ID_AIM_SYNC = 117; //ID пакета
IPacket:ID_AIM_SYNC(playerid, BitStream:bs)
{
	new AIMSYNC[PR_AimSync];

	BS_IgnoreBits(bs, 8); //Игнорируем биты
	BS_ReadAimSync(bs, AIMSYNC);//Считываем информацию
	
  	//Выполняем проверку
 	if(AIMSYNC[PR_camFrontVec][0] != AIMSYNC[PR_camFrontVec][0] || floatcmp(floatabs(AIMSYNC[PR_camFrontVec][0]), 1.0000) == 1
		|| AIMSYNC[PR_camFrontVec][1] != AIMSYNC[PR_camFrontVec][1] || floatcmp(floatabs(AIMSYNC[PR_camFrontVec][1]), 1.0000) == 1
		|| AIMSYNC[PR_camFrontVec][2] != AIMSYNC[PR_camFrontVec][2] || floatcmp(floatabs(AIMSYNC[PR_camFrontVec][2]), 1.0000) == 1
		|| AIMSYNC[PR_camPos][0] != AIMSYNC[PR_camPos][0] || floatcmp(floatabs(AIMSYNC[PR_camPos][0]), 3500.0000) == 1
		|| AIMSYNC[PR_camPos][1] != AIMSYNC[PR_camPos][1] || floatcmp(floatabs(AIMSYNC[PR_camPos][1]), 3500.0000) == 1
		|| AIMSYNC[PR_camPos][2] != AIMSYNC[PR_camPos][2] || floatcmp(floatabs(AIMSYNC[PR_camPos][2]), 3500.0000) == 1)
	{
        	return false; // Делаем десинхронизацию
	}
    return 1;
}

Респавн всех авто сервера

Этот чит отправляет в RPC VehicleDestroyed нулевой id авто. Из-за чего все машины сервера респавнятся. Чтобы машины не респавнились будем проверять id авто, если оно будет равно 0, то будем делать десинхронизацию игроку.

const ID_VehicleDestroyed = 9;//ID RPC
IRPC:ID_VehicleDestroyed(playerid, BitStream:bs)
{
    new vehicleid;
    BS_IgnoreBits(bs, 8);//игнорируем биты
    BS_ReadUint16(bs, vehicleid);//Считываем информацию

    //Делаем проверку
    if(vehicleid == 0)
    {
        return false; //Делаем десинхронизацию
    }
    return 1;
}

На это сегодня всё. Возможно буду дополнять, как появятся новые уязвимости. Все эти же действия можно было выполнить и с использованием другого плагина RaknetManager, но это уже отдельная история.

Автор статьи: Weishaypt

Копирование на другие источники разрешено ТОЛЬКО с указанием автора и активной ссылки на источник (PAWNO-RUS.RU)! 

Спойлер

##### Входящие РПЦ #####
patch_incoming_rpc = "ConnectionRejected"        13     
patch_incoming_rpc = "ClientMessage"             14     
patch_incoming_rpc = "SetWorldTime"              15     
patch_incoming_rpc = "SetPlayerWeather"          19     
patch_incoming_rpc = "SetPlayerSkin"             20     
patch_incoming_rpc = "SetPlayerName"             21     
patch_incoming_rpc = "SetPlayerPos"              22     
patch_incoming_rpc = "SetPlayerPosFindZ"         23     
patch_incoming_rpc = "SetPlayerHealth"           24     
patch_incoming_rpc = "PutPlayerInVehicle"        25     
patch_incoming_rpc = "RemovePlayerFromVehicle"   26     
patch_incoming_rpc = "SetPlayerColor"            27     
patch_incoming_rpc = "DisplayGameText"           28     
patch_incoming_rpc = "ForceSpawnSelection"       29     
patch_incoming_rpc = "AttachObjectToPlayer"      30     
patch_incoming_rpc = "InitMenu"                  31     
patch_incoming_rpc = "ShowMenu"                  32     
patch_incoming_rpc = "HideMenu"                  33     
patch_incoming_rpc = "SetPlayerWantedLevel"      34     
patch_incoming_rpc = "ShowTextDraw"              35     
patch_incoming_rpc = "HideTextDraw"              36     
patch_incoming_rpc = "EnableStuntBonus"          37     
patch_incoming_rpc = "EditTextDraw"              38     
patch_incoming_rpc = "AddGangZone"               39     
patch_incoming_rpc = "PlayCrimeReportForPlayer"  43     
patch_incoming_rpc = "PlayAudioStream"           45     
patch_incoming_rpc = "StopAudioStreamForPlayer"  46     
patch_incoming_rpc = "RemoveBuildingForPlayer"   47     
patch_incoming_rpc = "CreateObject"              48     
patch_incoming_rpc = "SetObjectPos"              49     
patch_incoming_rpc = "SetObjectRotation"         50     
patch_incoming_rpc = "DestroyObject"             51     
patch_incoming_rpc = "CreateExplosion"           54     
patch_incoming_rpc = "ShowNameTagForPlayer"      55     
patch_incoming_rpc = "AttachCameraToObject"      56     
patch_incoming_rpc = "ClickTextDraw"             58     
patch_incoming_rpc = "GiveTakeDamage"            60     
patch_incoming_rpc = "EditAttachedObject"        61     
patch_incoming_rpc = "EditObject"                62     
patch_incoming_rpc = "SelectObject"              63     
patch_incoming_rpc = "CancelEdit"                64     
patch_incoming_rpc = "WorldPlayerAdd"            69     
patch_incoming_rpc = "SetShopName"               70     
patch_incoming_rpc = "SetDrunkLevel"             72     
patch_incoming_rpc = "SetChatBubble"             75     
patch_incoming_rpc = "ShowDialog"                77     
patch_incoming_rpc = "VehicleParams"             80     
patch_incoming_rpc = "RemoveGangZone"            82     
patch_incoming_rpc = "ClientJoin"                81     
patch_incoming_rpc = "FlashGangZone"             83    
patch_incoming_rpc = "StopFlashGangZone"         84     
patch_incoming_rpc = "ApplyAnimation"            85     
patch_incoming_rpc = "ClearAnimations"           86     
patch_incoming_rpc = "SetSpecialAction"          87     
patch_incoming_rpc = "SetFightingStyle"          88     
patch_incoming_rpc = "SetPlayerVelocity"         89     
patch_incoming_rpc = "SetVehicleVelocity"        90     
patch_incoming_rpc = "MoveObject"                94     
patch_incoming_rpc = "StopObject"                95     
patch_incoming_rpc = "TogglePlayerSpectating"    97     
patch_incoming_rpc = "SetPlayerSpectating"       98     
patch_incoming_rpc = "PlayerSpectatePlayer"      99     
patch_incoming_rpc = "PlayerSpectateVehicle"     100    
patch_incoming_rpc = "UpdateScoresPingsIPs"      105   
patch_incoming_rpc = "SetPlayerInterior"         106    
patch_incoming_rpc = "SetCameraPos"              107    
patch_incoming_rpc = "SetCameraLookAt"           108    
patch_incoming_rpc = "SetVehiclePos"             109    
patch_incoming_rpc = "SetVehicleZAngle"          110    
patch_incoming_rpc = "SetVehicleParamsForPlayer" 111    
patch_incoming_rpc = "SetCameraBehindPlayer"     112    
patch_incoming_rpc = "TogglePlayerControllable"  113    
patch_incoming_rpc = "PlaySound"                 114    
patch_incoming_rpc = "SetPlayerWorldBounds"      115    
patch_incoming_rpc = "GivePlayerMoney"           116    
patch_incoming_rpc = "SetPlayerFacingAngle"      117    
patch_incoming_rpc = "ResetMoney"                118    
patch_incoming_rpc = "ResetPlayerWeapons"        119    
patch_incoming_rpc = "GivePlayerWeapon"          120    
patch_incoming_rpc = "LinkVehicleToInterior"     122    
patch_incoming_rpc = "SetPlayerArmour"           123    
patch_incoming_rpc = "SetSpawnInfo"              125    
patch_incoming_rpc = "SetPlayerTeam"             126    
patch_incoming_rpc = "DeathMessage"              153    
patch_incoming_rpc = "SetMapIcon"                154    
patch_incoming_rpc = "DisableMapIcon"            155    
patch_incoming_rpc = "SetGravity"                157   
patch_incoming_rpc = "SetVehicleHealth"          158    
patch_incoming_rpc = "AttachTrailerToVehicle"    159    
patch_incoming_rpc = "DetachTrailerFromVehicle"  160    
patch_incoming_rpc = "AddVehicleComponent"       161    

##### Исходящие РПЦ #####
patch_outcoming_rpc = "ServerCommand"         6      
patch_outcoming_rpc = "SetInteriorId"         7      
patch_outcoming_rpc = "MapMarker"             8      
patch_outcoming_rpc = "VehicleDestroyed"      9      
patch_outcoming_rpc = "ServerJoin"            10     
patch_outcoming_rpc = "ServerQuit"            11     
patch_outcoming_rpc = "InitGame"              12     
patch_outcoming_rpc = "ClickTextDraw"         58     
patch_outcoming_rpc = "GiveTakeDamage"        60     
patch_outcoming_rpc = "WorldPlayerAdd"        69     
patch_outcoming_rpc = "DialogResponse"        78     
patch_outcoming_rpc = "ClickPlayer"           79      0
patch_outcoming_rpc = "PlayerSpectatePlayer"  99     
patch_outcoming_rpc = "PlayerSpectateVehicle" 100    
patch_outcoming_rpc = "RequestClass"          101    
patch_outcoming_rpc = "RequestSpawn"          102    
patch_outcoming_rpc = "EnterVehicle"          103    
patch_outcoming_rpc = "ExitVehicle"           104    
patch_outcoming_rpc = "UpdateScoresPingsIPs"  105    
patch_outcoming_rpc = "WorldPlayerRemove"     127    
patch_outcoming_rpc = "WorldVehicleAdd"       128    
patch_outcoming_rpc = "WorldVehicleRemove"    129    
patch_outcoming_rpc = "WorldPlayerDeath"      130    
patch_outcoming_rpc = "DamageVehicle"         131   
patch_outcoming_rpc = "GameModeRestart"       136    
patch_outcoming_rpc = "Chat"                  138    
patch_outcoming_rpc = "ScmEvent"              140    
patch_outcoming_rpc = "PickedUpPickup"        142    
patch_outcoming_rpc = "MenuSelect"            143    
patch_outcoming_rpc = "MenuQuit"              144    
patch_outcoming_rpc = "Spawn"                 150    
patch_outcoming_rpc = "Death"                 151    
patch_outcoming_rpc = "NPCJoin"               152    

##### Входящие пакеты #####
patch_incoming_packet = "Authentication"          12     
patch_incoming_packet = "ConnectionAccepted"      34     
patch_incoming_packet = "ConnectionAttemptFailed" 29     
patch_incoming_packet = "InvalidPassword"         37     
patch_incoming_packet = "ConnectionLost"          33     
patch_incoming_packet = "ConnectionClosed"        32     
patch_incoming_packet = "NoFreeConnections"       31     
patch_incoming_packet = "ConnectionBanned"        35     
patch_incoming_packet = "UnoccupiedData"          110    
patch_incoming_packet = "MarkersData"             111    
patch_incoming_packet = "WeaponData"              112    
patch_incoming_packet = "TrailerData"             114    
patch_incoming_packet = "PassengerData"           115    
patch_incoming_packet = "PlayerData"              116    
patch_incoming_packet = "AimData"                 117    
patch_incoming_packet = "VehicleData"             118    

##### Исходящие пакеты #####
patch_outcoming_packet = "Authentication" 12     
patch_outcoming_packet = "UnoccupiedData" 110    
patch_outcoming_packet = "MarkersData"    111    
patch_outcoming_packet = "WeaponData"     112    
patch_outcoming_packet = "SpectatingData" 113    
patch_outcoming_packet = "TrailerData"    114    
patch_outcoming_packet = "PassengerData"  115    
patch_outcoming_packet = "PlayerData"     116   
patch_outcoming_packet = "AimData"        117    
patch_outcoming_packet = "VehicleData"    118   

 

Отредактировано пользователем odosenok

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


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

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

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

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

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


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

Войти

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


Войти

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

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

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

    • Mister Odin
      От Mister Odin
       
      new
       g_teleport_list[39][E_TELEPORT_LIST] = {  {"Спавн пгт.Батырево", 1802.3612, 2508.4824, 15.8887},  {"Спавн г.Арзамас", -113.5887, 977.7222, 12.0346},     {"Спавн г.Южный", 2744.2770, -2446.7246, 21.8988},     {"Центральный банк", 1852.020385,2040.791381,15.892713},  {"Рублёвка", -837.7783, 888.6161, 12.7232},  {"Казино", 1332.4252, 2358.7014, 17.6641},  {"Битва за контейнеры", 614.5167, 1722.3566, 12.0709},  {"Автосалон низкого класса", 2493.9616, -722.9544, 12.3315},  {"Автосалон среднего класса", 1407.7449, 455.4801, 13.1630},  {"Автосалон высокого класса", -14.0637, 2614.5664, 10.9892},   {"Мотосалон Harley Davidson", 785.720153, 750.465087, 12.000024},  {"Автошкола", 1909.174438,2227.679687,15.708162},  {"Военкомат", 1916.778564,2302.411376,15.574637},  {"Правительство области", -139.140975,593.789611,12.145712},  {"Отдел полиции №1 (ГИБДД)", 1906.805786,-2234.382812,11.257631},  {"Отдел полиции №2 (УМВД)", 2581.309326,-2416.139892,21.960090},  {"Отдел ФСБ", 1823.904663,2095.636718,15.848405},  {"Городская больница г.Арзамас", -285.797210,581.851562,12.120290},   {"СМИ", -317.708038,821.221679,13.051450},  {"Воинская часть", 1703.197265,1678.025878,15.279437},  {"Арзамасская ОПГ", 438.705322,1046.505126,12.002637},  {"Батыревская ОПГ", 1941.203857,2161.006591,15.705187},  {"Лыткаринская ОПГ", -2346.002441,75.257041,21.002962},  {"Шахта", 2381.5727, 1726.4451, -2.1506},  {"Завод", -1062.6697, 2204.1894, 38.0964},  {"Инкосация", 1864.1374, 2011.7136, 15.8546},  {"Транспортная Компания", 2362.1115, 1972.5627, 15.5530},  {"База механиков", 1840.918090,-118.025146,15.695312},  {"Курьерская служба доставки", 2764.509765,-2396.882568,21.890625},  {"Аренда автобуса(Южный)", 2771.041992,-2454.780761,21.845964},  {"Аренда автобуса(Арзамас)", -127.487670,943.652648,12.142824},   {"Аренда автобуса(Батырево)", 1798.986328,2529.591552,15.664262},  {"Гоночная трасса", -1568.7784, 1611.8305, 36.3971},  {"Дом на горе", -789.5397, -456.7479, 741.1422},  {"СТО и тюнинг-ателье", 1856.1375, -122.3266, 15.6888},  {"Аренда транспорта пгт.Батырево", 1763.641723,2255.673339,15.865348},  {"Аренда транспорта г.Арзамас", -36.923530,1360.673583,12.002090},  {"Аренда транспорта г.Южный", 1966.599975,-2603.943603,10.820312},  {"Тайный интерьер в Лыткарино", -2424.5818, 2846.3291, 40.7908} };