From 3a1bf9e2f9c6165a565e4db1df388a69c831cf20 Mon Sep 17 00:00:00 2001 From: Thekuca <63980591+Thekuca@users.noreply.github.com> Date: Wed, 31 Jan 2024 20:21:53 +0100 Subject: [PATCH 1/6] =?UTF-8?q?=E2=9B=94ditch=20spawnmanager?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- [core]/es_extended/client/main.lua | 1 - [core]/es_extended/fxmanifest.lua | 3 +- [core]/es_extended/server/main.lua | 1 + [core]/esx_multicharacter/client/main.lua | 48 +++++++---------------- server.cfg | 1 - 5 files changed, 16 insertions(+), 38 deletions(-) diff --git a/[core]/es_extended/client/main.lua b/[core]/es_extended/client/main.lua index f161f1f44..4f4edbd16 100644 --- a/[core]/es_extended/client/main.lua +++ b/[core]/es_extended/client/main.lua @@ -5,7 +5,6 @@ CreateThread(function() Wait(100) if NetworkIsPlayerActive(PlayerId()) then - exports.spawnmanager:setAutoSpawn(false) DoScreenFadeOut(0) Wait(500) TriggerServerEvent("esx:onPlayerJoined") diff --git a/[core]/es_extended/fxmanifest.lua b/[core]/es_extended/fxmanifest.lua index f251e2287..2b195a9d2 100644 --- a/[core]/es_extended/fxmanifest.lua +++ b/[core]/es_extended/fxmanifest.lua @@ -74,6 +74,5 @@ files { dependencies { '/native:0x6AE51D4B', '/native:0xA61C8FC6', - 'oxmysql', - 'spawnmanager', + 'oxmysql' } diff --git a/[core]/es_extended/server/main.lua b/[core]/es_extended/server/main.lua index e268ec803..343321ee2 100644 --- a/[core]/es_extended/server/main.lua +++ b/[core]/es_extended/server/main.lua @@ -674,6 +674,7 @@ local DoNotUse = { ["fivem-map-hipster"] = true, ["qb-core"] = true, ["default_spawnpoint"] = true, + ["spawnmanager"] = true } AddEventHandler("onResourceStart", function(key) diff --git a/[core]/esx_multicharacter/client/main.lua b/[core]/esx_multicharacter/client/main.lua index 556ccfe37..76bc6c7b1 100644 --- a/[core]/esx_multicharacter/client/main.lua +++ b/[core]/esx_multicharacter/client/main.lua @@ -9,7 +9,6 @@ if ESX.GetConfig().Multichar then Wait(100) if NetworkIsPlayerActive(PlayerId()) then - exports.spawnmanager:setAutoSpawn(false) DoScreenFadeOut(0) while GetResourceState("esx_context") ~= "started" do Wait(100) @@ -99,28 +98,17 @@ if ESX.GetConfig().Multichar then SetupCharacter = function(index) if not spawned then - exports.spawnmanager:spawnPlayer({ - x = SpawnCoords.x, - y = SpawnCoords.y, - z = SpawnCoords.z, - heading = SpawnCoords.w, - model = Characters[index].model or mp_m_freemode_01, - skipFade = true, - }, function() + local skin = Characters[index] and Characters[index].skin or Characters[index] and Config.Default + + if Characters[index] and not Characters[index].model then + skin.sex = Characters[index].sex == TranslateCap('female') and 1 or 0 + end + + ESX.SpawnPlayer(skin, {x = SpawnCoords.x, y = SpawnCoords.y, z = SpawnCoords.z}, function() canRelog = false - if Characters[index] then - local skin = Characters[index].skin or Config.Default - if not Characters[index].model then - if Characters[index].sex == TranslateCap("female") then - skin.sex = 1 - else - skin.sex = 0 - end - end - TriggerEvent("skinchanger:loadSkin", skin) - end DoScreenFadeIn(600) end) + repeat Wait(200) until not IsScreenFadedOut() @@ -255,28 +243,20 @@ if ESX.GetConfig().Multichar then Characters = data slots = slots local Character = next(Characters) - exports.spawnmanager:forceRespawn() if not Character then SendNUIMessage({ action = "closeui", }) - exports.spawnmanager:spawnPlayer({ - x = SpawnCoords.x, - y = SpawnCoords.y, - z = SpawnCoords.z, - heading = SpawnCoords.w, - model = mp_m_freemode_01, - skipFade = true, - }, function() + ESX.SpawnPlayer({model = mp_m_freemode_01}, {x = SpawnCoords.x, y = SpawnCoords.y, z = SpawnCoords.z}, function() canRelog = false DoScreenFadeIn(400) Wait(400) - local playerPed = PlayerPedId() - SetPedAoBlobRendering(playerPed, false) - SetEntityAlpha(playerPed, 0) - TriggerServerEvent("esx_multicharacter:CharacterChosen", 1, true) - TriggerEvent("esx_identity:showRegisterIdentity") + local ped = PlayerPedId() + SetPedAoBlobRendering(ped, false) + SetEntityAlpha(ped, 0) + TriggerServerEvent('esx_multicharacter:CharacterChosen', 1, true) + TriggerEvent('esx_identity:showRegisterIdentity') end) else SelectCharacterMenu(Characters, slots) diff --git a/server.cfg b/server.cfg index a4741dd0d..a6fafab6f 100644 --- a/server.cfg +++ b/server.cfg @@ -33,7 +33,6 @@ setr esx:locale "en" ## These resources will start by default. ensure chat -ensure spawnmanager ensure sessionmanager ensure hardcap From ec812ca2d415ab80ae587ffb8505ef899b2097b4 Mon Sep 17 00:00:00 2001 From: Thekuca <63980591+Thekuca@users.noreply.github.com> Date: Wed, 31 Jan 2024 21:11:36 +0100 Subject: [PATCH 2/6] =?UTF-8?q?=E2=99=BB=EF=B8=8Fspawnmanagere=20revert?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- [core]/es_extended/client/main.lua | 1 + [core]/es_extended/fxmanifest.lua | 3 ++- [core]/es_extended/server/main.lua | 3 +-- [core]/esx_multicharacter/client/main.lua | 1 + server.cfg | 1 + 5 files changed, 6 insertions(+), 3 deletions(-) diff --git a/[core]/es_extended/client/main.lua b/[core]/es_extended/client/main.lua index 4f4edbd16..f161f1f44 100644 --- a/[core]/es_extended/client/main.lua +++ b/[core]/es_extended/client/main.lua @@ -5,6 +5,7 @@ CreateThread(function() Wait(100) if NetworkIsPlayerActive(PlayerId()) then + exports.spawnmanager:setAutoSpawn(false) DoScreenFadeOut(0) Wait(500) TriggerServerEvent("esx:onPlayerJoined") diff --git a/[core]/es_extended/fxmanifest.lua b/[core]/es_extended/fxmanifest.lua index 2b195a9d2..eb8b289a1 100644 --- a/[core]/es_extended/fxmanifest.lua +++ b/[core]/es_extended/fxmanifest.lua @@ -74,5 +74,6 @@ files { dependencies { '/native:0x6AE51D4B', '/native:0xA61C8FC6', - 'oxmysql' + 'oxmysql', + 'spawnmanager' } diff --git a/[core]/es_extended/server/main.lua b/[core]/es_extended/server/main.lua index 343321ee2..b9e3a04c0 100644 --- a/[core]/es_extended/server/main.lua +++ b/[core]/es_extended/server/main.lua @@ -673,8 +673,7 @@ local DoNotUse = { ["fivem-map-skater"] = true, ["fivem-map-hipster"] = true, ["qb-core"] = true, - ["default_spawnpoint"] = true, - ["spawnmanager"] = true + ["default_spawnpoint"] = true } AddEventHandler("onResourceStart", function(key) diff --git a/[core]/esx_multicharacter/client/main.lua b/[core]/esx_multicharacter/client/main.lua index 76bc6c7b1..58581bd6f 100644 --- a/[core]/esx_multicharacter/client/main.lua +++ b/[core]/esx_multicharacter/client/main.lua @@ -9,6 +9,7 @@ if ESX.GetConfig().Multichar then Wait(100) if NetworkIsPlayerActive(PlayerId()) then + exports.spawnmanager:setAutoSpawn(false) DoScreenFadeOut(0) while GetResourceState("esx_context") ~= "started" do Wait(100) diff --git a/server.cfg b/server.cfg index a6fafab6f..a4741dd0d 100644 --- a/server.cfg +++ b/server.cfg @@ -33,6 +33,7 @@ setr esx:locale "en" ## These resources will start by default. ensure chat +ensure spawnmanager ensure sessionmanager ensure hardcap From b925a8ed958f16cab13846577ae9c23bcf93bdc0 Mon Sep 17 00:00:00 2001 From: Thekuca <63980591+Thekuca@users.noreply.github.com> Date: Thu, 1 Feb 2024 18:04:53 +0100 Subject: [PATCH 3/6] =?UTF-8?q?=E2=99=BB=EF=B8=8Frefactor(es=5Fextended/se?= =?UTF-8?q?rver/main)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- [core]/es_extended/server/main.lua | 169 ++++++++++++----------------- 1 file changed, 67 insertions(+), 102 deletions(-) diff --git a/[core]/es_extended/server/main.lua b/[core]/es_extended/server/main.lua index b9e3a04c0..4bc1a7418 100644 --- a/[core]/es_extended/server/main.lua +++ b/[core]/es_extended/server/main.lua @@ -26,17 +26,12 @@ if Config.Multichar then end if not ESX.Players[src] then - local identifier = char .. ":" .. ESX.GetIdentifier(src) - if data then - createESXPlayer(identifier, src, data) - else - loadESXPlayer(identifier, src, false) - end + local identifier = ('%s:%s'):format(char, ESX.GetIdentifier(src)) + return data and createESXPlayer(identifier, src, data) or loadESXPlayer(identifier, src, false) end end) else - RegisterNetEvent("esx:onPlayerJoined") - AddEventHandler("esx:onPlayerJoined", function() + RegisterNetEvent("esx:onPlayerJoined", function() local _source = source while not next(ESX.Jobs) do Wait(50) @@ -50,25 +45,17 @@ end function onPlayerJoined(playerId) local identifier = ESX.GetIdentifier(playerId) - if identifier then - if ESX.GetPlayerFromIdentifier(identifier) then - DropPlayer( - playerId, - ("there was an error loading your character!\nError code: identifier-active-ingame\n\nThis error is caused by a player on this server who has the same identifier as you have. Make sure you are not playing on the same Rockstar account.\n\nYour Rockstar identifier: %s"):format( - identifier - ) - ) - else - local result = MySQL.scalar.await("SELECT 1 FROM users WHERE identifier = ?", { identifier }) - if result then - loadESXPlayer(identifier, playerId, false) - else - createESXPlayer(identifier, playerId) - end - end - else - DropPlayer(playerId, "there was an error loading your character!\nError code: identifier-missing-ingame\n\nThe cause of this error is not known, your identifier could not be found. Please come back later or report this problem to the server administration team.") + + if not identifier then + return DropPlayer(playerId, "there was an error loading your character!\nError code: identifier-missing-ingame\n\nThe cause of this error is not known, your identifier could not be found. Please come back later or report this problem to the server administration team.") + end + + if ESX.GetPlayerFromIdentifier(identifier) then + return DropPlayer(playerId, ("there was an error loading your character!\nError code: identifier-active-ingame\n\nThis error is caused by a player on this server who has the same identifier as you have. Make sure you are not playing on the same Rockstar account.\n\nYour Rockstar identifier: %s"):format(identifier)) end + + local result = MySQL.scalar.await("SELECT 1 FROM users WHERE identifier = ?", { identifier }) + return result and loadESXPlayer(identifier, playerId, false) or createESXPlayer(identifier, playerId) end function createESXPlayer(identifier, playerId, data) @@ -110,13 +97,7 @@ if not Config.Multichar then end if identifier then - if ESX.GetPlayerFromIdentifier(identifier) then - return deferrals.done( - ("[ESX] There was an error loading your character!\nError code: identifier-active\n\nThis error is caused by a player on this server who has the same identifier as you have. Make sure you are not playing on the same account.\n\nYour identifier: %s"):format(identifier) - ) - else - return deferrals.done() - end + return ESX.GetPlayerFromIdentifier(identifier) and deferrals.done(("[ESX] There was an error loading your character!\nError code: identifier-active\n\nThis error is caused by a player on this server who has the same identifier as you have. Make sure you are not playing on the same account.\n\nYour identifier: %s"):format(identifier)) or deferrals.done() else return deferrals.done("[ESX] There was an error loading your character!\nError code: identifier-missing\n\nThe cause of this error is not known, your identifier could not be found. Please come back later or report this problem to the server administration team.") end @@ -140,8 +121,7 @@ function loadESXPlayer(identifier, playerId, isNew) local result = MySQL.prepare.await(loadPlayer, { identifier }) -- Accounts - local accounts = result.accounts - accounts = (accounts and accounts ~= "") and json.decode(accounts) or {} + local accounts = (result.accounts and result.accounts ~= "") and json.decode(result.accounts) or {} for account, data in pairs(Config.Accounts) do data.round = data.round or data.round == nil @@ -164,7 +144,7 @@ function loadESXPlayer(identifier, playerId, isNew) job, grade = "unemployed", "0" end - jobObject, gradeObject = ESX.Jobs[job], ESX.Jobs[job].grades[grade] + local jobObject, gradeObject = ESX.Jobs[job], ESX.Jobs[job].grades[grade] userData.job = { id = jobObject.id, @@ -296,6 +276,7 @@ function loadESXPlayer(identifier, playerId, isNew) end end end + xPlayer.triggerEvent("esx:registerSuggestions", Core.RegisteredCommands) print(('[^2INFO^0] Player ^5"%s"^0 has connected to the server. ID: ^5%s^7'):format(xPlayer.getName(), playerId)) end @@ -363,24 +344,20 @@ AddEventHandler("esx:playerLogout", function(playerId, cb) end) if not Config.OxInventory then - RegisterNetEvent("esx:updateWeaponAmmo") - AddEventHandler("esx:updateWeaponAmmo", function(weaponName, ammoCount) + RegisterNetEvent("esx:updateWeaponAmmo", function(weaponName, ammoCount) local xPlayer = ESX.GetPlayerFromId(source) - if xPlayer then - xPlayer.updateWeaponAmmo(weaponName, ammoCount) - end + return xPlayer and xPlayer.updateWeaponAmmo(weaponName, ammoCount) end) - RegisterNetEvent("esx:giveInventoryItem") - AddEventHandler("esx:giveInventoryItem", function(target, itemType, itemName, itemCount) + RegisterNetEvent("esx:giveInventoryItem", function(target, itemType, itemName, itemCount) local playerId = source local sourceXPlayer = ESX.GetPlayerFromId(playerId) local targetXPlayer = ESX.GetPlayerFromId(target) local distance = #(GetEntityCoords(GetPlayerPed(playerId)) - GetEntityCoords(GetPlayerPed(target))) + if not sourceXPlayer or not targetXPlayer or distance > Config.DistanceGive then - print(("[^3WARNING^7] Player Detected Cheating: ^5%s^7"):format(GetPlayerName(playerId))) - return + return print(("[^3WARNING^7] Player Detected Cheating: ^5%s^7"):format(GetPlayerName(playerId))) end if itemType == "item_standard" then @@ -526,58 +503,51 @@ if not Config.OxInventory then end end) - RegisterNetEvent("esx:useItem") - AddEventHandler("esx:useItem", function(itemName) + RegisterNetEvent("esx:useItem", function(itemName) local source = source local xPlayer = ESX.GetPlayerFromId(source) local count = xPlayer.getInventoryItem(itemName).count - if count > 0 then - ESX.UseItem(source, itemName) - else - xPlayer.showNotification(TranslateCap("act_imp")) - end + return count > 0 and ESX.UseItem(source, itemName) or xPlayer.showNotification(TranslateCap('act_imp')) end) - RegisterNetEvent("esx:onPickup") - AddEventHandler("esx:onPickup", function(pickupId) + RegisterNetEvent("esx:onPickup", function(pickupId) local pickup, xPlayer, success = Core.Pickups[pickupId], ESX.GetPlayerFromId(source) - if pickup then - local playerPickupDistance = #(pickup.coords - xPlayer.getCoords(true)) - if playerPickupDistance > 5.0 then - print(("[^3WARNING^7] Player Detected Cheating (Out of range pickup): ^5%s^7"):format(xPlayer.getIdentifier())) - return - end + if not pickup then return end - if pickup.type == "item_standard" then - if xPlayer.canCarryItem(pickup.name, pickup.count) then - xPlayer.addInventoryItem(pickup.name, pickup.count) - success = true - else - xPlayer.showNotification(TranslateCap("threw_cannot_pickup")) - end - elseif pickup.type == "item_account" then + local playerPickupDistance = #(pickup.coords - xPlayer.getCoords(true)) + if playerPickupDistance > 5.0 then + return print(("[^3WARNING^7] Player Detected Cheating (Out of range pickup): ^5%s^7"):format(xPlayer.getIdentifier())) + end + + if pickup.type == "item_standard" then + if xPlayer.canCarryItem(pickup.name, pickup.count) then + xPlayer.addInventoryItem(pickup.name, pickup.count) success = true - xPlayer.addAccountMoney(pickup.name, pickup.count, "Picked up") - elseif pickup.type == "item_weapon" then - if xPlayer.hasWeapon(pickup.name) then - xPlayer.showNotification(TranslateCap("threw_weapon_already")) - else - success = true - xPlayer.addWeapon(pickup.name, pickup.count) - xPlayer.setWeaponTint(pickup.name, pickup.tintIndex) + else + xPlayer.showNotification(TranslateCap("threw_cannot_pickup")) + end + elseif pickup.type == "item_account" then + success = true + xPlayer.addAccountMoney(pickup.name, pickup.count, "Picked up") + elseif pickup.type == "item_weapon" then + if xPlayer.hasWeapon(pickup.name) then + xPlayer.showNotification(TranslateCap("threw_weapon_already")) + else + success = true + xPlayer.addWeapon(pickup.name, pickup.count) + xPlayer.setWeaponTint(pickup.name, pickup.tintIndex) - for _, v in ipairs(pickup.components) do - xPlayer.addWeaponComponent(pickup.name, v) - end + for _, v in ipairs(pickup.components) do + xPlayer.addWeaponComponent(pickup.name, v) end end + end - if success then - Core.Pickups[pickupId] = nil - TriggerClientEvent("esx:removePickup", -1, pickupId) - end + if success then + Core.Pickups[pickupId] = nil + TriggerClientEvent("esx:removePickup", -1, pickupId) end end) end @@ -602,7 +572,7 @@ ESX.RegisterServerCallback("esx:isUserAdmin", function(source, cb) end) ESX.RegisterServerCallback("esx:getGameBuild", function(_, cb) - cb(tonumber(GetConvar("sv_enforceGameBuild", 1604))) + cb(tonumber(GetConvarInt("sv_enforceGameBuild", 1604))) end) ESX.RegisterServerCallback("esx:getOtherPlayerData", function(_, cb, target) @@ -626,11 +596,7 @@ ESX.RegisterServerCallback("esx:getPlayerNames", function(source, cb, players) for playerId, _ in pairs(players) do local xPlayer = ESX.GetPlayerFromId(playerId) - if xPlayer then - players[playerId] = xPlayer.getName() - else - players[playerId] = nil - end + players[playerId] = xPlayer and xPlayer.getName() or nil end cb(players) @@ -648,24 +614,23 @@ ESX.RegisterServerCallback("esx:spawnVehicle", function(source, cb, vehData) timeout += 1 end end + cb(id) end) end) AddEventHandler("txAdmin:events:scheduledRestart", function(eventData) - if eventData.secondsRemaining == 60 then - CreateThread(function() - Wait(50000) - Core.SavePlayers() - end) - end -end) + if eventData.secondsRemaining ~= 60 then return end -AddEventHandler("txAdmin:events:serverShuttingDown", function() - Core.SavePlayers() + CreateThread(function() + Wait(50000) + Core.SavePlayers() + end) end) -local DoNotUse = { +AddEventHandler("txAdmin:events:serverShuttingDown", Core.SavePlayers) + +local doNotUse = { ["essentialmode"] = true, ["es_admin2"] = true, ["basic-gamemode"] = true, @@ -673,11 +638,11 @@ local DoNotUse = { ["fivem-map-skater"] = true, ["fivem-map-hipster"] = true, ["qb-core"] = true, - ["default_spawnpoint"] = true + ["default_spawnpoint"] = true, } AddEventHandler("onResourceStart", function(key) - if DoNotUse[string.lower(key)] then + if doNotUse[string.lower(key)] then while GetResourceState(key) ~= "started" do Wait(0) end @@ -687,7 +652,7 @@ AddEventHandler("onResourceStart", function(key) end end) -for key in pairs(DoNotUse) do +for key in pairs(doNotUse) do if GetResourceState(key) == "started" or GetResourceState(key) == "starting" then StopResource(key) print(("[^1ERROR^7] WE STOPPED A RESOURCE THAT WILL BREAK ^1ESX^7, PLEASE REMOVE ^5%s^7"):format(key)) From 2fd609a8893c294bbc3eb21616b791902dc49ce9 Mon Sep 17 00:00:00 2001 From: Thekuca <63980591+Thekuca@users.noreply.github.com> Date: Thu, 1 Feb 2024 22:43:14 +0100 Subject: [PATCH 4/6] =?UTF-8?q?=F0=9F=86=95csoki=20callbacks?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../es_extended/client/modules/callback.lua | 22 ++++++++++++++----- 1 file changed, 17 insertions(+), 5 deletions(-) diff --git a/[core]/es_extended/client/modules/callback.lua b/[core]/es_extended/client/modules/callback.lua index cf58c391c..63ae2c1a3 100644 --- a/[core]/es_extended/client/modules/callback.lua +++ b/[core]/es_extended/client/modules/callback.lua @@ -6,13 +6,25 @@ local clientCallbacks = {} ---@param eventName string ---@param callback function ---@param ... any -ESX.TriggerServerCallback = function(eventName, callback, ...) - serverRequests[RequestId] = callback +ESX.TriggerServerCallback = setmetatable({ + Await = function(eventName, ...) + local p = promise.new() - TriggerServerEvent("esx:triggerServerCallback", eventName, RequestId, GetInvokingResource() or "unknown", ...) + ESX.TriggerServerCallback(eventName, function(...) + p:resolve(...) + end, ...) - RequestId = RequestId + 1 -end + return Citizen.Await(p) + end +}, { + __call = function(eventName, callback, ...) + serverRequests[RequestId] = callback + + TriggerServerEvent('esx:triggerServerCallback', eventName, RequestId, GetInvokingResource() or 'unknown', ...) + + RequestId = RequestId + 1 + end +}) RegisterNetEvent("esx:serverCallback", function(requestId, invoker, ...) if not serverRequests[requestId] then From 2e5d1111c87e86ae71e9d922ffb5875247742cdf Mon Sep 17 00:00:00 2001 From: Thekuca Date: Thu, 1 Feb 2024 23:15:48 +0100 Subject: [PATCH 5/6] =?UTF-8?q?=E2=99=BB=EF=B8=8Frefactor(es=5Fextended/cl?= =?UTF-8?q?ient/main)=20general=20code=20refactor=20and=20await=20callback?= =?UTF-8?q?s?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- [core]/es_extended/client/main.lua | 252 ++++++++++++----------------- 1 file changed, 105 insertions(+), 147 deletions(-) diff --git a/[core]/es_extended/client/main.lua b/[core]/es_extended/client/main.lua index f161f1f44..4df316dda 100644 --- a/[core]/es_extended/client/main.lua +++ b/[core]/es_extended/client/main.lua @@ -14,9 +14,7 @@ CreateThread(function() end end) -RegisterNetEvent("esx:requestModel", function(model) - ESX.Streaming.RequestModel(model) -end) +RegisterNetEvent("esx:requestModel", ESX.Streaming.RequestModel) function ESX.SpawnPlayer(skin, coords, cb) local p = promise.new() @@ -71,7 +69,7 @@ AddEventHandler("esx:playerLoaded", function(xPlayer, _, skin) local timer = GetGameTimer() while not HaveAllStreamingRequestsCompleted(ESX.PlayerData.ped) and (GetGameTimer() - timer) < 2000 do Wait(0) - end + end if Config.EnablePVP then SetCanAttackFriendly(ESX.PlayerData.ped, true, false) @@ -211,8 +209,7 @@ AddEventHandler("esx:playerLoaded", function(xPlayer, _, skin) end) -RegisterNetEvent("esx:onPlayerLogout") -AddEventHandler("esx:onPlayerLogout", function() +RegisterNetEvent("esx:onPlayerLogout", function() ESX.PlayerLoaded = false end) @@ -277,9 +274,9 @@ AddStateBagChangeHandler("VehicleProperties", nil, function(bagName, _, value) local netId = bagName:gsub("entity:", "") local vehicle = NetToVeh(tonumber(netId)) - + ESX.Game.SetVehicleProperties(vehicle, value) -end) +end) RegisterNetEvent("esx:setAccountMoney") AddEventHandler("esx:setAccountMoney", function(account) @@ -294,8 +291,7 @@ AddEventHandler("esx:setAccountMoney", function(account) end) if not Config.OxInventory then - RegisterNetEvent("esx:addInventoryItem") - AddEventHandler("esx:addInventoryItem", function(item, count, showNotification) + RegisterNetEvent("esx:addInventoryItem", function(item, count, showNotification) for k, v in ipairs(ESX.PlayerData.inventory) do if v.name == item then ESX.UI.ShowInventoryItemNotification(true, v.label, count - v.count) @@ -309,8 +305,7 @@ if not Config.OxInventory then end end) - RegisterNetEvent("esx:removeInventoryItem") - AddEventHandler("esx:removeInventoryItem", function(item, count, showNotification) + RegisterNetEvent("esx:removeInventoryItem", function(item, count, showNotification) for i = 1, #ESX.PlayerData.inventory do if ESX.PlayerData.inventory[i].name == item then ESX.UI.ShowInventoryItemNotification(false, ESX.PlayerData.inventory[i].label, ESX.PlayerData.inventory[i].count - count) @@ -324,46 +319,38 @@ if not Config.OxInventory then end end) - RegisterNetEvent("esx:addWeapon") - AddEventHandler("esx:addWeapon", function() + RegisterNetEvent("esx:addWeapon", function() print("[^1ERROR^7] event ^5'esx:addWeapon'^7 Has Been Removed. Please use ^5xPlayer.addWeapon^7 Instead!") end) - RegisterNetEvent("esx:addWeaponComponent") - AddEventHandler("esx:addWeaponComponent", function() + RegisterNetEvent("esx:addWeaponComponent", function() print("[^1ERROR^7] event ^5'esx:addWeaponComponent'^7 Has Been Removed. Please use ^5xPlayer.addWeaponComponent^7 Instead!") end) - RegisterNetEvent("esx:setWeaponAmmo") - AddEventHandler("esx:setWeaponAmmo", function() + RegisterNetEvent("esx:setWeaponAmmo", function() print("[^1ERROR^7] event ^5'esx:setWeaponAmmo'^7 Has Been Removed. Please use ^5xPlayer.addWeaponAmmo^7 Instead!") end) - RegisterNetEvent("esx:setWeaponTint") - AddEventHandler("esx:setWeaponTint", function(weapon, weaponTintIndex) + RegisterNetEvent("esx:setWeaponTint", function(weapon, weaponTintIndex) SetPedWeaponTintIndex(ESX.PlayerData.ped, joaat(weapon), weaponTintIndex) end) - RegisterNetEvent("esx:removeWeapon") - AddEventHandler("esx:removeWeapon", function() + RegisterNetEvent("esx:removeWeapon", function() print("[^1ERROR^7] event ^5'esx:removeWeapon'^7 Has Been Removed. Please use ^5xPlayer.removeWeapon^7 Instead!") end) - RegisterNetEvent("esx:removeWeaponComponent") - AddEventHandler("esx:removeWeaponComponent", function(weapon, weaponComponent) + RegisterNetEvent("esx:removeWeaponComponent", function(weapon, weaponComponent) local componentHash = ESX.GetWeaponComponent(weapon, weaponComponent).hash RemoveWeaponComponentFromPed(ESX.PlayerData.ped, joaat(weapon), componentHash) end) end -RegisterNetEvent("esx:setJob") -AddEventHandler("esx:setJob", function(Job) +RegisterNetEvent("esx:setJob", function(Job) ESX.SetPlayerData("job", Job) end) if not Config.OxInventory then - RegisterNetEvent("esx:createPickup") - AddEventHandler("esx:createPickup", function(pickupId, label, coords, itemType, name, components, tintIndex) + RegisterNetEvent("esx:createPickup", function(pickupId, label, coords, itemType, name, components, tintIndex) local function setObjectProperties(object) SetEntityAsMissionEntity(object, true, false) PlaceObjectOnGroundProperly(object) @@ -378,33 +365,31 @@ if not Config.OxInventory then } end - if itemType == "item_weapon" then - local weaponHash = joaat(name) - ESX.Streaming.RequestWeaponAsset(weaponHash) - local pickupObject = CreateWeaponObject(weaponHash, 50, coords.x, coords.y, coords.z, true, 1.0, 0) - SetWeaponObjectTintIndex(pickupObject, tintIndex) + if itemType ~= 'item_weapon' then + return ESX.Game.SpawnLocalObject('prop_money_bag_01', coords, setObjectProperties) + end - for _, v in ipairs(components) do - local component = ESX.GetWeaponComponent(name, v) - GiveWeaponComponentToWeaponObject(pickupObject, component.hash) - end + local weaponHash = joaat(name) + ESX.Streaming.RequestWeaponAsset(weaponHash) + local pickupObject = CreateWeaponObject(weaponHash, 50, coords.x, coords.y, coords.z, true, 1.0, 0) + SetWeaponObjectTintIndex(pickupObject, tintIndex) - setObjectProperties(pickupObject) - else - ESX.Game.SpawnLocalObject("prop_money_bag_01", coords, setObjectProperties) + for _, v in ipairs(components) do + local component = ESX.GetWeaponComponent(name, v) + GiveWeaponComponentToWeaponObject(pickupObject, component.hash) end + + setObjectProperties(pickupObject) end) - RegisterNetEvent("esx:createMissingPickups") - AddEventHandler("esx:createMissingPickups", function(missingPickups) + RegisterNetEvent("esx:createMissingPickups", function(missingPickups) for pickupId, pickup in pairs(missingPickups) do TriggerEvent("esx:createPickup", pickupId, pickup.label, vector3(pickup.coords.x, pickup.coords.y, pickup.coords.z - 1.0), pickup.type, pickup.name, pickup.components, pickup.tintIndex) end end) end -RegisterNetEvent("esx:registerSuggestions") -AddEventHandler("esx:registerSuggestions", function(registeredCommands) +RegisterNetEvent("esx:registerSuggestions", function(registeredCommands) for name, command in pairs(registeredCommands) do if command.suggestion then TriggerEvent("chat:addSuggestion", ("/%s"):format(name), command.suggestion.help, command.suggestion.arguments) @@ -413,12 +398,11 @@ AddEventHandler("esx:registerSuggestions", function(registeredCommands) end) if not Config.OxInventory then - RegisterNetEvent("esx:removePickup") - AddEventHandler("esx:removePickup", function(pickupId) - if pickups[pickupId] and pickups[pickupId].obj then - ESX.Game.DeleteObject(pickups[pickupId].obj) - pickups[pickupId] = nil - end + RegisterNetEvent("esx:removePickup", function(pickupId) + if not pickups[pickupId] and not pickups[pickupId].obj then return end + + ESX.Game.DeleteObject(pickups[pickupId].obj) + pickups[pickupId] = nil end) end @@ -455,9 +439,8 @@ end if not Config.OxInventory and Config.EnableDefaultInventory then ESX.RegisterInput("showinv", TranslateCap("keymap_showinventory"), "keyboard", "F2", function() - if not ESX.PlayerData.dead then - ESX.ShowInventory() - end + if ESX.PlayerData.dead then return end + ESX.ShowInventory() end) end @@ -516,8 +499,7 @@ end ----- Admin commands from esx_adminplus -RegisterNetEvent("esx:tpm") -AddEventHandler("esx:tpm", function() +RegisterNetEvent("esx:tpm", function() local GetEntityCoords = GetEntityCoords local GetGroundZFor_3dCoord = GetGroundZFor_3dCoord local GetFirstBlipInfoId = GetFirstBlipInfoId @@ -526,82 +508,71 @@ AddEventHandler("esx:tpm", function() local GetBlipInfoIdCoord = GetBlipInfoIdCoord local GetVehiclePedIsIn = GetVehiclePedIsIn - ESX.TriggerServerCallback("esx:isUserAdmin", function(admin) - if not admin then - return - end - local blipMarker = GetFirstBlipInfoId(8) - if not DoesBlipExist(blipMarker) then - ESX.ShowNotification(TranslateCap("tpm_nowaypoint"), true, false, 140) - return "marker" - end + if not ESX.TriggerServerCallback.Await('esx:isUserAdmin') then return end - -- Fade screen to hide how clients get teleported. - DoScreenFadeOut(650) - while not IsScreenFadedOut() do - Wait(0) - end + local blipMarker = GetFirstBlipInfoId(8) + if not DoesBlipExist(blipMarker) then + ESX.ShowNotification(TranslateCap("tpm_nowaypoint"), true, false, 140) + return "marker" + end - local ped, coords = ESX.PlayerData.ped, GetBlipInfoIdCoord(blipMarker) - local vehicle = GetVehiclePedIsIn(ped, false) - local oldCoords = GetEntityCoords(ped) + DoScreenFadeOut(650) + while not IsScreenFadedOut() do + Wait(0) + end - -- Unpack coords instead of having to unpack them while iterating. - -- 825.0 seems to be the max a player can reach while 0.0 being the lowest. - local x, y, groundZ, Z_START = coords["x"], coords["y"], 850.0, 950.0 - local found = false - FreezeEntityPosition(vehicle > 0 and vehicle or ped, true) + local ped, coords = ESX.PlayerData.ped, GetBlipInfoIdCoord(blipMarker) + local vehicle = GetVehiclePedIsIn(ped, false) + local oldCoords = GetEntityCoords(ped) - for i = Z_START, 0, -25.0 do - local z = i - if (i % 2) ~= 0 then - z = Z_START - i - end + local x, y, groundZ, Z_START = coords["x"], coords["y"], 850.0, 950.0 + local found = false + FreezeEntityPosition(vehicle > 0 and vehicle or ped, true) - NewLoadSceneStart(x, y, z, x, y, z, 50.0, 0) - local curTime = GetGameTimer() - while IsNetworkLoadingScene() do - if GetGameTimer() - curTime > 1000 then - break - end - Wait(0) - end - NewLoadSceneStop() - SetPedCoordsKeepVehicle(ped, x, y, z) + for i = Z_START, 0, -25.0 do + local z = i + if (i % 2) ~= 0 then + z = Z_START - i + end - while not HasCollisionLoadedAroundEntity(ped) do - RequestCollisionAtCoord(x, y, z) - if GetGameTimer() - curTime > 1000 then - break - end - Wait(0) + NewLoadSceneStart(x, y, z, x, y, z, 50.0, 0) + local curTime = GetGameTimer() + while IsNetworkLoadingScene() do + if GetGameTimer() - curTime > 1000 then + break end + Wait(0) + end + NewLoadSceneStop() + SetPedCoordsKeepVehicle(ped, x, y, z) - -- Get ground coord. As mentioned in the natives, this only works if the client is in render distance. - found, groundZ = GetGroundZFor_3dCoord(x, y, z, false) - if found then - Wait(0) - SetPedCoordsKeepVehicle(ped, x, y, groundZ) + while not HasCollisionLoadedAroundEntity(ped) do + RequestCollisionAtCoord(x, y, z) + if GetGameTimer() - curTime > 1000 then break end Wait(0) end - -- Remove black screen once the loop has ended. - DoScreenFadeIn(650) - FreezeEntityPosition(vehicle > 0 and vehicle or ped, false) - - if not found then - -- If we can't find the coords, set the coords to the old ones. - -- We don't unpack them before since they aren't in a loop and only called once. - SetPedCoordsKeepVehicle(ped, oldCoords["x"], oldCoords["y"], oldCoords["z"] - 1.0) - ESX.ShowNotification(TranslateCap("tpm_success"), true, false, 140) + found, groundZ = GetGroundZFor_3dCoord(x, y, z, false) + if found then + Wait(0) + SetPedCoordsKeepVehicle(ped, x, y, groundZ) + break end + Wait(0) + end + + DoScreenFadeIn(650) + FreezeEntityPosition(vehicle > 0 and vehicle or ped, false) - -- If Z coord was found, set coords in found coords. - SetPedCoordsKeepVehicle(ped, x, y, groundZ) + if not found then + SetPedCoordsKeepVehicle(ped, oldCoords["x"], oldCoords["y"], oldCoords["z"] - 1.0) ESX.ShowNotification(TranslateCap("tpm_success"), true, false, 140) - end) + end + + SetPedCoordsKeepVehicle(ped, x, y, groundZ) + ESX.ShowNotification(TranslateCap("tpm_success"), true, false, 140) end) local noclip = false @@ -649,34 +620,27 @@ local function noclipThread() end end -RegisterNetEvent("esx:noclip") -AddEventHandler("esx:noclip", function() - ESX.TriggerServerCallback("esx:isUserAdmin", function(admin) - if not admin then - return - end +RegisterNetEvent("esx:noclip", function() + if not ESX.TriggerServerCallback.Await('esx:isUserAdmin') then return end - if not noclip then - noclip_pos = GetEntityCoords(ESX.PlayerData.ped, false) - heading = GetEntityHeading(ESX.PlayerData.ped) - end + if not noclip then + noclip_pos = GetEntityCoords(ESX.PlayerData.ped, false) + heading = GetEntityHeading(ESX.PlayerData.ped) + end - noclip = not noclip - if noclip then - CreateThread(noclipThread) - end + noclip = not noclip + if noclip then + CreateThread(noclipThread) + end - ESX.ShowNotification(TranslateCap("noclip_message", noclip and Translate("enabled") or Translate("disabled")), true, false, 140) - end) + ESX.ShowNotification(TranslateCap("noclip_message", noclip and Translate("enabled") or Translate("disabled")), true, false, 140) end) -RegisterNetEvent("esx:killPlayer") -AddEventHandler("esx:killPlayer", function() +RegisterNetEvent("esx:killPlayer", function() SetEntityHealth(ESX.PlayerData.ped, 0) end) -RegisterNetEvent("esx:repairPedVehicle") -AddEventHandler("esx:repairPedVehicle", function() +RegisterNetEvent("esx:repairPedVehicle", function() local ped = ESX.PlayerData.ped local vehicle = GetVehiclePedIsIn(ped, false) SetVehicleEngineHealth(vehicle, 1000) @@ -685,18 +649,12 @@ AddEventHandler("esx:repairPedVehicle", function() SetVehicleDirtLevel(vehicle, 0) end) -RegisterNetEvent("esx:freezePlayer") -AddEventHandler("esx:freezePlayer", function(input) - local player = PlayerId() - if input == "freeze" then - SetEntityCollision(ESX.PlayerData.ped, false) - FreezeEntityPosition(ESX.PlayerData.ped, true) - SetPlayerInvincible(player, true) - elseif input == "unfreeze" then - SetEntityCollision(ESX.PlayerData.ped, true) - FreezeEntityPosition(ESX.PlayerData.ped, false) - SetPlayerInvincible(player, false) - end +RegisterNetEvent("esx:freezePlayer", function(input) + local state = input == 'freeze' + + SetEntityCollision(ESX.PlayerData.ped, not state) + FreezeEntityPosition(ESX.PlayerData.ped, state) + SetPlayerInvincible(PlayerId(), state) end) ESX.RegisterClientCallback("esx:GetVehicleType", function(cb, model) From c46aa105f9566707bf7bb443b46e910b69c670dc Mon Sep 17 00:00:00 2001 From: Thekuca Date: Fri, 2 Feb 2024 14:08:03 +0100 Subject: [PATCH 6/6] revert await callbacks --- [core]/es_extended/client/main.lua | 122 +++++++++--------- .../es_extended/client/modules/callback.lua | 22 +--- 2 files changed, 68 insertions(+), 76 deletions(-) diff --git a/[core]/es_extended/client/main.lua b/[core]/es_extended/client/main.lua index 4df316dda..f95c2c3ac 100644 --- a/[core]/es_extended/client/main.lua +++ b/[core]/es_extended/client/main.lua @@ -508,71 +508,73 @@ RegisterNetEvent("esx:tpm", function() local GetBlipInfoIdCoord = GetBlipInfoIdCoord local GetVehiclePedIsIn = GetVehiclePedIsIn - if not ESX.TriggerServerCallback.Await('esx:isUserAdmin') then return end + ESX.TriggerServerCallback('esx:isUserAdmin', function(isAdmin) + if not isAdmin then return end - local blipMarker = GetFirstBlipInfoId(8) - if not DoesBlipExist(blipMarker) then - ESX.ShowNotification(TranslateCap("tpm_nowaypoint"), true, false, 140) - return "marker" - end + local blipMarker = GetFirstBlipInfoId(8) + if not DoesBlipExist(blipMarker) then + ESX.ShowNotification(TranslateCap("tpm_nowaypoint"), true, false, 140) + return "marker" + end - DoScreenFadeOut(650) - while not IsScreenFadedOut() do - Wait(0) - end + DoScreenFadeOut(650) + while not IsScreenFadedOut() do + Wait(0) + end - local ped, coords = ESX.PlayerData.ped, GetBlipInfoIdCoord(blipMarker) - local vehicle = GetVehiclePedIsIn(ped, false) - local oldCoords = GetEntityCoords(ped) + local ped, coords = ESX.PlayerData.ped, GetBlipInfoIdCoord(blipMarker) + local vehicle = GetVehiclePedIsIn(ped, false) + local oldCoords = GetEntityCoords(ped) - local x, y, groundZ, Z_START = coords["x"], coords["y"], 850.0, 950.0 - local found = false - FreezeEntityPosition(vehicle > 0 and vehicle or ped, true) + local x, y, groundZ, Z_START = coords["x"], coords["y"], 850.0, 950.0 + local found = false + FreezeEntityPosition(vehicle > 0 and vehicle or ped, true) - for i = Z_START, 0, -25.0 do - local z = i - if (i % 2) ~= 0 then - z = Z_START - i - end + for i = Z_START, 0, -25.0 do + local z = i + if (i % 2) ~= 0 then + z = Z_START - i + end - NewLoadSceneStart(x, y, z, x, y, z, 50.0, 0) - local curTime = GetGameTimer() - while IsNetworkLoadingScene() do - if GetGameTimer() - curTime > 1000 then - break + NewLoadSceneStart(x, y, z, x, y, z, 50.0, 0) + local curTime = GetGameTimer() + while IsNetworkLoadingScene() do + if GetGameTimer() - curTime > 1000 then + break + end + Wait(0) end - Wait(0) - end - NewLoadSceneStop() - SetPedCoordsKeepVehicle(ped, x, y, z) + NewLoadSceneStop() + SetPedCoordsKeepVehicle(ped, x, y, z) - while not HasCollisionLoadedAroundEntity(ped) do - RequestCollisionAtCoord(x, y, z) - if GetGameTimer() - curTime > 1000 then + while not HasCollisionLoadedAroundEntity(ped) do + RequestCollisionAtCoord(x, y, z) + if GetGameTimer() - curTime > 1000 then + break + end + Wait(0) + end + + found, groundZ = GetGroundZFor_3dCoord(x, y, z, false) + if found then + Wait(0) + SetPedCoordsKeepVehicle(ped, x, y, groundZ) break end Wait(0) end - found, groundZ = GetGroundZFor_3dCoord(x, y, z, false) - if found then - Wait(0) - SetPedCoordsKeepVehicle(ped, x, y, groundZ) - break - end - Wait(0) - end + DoScreenFadeIn(650) + FreezeEntityPosition(vehicle > 0 and vehicle or ped, false) - DoScreenFadeIn(650) - FreezeEntityPosition(vehicle > 0 and vehicle or ped, false) + if not found then + SetPedCoordsKeepVehicle(ped, oldCoords["x"], oldCoords["y"], oldCoords["z"] - 1.0) + ESX.ShowNotification(TranslateCap("tpm_success"), true, false, 140) + end - if not found then - SetPedCoordsKeepVehicle(ped, oldCoords["x"], oldCoords["y"], oldCoords["z"] - 1.0) + SetPedCoordsKeepVehicle(ped, x, y, groundZ) ESX.ShowNotification(TranslateCap("tpm_success"), true, false, 140) - end - - SetPedCoordsKeepVehicle(ped, x, y, groundZ) - ESX.ShowNotification(TranslateCap("tpm_success"), true, false, 140) + end) end) local noclip = false @@ -621,19 +623,21 @@ local function noclipThread() end RegisterNetEvent("esx:noclip", function() - if not ESX.TriggerServerCallback.Await('esx:isUserAdmin') then return end + ESX.TriggerServerCallback('esx:isUserAdmin', function(isAdmin) + if not isAdmin then return end - if not noclip then - noclip_pos = GetEntityCoords(ESX.PlayerData.ped, false) - heading = GetEntityHeading(ESX.PlayerData.ped) - end + if not noclip then + noclip_pos = GetEntityCoords(ESX.PlayerData.ped, false) + heading = GetEntityHeading(ESX.PlayerData.ped) + end - noclip = not noclip - if noclip then - CreateThread(noclipThread) - end + noclip = not noclip + if noclip then + CreateThread(noclipThread) + end - ESX.ShowNotification(TranslateCap("noclip_message", noclip and Translate("enabled") or Translate("disabled")), true, false, 140) + ESX.ShowNotification(TranslateCap("noclip_message", noclip and Translate("enabled") or Translate("disabled")), true, false, 140) + end) end) RegisterNetEvent("esx:killPlayer", function() diff --git a/[core]/es_extended/client/modules/callback.lua b/[core]/es_extended/client/modules/callback.lua index 63ae2c1a3..0c3dbdd6e 100644 --- a/[core]/es_extended/client/modules/callback.lua +++ b/[core]/es_extended/client/modules/callback.lua @@ -6,25 +6,13 @@ local clientCallbacks = {} ---@param eventName string ---@param callback function ---@param ... any -ESX.TriggerServerCallback = setmetatable({ - Await = function(eventName, ...) - local p = promise.new() +ESX.TriggerServerCallback = function(eventName, callback, ...) + serverRequests[RequestId] = callback - ESX.TriggerServerCallback(eventName, function(...) - p:resolve(...) - end, ...) + TriggerServerEvent('esx:triggerServerCallback', eventName, RequestId, GetInvokingResource() or 'unknown', ...) - return Citizen.Await(p) - end -}, { - __call = function(eventName, callback, ...) - serverRequests[RequestId] = callback - - TriggerServerEvent('esx:triggerServerCallback', eventName, RequestId, GetInvokingResource() or 'unknown', ...) - - RequestId = RequestId + 1 - end -}) + RequestId = RequestId + 1 +end RegisterNetEvent("esx:serverCallback", function(requestId, invoker, ...) if not serverRequests[requestId] then