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