ed
This commit is contained in:
parent
1ed76cfb9b
commit
6c91401253
15 changed files with 1112 additions and 0 deletions
23
resources/[carscripts]/qb-vehicle-tracker/server/db.lua
Normal file
23
resources/[carscripts]/qb-vehicle-tracker/server/db.lua
Normal file
|
@ -0,0 +1,23 @@
|
|||
local db = {}
|
||||
|
||||
function db.deleteOldTrackers()
|
||||
return MySQL.query.await('DELETE FROM `vehicle_trackers` WHERE startedAt < (NOW() - INTERVAL 7 DAY)')
|
||||
end
|
||||
|
||||
function db.addTracker(serialNumber, vehiclePlate)
|
||||
return MySQL.prepare.await('INSERT INTO `vehicle_trackers` (`serialNumber`, `vehiclePlate`) VALUES (?, ?)', { serialNumber, vehiclePlate })
|
||||
end
|
||||
|
||||
function db.deleteTracker(vehiclePlate)
|
||||
return MySQL.prepare.await('DELETE FROM `vehicle_trackers` WHERE `vehiclePlate` = ?', { vehiclePlate })
|
||||
end
|
||||
|
||||
function db.getTracker(serialNumber)
|
||||
return MySQL.single.await('SELECT `serialNumber`, `vehiclePlate` FROM `vehicle_trackers` WHERE `serialNumber` = ? LIMIT 1', { serialNumber })
|
||||
end
|
||||
|
||||
function db.isTracked(vehiclePlate)
|
||||
return MySQL.scalar.await('SELECT `serialNumber` FROM `vehicle_trackers` WHERE `vehiclePlate` = ? LIMIT 1', { vehiclePlate })
|
||||
end
|
||||
|
||||
return db
|
80
resources/[carscripts]/qb-vehicle-tracker/server/server.lua
Normal file
80
resources/[carscripts]/qb-vehicle-tracker/server/server.lua
Normal file
|
@ -0,0 +1,80 @@
|
|||
local QBCore = exports['qb-core']:GetCoreObject()
|
||||
local config = require 'config'
|
||||
local utils = require 'server.utils'
|
||||
local db = require 'server.db'
|
||||
|
||||
-- QB Usable Items
|
||||
QBCore.Functions.CreateUseableItem(config.trackerItem, function(source, item)
|
||||
TriggerClientEvent('qb_vehicle_tracker:client:placeTracker', source, item.slot, utils.getRandomSerialNumber())
|
||||
end)
|
||||
|
||||
QBCore.Functions.CreateUseableItem(config.trackerTabletItem, function(source, item)
|
||||
local serialNumber = item.info and item.info.serialNumber or item.metadata.serialNumber
|
||||
TriggerClientEvent('qb_vehicle_tracker:client:manageTracker', source, serialNumber)
|
||||
end)
|
||||
|
||||
QBCore.Functions.CreateUseableItem(config.trackerScannerItem, function(source, item)
|
||||
TriggerClientEvent('qb_vehicle_tracker:client:scanTracker', source, item.slot)
|
||||
end)
|
||||
|
||||
-- Event Handler
|
||||
AddEventHandler('onResourceStart', function(resourceName)
|
||||
if cache.resource == resourceName then
|
||||
db.deleteOldTrackers()
|
||||
end
|
||||
end)
|
||||
|
||||
-- Callbacks
|
||||
lib.callback.register('qb_vehicle_tracker:getTrackedVehicleBySerial', function(_, serialNumber)
|
||||
if type(serialNumber) ~= "string" or string.len(serialNumber) < 11 then return end
|
||||
|
||||
local tracker = db.getTracker(serialNumber)
|
||||
if not tracker then return end
|
||||
|
||||
local vehicleNetworkID = utils.getVehicleNetworkIdByPlate(tracker.vehiclePlate)
|
||||
if not vehicleNetworkID then return end
|
||||
|
||||
local vehicleEntity = NetworkGetEntityFromNetworkId(vehicleNetworkID)
|
||||
if not DoesEntityExist(vehicleEntity) then return end
|
||||
|
||||
local vehCoords = GetEntityCoords(vehicleEntity)
|
||||
|
||||
return tracker.vehiclePlate, vector2(vehCoords.x, vehCoords.y)
|
||||
end)
|
||||
|
||||
lib.callback.register('qb_vehicle_tracker:isVehicleTracked', function(source, vehiclePlate)
|
||||
if type(vehiclePlate) ~= "string" or not utils.isPlayerNearVehicle(GetEntityCoords(GetPlayerPed(source)), vehiclePlate) then
|
||||
return false
|
||||
end
|
||||
|
||||
return db.isTracked(utils.trim(vehiclePlate))
|
||||
end)
|
||||
|
||||
lib.callback.register('qb_vehicle_tracker:placeTracker', function(source, vehiclePlate, slot, serialNumber)
|
||||
if type(vehiclePlate) ~= "string" or type(serialNumber) ~= "string" or string.len(serialNumber) < 11 then return false end
|
||||
if not utils.isPlayerNearVehicle(GetEntityCoords(GetPlayerPed(source)), vehiclePlate) then return false end
|
||||
if not db.addTracker(serialNumber, utils.trim(vehiclePlate)) then return false end
|
||||
|
||||
local Player = QBCore.Functions.GetPlayer(source)
|
||||
if Player.Functions.AddItem(config.trackerTabletItem, 1, false, { plate = utils.trim(vehiclePlate), serialNumber = serialNumber }) then
|
||||
Player.Functions.RemoveItem(config.trackerItem, 1, slot)
|
||||
TriggerClientEvent('inventory:client:ItemBox', source, QBCore.Shared.Items[config.trackerTabletItem], 'add')
|
||||
end
|
||||
|
||||
return true
|
||||
end)
|
||||
|
||||
lib.callback.register('qb_vehicle_tracker:removeTracker', function(source, vehiclePlate, slot)
|
||||
if type(vehiclePlate) ~= "string" or not utils.isPlayerNearVehicle(GetEntityCoords(GetPlayerPed(source)), vehiclePlate) then
|
||||
return false
|
||||
end
|
||||
|
||||
if not db.deleteTracker(utils.trim(vehiclePlate)) then return false end
|
||||
|
||||
local Player = QBCore.Functions.GetPlayer(source)
|
||||
if Player.Functions.RemoveItem(config.trackerScannerItem, 1, slot) then
|
||||
TriggerClientEvent('inventory:client:ItemBox', source, QBCore.Shared.Items[config.trackerScannerItem], 'remove')
|
||||
end
|
||||
|
||||
return true
|
||||
end)
|
41
resources/[carscripts]/qb-vehicle-tracker/server/utils.lua
Normal file
41
resources/[carscripts]/qb-vehicle-tracker/server/utils.lua
Normal file
|
@ -0,0 +1,41 @@
|
|||
local utils = {}
|
||||
|
||||
---@return string
|
||||
function utils.getRandomSerialNumber()
|
||||
return lib.string.random('...........')
|
||||
end
|
||||
|
||||
---@param plate string
|
||||
---@return string
|
||||
function utils.trim(plate)
|
||||
return (plate:gsub("^%s*(.-)%s*$", "%1"))
|
||||
end
|
||||
|
||||
---@param vehiclePlate string
|
||||
---@return number?
|
||||
function utils.getVehicleNetworkIdByPlate(vehiclePlate)
|
||||
local vehicles = GetAllVehicles()
|
||||
|
||||
for _, vehicle in ipairs(vehicles) do
|
||||
if utils.trim(GetVehicleNumberPlateText(vehicle)) == utils.trim(vehiclePlate) then
|
||||
return NetworkGetNetworkIdFromEntity(vehicle)
|
||||
end
|
||||
end
|
||||
|
||||
return nil
|
||||
end
|
||||
|
||||
---@param playerCoords vector3
|
||||
---@param vehiclePlate string
|
||||
---@return boolean
|
||||
function utils.isPlayerNearVehicle(playerCoords, vehiclePlate)
|
||||
local vehicle = lib.getClosestVehicle(playerCoords, 3.0, true)
|
||||
|
||||
if not vehicle or not DoesEntityExist(vehicle) or GetVehicleNumberPlateText(vehicle) ~= vehiclePlate then
|
||||
return false
|
||||
end
|
||||
|
||||
return true
|
||||
end
|
||||
|
||||
return utils
|
Loading…
Add table
Add a link
Reference in a new issue