⚠️Common Errors
In this section, you will find answers to commonly encountered issues. Remember that most errors stem from incorrect configuration, lack of required resources, or insufficient modification.
Bear in mind that troubleshooting requires patience and precision. Try to carefully analyze the errors and systematically review possible solutions.
If the issue persists after verifying the configuration and available resources, please contact the support on the VMS Discord.
Chameleon color not working
Make sure you have updated your GTA 5 launcher
Make sure you are using the new game build on your server - recommended to use 2802
Add a line like this to your startup file (server.cfg):
sv_enforceGameBuild 2802
Selected options in tuning are not saved in the garage
Replace the functions responsible for saving and loading vehicle properties, you will find the prepared options in the section Installation
I'm getting the "vms_tuning:verifyPlateNotExist" error on ESX
It looks like you have an older ESX or a modified ESX and do not have the ESX.RegisterCommand function in your es_extended
Open the config.lua vms_tuning
Find
Config.AdminDiscountCodesCommand
Change in command generate and remove from
oldESX =
false
tooldESX =
true
[WARNING] Selected language "__" not found, changed to "EN", configure your language in translation.json
You have selected a language that does not exist for the translation.json file, create your language in this file.
My progress-bar takes 2x longer
In that case, add your export progressbar to the thread
CL.ProgressBar = function(label, time)
Citizen.CreateThread(function() -- Added
exports['progressbar']:Progress({
name = 'installation',
label = label,
duration = time,
canCancel = false,
controlDisables = {
disableMouse = false,
disableMovement = true,
disableCarMovement = true,
disableCombat = true,
}
})
end) -- Added
end
I don't see tuning points
If you do not see a tuning point, it means that you have misconfigured the job or grade_access, do it correctly.
If you are using QB-Core, go to the file qb-core/shared/jobs.lua
I don't see all options in management menu
A process similar to that of I don't see tuning points, but you have to configure manager_grades
and boss_grades
When trying to open the management menu, I get a ban from qb-management
Go to your qb-management/server/sv_boss.lua
Find these marked lines
if not Player.PlayerData.job.isboss then
ExploitBan(src, 'GetEmployees Exploiting')
return
end
Remove them.
I cannot open management menu on qbx-core
This is normal, because qbx_management does not have a callback by default to get a list of employees with the exact parameters we use from qb-management on qb-core.
To do this, you must register the prepared callback in your qbx_management.
Go to qbx_management/server/main.lua
Add this code in the file:
local QBCore = exports['qb-core']:GetCoreObject()
QBCore.Functions.CreateCallback('qbx_management:server:GetEmployeesForVMS', function(source, cb, jobname)
local employees = {}
local players = MySQL.query.await("SELECT * FROM `players` WHERE `job` LIKE '%" .. jobname .. "%'", {})
if players[1] ~= nil then
for _, value in pairs(players) do
local isOnline = QBCore.Functions.GetPlayerByCitizenId(value.citizenid)
if isOnline and isOnline.PlayerData.job.name == jobname then
employees[#employees + 1] = {
empSource = isOnline.PlayerData.citizenid,
grade = isOnline.PlayerData.job.grade,
isboss = isOnline.PlayerData.job.isboss,
name = '🟢 ' .. isOnline.PlayerData.charinfo.firstname .. ' ' .. isOnline.PlayerData.charinfo.lastname
}
elseif value.job.name == jobname then
employees[#employees + 1] = {
empSource = value.citizenid,
grade = value.job.grade,
isboss = value.job.isboss,
name = '🔴 ' .. value.charinfo.firstname .. ' ' .. value.charinfo.lastname
}
end
end
table.sort(employees, function(a, b)
return a.grade.level > b.grade.level
end)
end
cb(employees)
end)
Save the file as well as close it
Go to vms_tuning/config/config.client.lua
Find
CL.GetEmployees
functionReplace it with the one below:
CL.GetEmployees = function(cb, jobName)
QBCore.Functions.TriggerCallback('qbx_management:server:GetEmployeesForVMS', function(employees)
cb(employees)
end, jobName)
end
Save the file as well as close it
Restart server
Problem with Wheel Size/Wheel Width/Suspension Height/Wheel Stance/Engine Swap
In GTA, custom options such as Wheel Size, Wheel Width, Custom Suspension Height, Wheel Stance, and Engine Swap — which Rockstar Games has not normally allowed players to install in Online sessions via the mechanic's workshop — are not synchronized in the same way as other options, such as vehicle color, etc.
This means that we had to create our own synchronization for these parts, which results in higher resmon usage. However, this has been limited to the smallest possible consumption by using the best optimization methods. For example, this resmon will only be active when the vehicle is visible on your screen. If there are no vehicles visible on your screen, the synchronization module will not be active.
For the options Wheel Size, Wheel Width, and Custom Suspension Height to load with the optimized method, they must be created on the server side and must be assigned StateBag's with vehicle properties. By default, in ESX, there is a server-side function ESX.OneSync.SpawnVehicle
, which fulfills all the requirements - spawn on the server side and automatic setting of vehicle properties, but in the case of QB-Core, such a statebag is not assigned, so you need to enter it yourself in your garage system when the vehicle is created, example below
---@param veh number: Enitty ID
---@param vehProps table: Table with all vehicle props
Entity(veh).state:set("VehicleProperties", vehProps, true)
-- Example code for QB-Garages
QBCore.Functions.CreateCallback('qb-garages:server:spawnvehicle', function(source, cb, plate, vehicle, coords)
local vehType = QBCore.Shared.Vehicles[vehicle] and QBCore.Shared.Vehicles[vehicle].type or GetVehicleTypeByModel(vehicle)
local veh = CreateVehicleServerSetter(GetHashKey(vehicle), vehType, coords.x, coords.y, coords.z, coords.w)
local netId = NetworkGetNetworkIdFromEntity(veh)
SetVehicleNumberPlateText(veh, plate)
local vehProps = {}
local result = MySQL.rawExecute.await('SELECT mods FROM player_vehicles WHERE plate = ?', { plate })
if result and result[1] then
vehProps = json.decode(result[1].mods)
Entity(veh).state:set("VehicleProperties", vehProps, true) -- ADDED
end
OutsideVehicles[plate] = { netID = netId, entity = veh }
cb(netId, vehProps, plate)
end)
As for Wheel Stance and Engine Swap, this is managed by vms_tuning, and it is responsible for assigning special StateBag's for the vehicle, which we can synchronize and set. However, this also requires the vehicle to be spawned on the server side.
Without meeting the above guidelines, the options will not work correctly or synchronize.
Last updated