2026-04-14 17:41:39 +02:00

109 lines
2.9 KiB
Lua

function ParkBoats()
MySQL.update('UPDATE owned_vehicles SET `stored` = true WHERE `stored` = false AND type = @type', {
['@type'] = 'boat'
}, function (rowsChanged)
if rowsChanged > 0 then
print(('[^2INFO^7] Stored ^5%s^7 %s !'):format(rowsChanged, rowsChanged > 1 and 'boats' or 'boat'))
end
end)
end
MySQL.ready(function()
ParkBoats()
end)
ESX.RegisterServerCallback('esx_boat:buyBoat', function(source, cb, vehicleProps)
local xPlayer = ESX.Player(source)
local price = getPriceFromModel(vehicleProps.model)
-- vehicle model not found
if price == 0 then
print(('[^2INFO^7] Player ^5%s^7 Attempted To Exploit Shop'):format(xPlayer.src))
cb(false)
else
if xPlayer.getMoney() >= price then
xPlayer.removeMoney(price, "Boat Purchase")
MySQL.update('INSERT INTO owned_vehicles (owner, plate, vehicle, type, `stored`) VALUES (@owner, @plate, @vehicle, @type, @stored)', {
['@owner'] = xPlayer.getIdentifier(),
['@plate'] = vehicleProps.plate,
['@vehicle'] = json.encode(vehicleProps),
['@type'] = 'boat',
['@stored'] = true
}, function(rowsChanged)
cb(true)
end)
else
cb(false)
end
end
end)
RegisterServerEvent('esx_boat:takeOutVehicle')
AddEventHandler('esx_boat:takeOutVehicle', function(plate)
local xPlayer = ESX.Player(source)
MySQL.update('UPDATE owned_vehicles SET `stored` = @stored WHERE owner = @owner AND plate = @plate', {
['@stored'] = false,
['@owner'] = xPlayer.getIdentifier(),
['@plate'] = plate
}, function(rowsChanged)
if rowsChanged == 0 then
print(('[^2INFO^7] Player ^5%s^7 Attempted To Exploit Garage'):format(xPlayer.src))
end
end)
end)
ESX.RegisterServerCallback('esx_boat:storeVehicle', function (source, cb, plate)
local xPlayer = ESX.Player(source)
MySQL.update('UPDATE owned_vehicles SET `stored` = @stored WHERE owner = @owner AND plate = @plate', {
['@stored'] = true,
['@owner'] = xPlayer.getIdentifier(),
['@plate'] = plate
}, function(rowsChanged)
cb(rowsChanged)
end)
end)
ESX.RegisterServerCallback('esx_boat:getGarage', function(source, cb)
local xPlayer = ESX.Player(source)
MySQL.query('SELECT vehicle FROM owned_vehicles WHERE owner = @owner AND type = @type AND `stored` = @stored', {
['@owner'] = xPlayer.getIdentifier(),
['@type'] = 'boat',
['@stored'] = true
}, function(result)
local vehicles = {}
for i=1, #result, 1 do
table.insert(vehicles, result[i].vehicle)
end
cb(vehicles)
end)
end)
ESX.RegisterServerCallback('esx_boat:buyBoatLicense', function(source, cb)
local xPlayer = ESX.Player(source)
if xPlayer.getMoney() >= Config.LicensePrice then
xPlayer.removeMoney(Config.LicensePrice, "Boat License Purchase")
TriggerEvent('esx_license:addLicense', source, 'boat', function()
cb(true)
end)
else
cb(false)
end
end)
function getPriceFromModel(model)
for k,v in ipairs(Config.Vehicles) do
if joaat(v.model) == model then
return v.price
end
end
return 0
end