commit cec765e4538d5a0b696c2d87b58a67fe953d73ae Author: rubin Date: Sun Jan 28 17:50:46 2024 +0300 initial commit diff --git a/README.md b/README.md new file mode 100644 index 0000000..2367a55 --- /dev/null +++ b/README.md @@ -0,0 +1,9 @@ +[![Cкачать](pictures/download.png)](set-id.lua) +# [**Cкачать**](set-id.lua) +Перенести файл set-id.lua в папку moonloader\ +Для работы требуется Cleo / SampFuncs / Moоnloader + Samp.lua + +# Описание +С помощью этого скрипта можно искать нужный Вам ID. +Активация командой /setid [0] [999] - Диапазон от и до +Чтобы принудительно остановить - введите /setid без параметров \ No newline at end of file diff --git a/changelog b/changelog new file mode 100644 index 0000000..3afc22c --- /dev/null +++ b/changelog @@ -0,0 +1,5 @@ +Первый релиз 07.10.2020 +Версия от 28.01.2024 +- Fix Connection Rejected из-за неправильного выхода из игры +- Реконнект изменен с 15 на 5 секунд +- Добавлено авто-обновление \ No newline at end of file diff --git a/pictures/download.png b/pictures/download.png new file mode 100644 index 0000000..7c13b4a Binary files /dev/null and b/pictures/download.png differ diff --git a/pictures/menu.jpg b/pictures/menu.jpg new file mode 100644 index 0000000..5935150 Binary files /dev/null and b/pictures/menu.jpg differ diff --git a/pictures/youtube.png b/pictures/youtube.png new file mode 100644 index 0000000..e6780d9 Binary files /dev/null and b/pictures/youtube.png differ diff --git a/set-id.lua b/set-id.lua new file mode 100644 index 0000000..020fbf6 --- /dev/null +++ b/set-id.lua @@ -0,0 +1,370 @@ +script_name("set-id") +script_author("Serhiy_Rubin") +script_version("28.01.2024") + +require 'lib.moonloader' +require 'lib.sampfuncs' + +local sampev = require 'lib.samp.events' +local ffi = require("ffi") +local user32 = ffi.load("user32") -- Load User32 DLL handle + +ffi.cdef [[ bool SetCursorPos(int X, int Y); ]] +ffi.cdef([[ +enum{ + MB_OK = 0x00000000L, + MB_ICONINFORMATION = 0x00000040L +}; + +typedef void* HANDLE; +typedef HANDLE HWND; +typedef const char* LPCSTR; +typedef unsigned UINT; + +int MessageBoxA(HWND, LPCSTR, LPCSTR, UINT); +]]) +ffi.cdef [[ + typedef int BOOL; + typedef unsigned long HANDLE; + typedef HANDLE HWND; + typedef int bInvert; + HWND GetActiveWindow(void); + + BOOL FlashWindow(HWND hWnd, BOOL bInvert); + + HWND GetForegroundWindow(); +]] + +local setid, id1, id2 = false, 0, 0 +local timeconnect = 0 + +function main() + if not isSampLoaded() or not isSampfuncsLoaded() then return end + while not isSampAvailable() do wait(100) end + lua_thread.create(script_update.main) + sampRegisterChatCommand('setid', function(param) + if not setid then + if param:find('(%d+) (%d+)') then + setid = true + WorkInBackground(true) + if setid then + local S1, S2 = param:match('(%d+) (%d+)') + id1 = tonumber(S1) ; id2 = tonumber(S2) + local _, my_id = sampGetPlayerIdByCharHandle(PLAYER_PED) + for i = id1, id2 do + if i == my_id then + setid = false + WorkInBackground(false) + sampAddChatMessage(' ID: '..i..'. .', -1) + end + end + if setid then reconnect() end + return + end + end + else + setid = false + WorkInBackground(false) + sampAddChatMessage(' ID ', -1) + return + end + sampAddChatMessage(' /setid [0] [999] - ID', -1) + end) + + while true do + wait(0) + if setid then + local chatstring = sampGetChatString(99) + if chatstring == "Server closed the connection." then reconnect() end + if chatstring == "You are banned from this server." then reconnect() end + if chatstring == 'The server is restarting..' then reconnect() end + end + end +end + +function reconnect() + if (os.time() - timeconnect) > 6 then + sampAddChatMessage(' ID '..id1..' '..id2, -1) + lua_thread.create(function() + local bs = raknetNewBitStream() + raknetBitStreamWriteInt8(bs, PACKET_DISCONNECTION_NOTIFICATION) + raknetSendBitStream(bs) + raknetDeleteBitStream(bs) + + local bs = raknetNewBitStream() + raknetEmulPacketReceiveBitStream(PACKET_DISCONNECTION_NOTIFICATION, bs) + raknetDeleteBitStream(bs) + + timeconnect = os.time() + wait(5000+math.random(100, 500)) + sampSetGamestate(1) + end) + end +end + +function sampev.onInitGame(playerId, hostName, settings, vehicleModels, unknown) + lua_thread.create(function(playerId) + for i = id1, id2 do + if i == playerId then + setid = false + sampAddChatMessage(' ID: '..i..'. .', -1) + isAFK_Message(' ID: '..i..'. .') + WorkInBackground(false) + if ffi.C.GetActiveWindow() ~= nil then + lua_thread.create(function() + repeat wait(0) until sampIsCursorActive() + local X, Y = convertGameScreenCoordsToWindowScreenCoords(317.65740966797, 404.25) + ffi.C.SetCursorPos(X, Y) + setVirtualKeyDown(1, true) + setVirtualKeyDown(1, false) + end) + end + end + end + if setid then sampAddChatMessage(' ID: '..playerId..'. .', -1) ; reconnect() end + end, playerId) +end + +function isAFK_Message(text) + if ffi.C.GetActiveWindow() == nil then + user32.MessageBoxA(nil, text, "SetID", 0x00010000) + end +end + +function WorkInBackground(work) + local memory = require 'memory' + if work then -- on + memory.setuint8(7634870, 1) + memory.setuint8(7635034, 1) + memory.fill(7623723, 144, 8) + memory.fill(5499528, 144, 6) + memory.fill(0x00531155, 0x90, 5, true) + else -- off + memory.setuint8(7634870, 0) + memory.setuint8(7635034, 0) + memory.hex2bin('5051FF1500838500', 7623723, 8) + memory.hex2bin('0F847B010000', 5499528, 6) + end +end + +function openURL(url, fpath) + local text = "" + local file_download = false + local download_final = false + + + if doesFileExist(fpath) then + os.remove(fpath) + end + + downloadUrlToFile(url, fpath, function(id, status, p1, p2) + if status == dlstatus.STATUS_ENDDOWNLOADDATA then + file_download = true + end + if status == dlstatus.STATUSEX_ENDDOWNLOAD then + download_final = true + end + end + ) + + repeat + wait(1000) + until download_final or file_download + + if file_download then + local f = io.open(fpath, "r") + if f then + text = f:read("*a") + io.close(f) + end + os.remove(fpath) + end + + if (text:find("Not found") and not text:find('"Not found"')) or text == "" then + text = "" + addChatMessage(" :") + addChatMessage(url) + end + + return text +end +script_update = { + version_url = "http://git.deadpoo.net/rubin/set-id/raw/branch/master/version", + script_url = "http://git.deadpoo.net/rubin/set-id/raw/branch/master/set-id.lua", + changelog_url = "http://git.deadpoo.net/rubin/set-id/raw/branch/master/changelog", + address_ini = string.format("rubin-mods-updates\\%s.ini", thisScript().name), + main = function() + if not doesDirectoryExist("moonloader\\config\\rubin-mods-updates") then + createDirectory("moonloader\\config\\rubin-mods-updates") + end + local ini = inicfg.load({ + settings = { + check_update = true, + auto_update = true, + server_version = "" + } + }, script_update.address_ini) + ini.settings.version_url = script_update.version_url + ini.settings.script_url = script_update.script_url + ini.settings.changelog_url = script_update.changelog_url + ini.settings.version = thisScript().version + ini.settings.script_name = thisScript().name + local command = (thisScript().name:gsub(" ", "").."-update"):lower() + sampRegisterChatCommand(command, script_update.command) + if ini.settings.check_update or ini.settings.auto_update then + local fpath = os.tmpname() + local result, text = pcall(openURL, script_update.version_url, fpath) + if result then + ini.settings.server_version = text + if text ~= "" and text ~= thisScript().version then + addChatMessage( string.format(" '%s'. : '%s'", text, thisScript().version) ) + if ini.settings.auto_update then + addChatMessage( string.format(" . !") ) + script_update.command() + else + addChatMessage( string.format(" . : /%s", command) ) + end + end + end + end + inicfg.save(ini, script_update.address_ini) + script_update.menu.init() + end, + command = function() + lua_thread.create(function() + local fpath = os.tmpname() + local result, text = pcall(openURL, script_update.version_url, fpath) + if result then + if text ~= "" and text ~= thisScript().version then + addChatMessage( string.format(" '%s'. : '%s'", text, thisScript().version) ) + local fpath = os.tmpname() + local result, text = pcall(openURL, script_update.script_url, fpath) + if result and text ~= "" and text:find(thisScript().name:gsub("%-", "%%-")) then + local file, error = io.open(thisScript().path, "w") + if file ~= nil then + file:write(text) + file:flush() + io.close(file) + addChatMessage(" , !") + wait(500) + thisScript():reload() + end + end + else + addChatMessage(" !") + end + end + end) + end, + menu = { + dialog = {}, + ini = {}, + init = function() + if not sampIsChatCommandDefined("rubin-mods") then + sampAddChatMessage("{667dff}[RUBIN MODS]{FFFFFF} : /rubin-mods", 0xFFFFFFFF) + sampRegisterChatCommand("rubin-mods",script_update.menu.show) + while true do + wait(0) + local result, button, list, input = sampHasDialogRespond(2160) + if result and button == 1 then + if script_update.menu.ini[list+1] ~= nil and script_update.menu.dialog[list+1] ~= nil then + script_update.menu.dialog[list+1](script_update.menu.ini[list+1]) + end + end + local result, button, list, input = sampHasDialogRespond(2162) + if result then + if button == 1 then + if script_update.menu2.text[list+1] ~= nil and script_update.menu2.dialog[list+1] ~= nil then + script_update.menu2.dialog[list+1]() + end + else + script_update.menu.show() + end + end + local result, button, list, input = sampHasDialogRespond(2161) + if result then + script_update.menu2.show(script_update.menu2.data) + end + end + end + end, + show = function() + script_update.menu.dialog = {} + script_update.menu.ini = {} + local text = "" + if doesDirectoryExist("moonloader\\config\\rubin-mods-updates") then + local FileHandle, FileName = findFirstFile("moonloader\\config\\rubin-mods-updates\\*") + while FileName ~= nil do + if FileName ~= nil and FileName ~= ".." and FileName ~= "." and FileName:find("%.ini") then + local address = string.format("moonloader\\config\\rubin-mods-updates\\%s", FileName) + if doesFileExist(address) then + local ini = inicfg.load({}, address) + script_update.menu.ini[#script_update.menu.ini+1] = address + text = string.format("%s%s\n", text, string.format("%s\t%s%s", ini.settings.script_name, (ini.settings.version == ini.settings.server_version and "{59fc30}" or "{ff0000}"),ini.settings.version)) + script_update.menu.dialog[#script_update.menu.dialog+1] = function(data) + script_update.menu2.show(data) + end + end + end + FileName = findNextFile(FileHandle) + end + findClose(FileHandle) + else + text = " :\t\n moonloader\\config\\rubin-mods-updates\t" + end + sampShowDialog(2160," : Rubin Mods","\t\n"..text,"","",5) + end + }, + menu2 = { + data = {}, + text = {}, + dialog = {}, + show = function(data) + script_update.menu2.data = data + script_update.menu2.text = {} + script_update.menu2.dialog = {} + if doesFileExist(data) then + local ini = inicfg.load({}, data) + script_update.menu2.text[#script_update.menu2.text+1] = string.format(" %s", (ini.settings.auto_update and "{59fc30}ON" or "{ff0000}OFF")) + script_update.menu2.dialog[#script_update.menu2.dialog+1] = function() + ini.settings.auto_update = not ini.settings.auto_update + inicfg.save(ini, data) + script_update.menu2.show(data) + end + if not ini.settings.auto_update then + script_update.menu2.text[#script_update.menu2.text+1] = string.format(" %s", (ini.settings.check_update and "{59fc30}ON" or "{ff0000}OFF")) + script_update.menu2.dialog[#script_update.menu2.dialog+1] = function() + ini.settings.check_update = not ini.settings.check_update + inicfg.save(ini, data) + script_update.menu2.show(data) + end + end + script_update.menu2.text[#script_update.menu2.text+1] = string.format(" ") + script_update.menu2.dialog[#script_update.menu2.dialog+1] = function() + script_update.changelog(ini.settings.changelog_url, ini.settings.script_name) + end + script_update.menu2.text[#script_update.menu2.text+1] = string.format(" ") + script_update.menu2.dialog[#script_update.menu2.dialog+1] = function() + os.remove(data) + script_update.menu.show() + end + local text = "" + for i = 1, #script_update.menu2.text do + text = text..script_update.menu2.text[i].."\n" + end + sampShowDialog(2162," "..ini.settings.script_name,text,"","",2) + end + end + }, + changelog = function(url, name) + local fpath = os.tmpname() + local result, text = pcall(openURL, url, fpath) + if result then + sampShowDialog(2161,"Changelog - "..name,text,"","",4) + end + end +} +function addChatMessage(text) + local tag = string.format("{667dff}[%s]{FFFFFF} ", thisScript().name) + sampAddChatMessage(tag..text, 0xFFFFFFFF) +end \ No newline at end of file diff --git a/version b/version new file mode 100644 index 0000000..1831fc9 --- /dev/null +++ b/version @@ -0,0 +1 @@ +28.01.2024 \ No newline at end of file