109 lines
2.9 KiB
Lua
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 |