description |
---|
Learn about and how to use common core server functions! |
- Get the coords of a passed entity
function QBCore.Functions.GetCoords(entity)
local coords = GetEntityCoords(entity, false)
local heading = GetEntityHeading(entity)
return vector4(coords.x, coords.y, coords.z, heading)
end
-- Example
local ped = GetPlayerPed(source)
local coords = QBCore.Functions.GetCoords(ped)
print(coords)
- Get a specific identifier of a player
function QBCore.Functions.GetIdentifier(source, idtype)
local idtype = idtype or QBConfig.IdentifierType
for key, value in pairs(GetPlayerIdentifiers(source)) do
if string.find(value, idtype) then
return identifier
end
end
return nil
end
-- Example
local identifier = QBCore.Functions.GetIdentifier(source, 'license')
print(identifier)
OR -- defaults to the identifier in the config of qb-core
local identifier = QBCore.Functions.GetIdentifier(source)
print(identifier)
- Get a players source by identifer
function QBCore.Functions.GetSource(identifier)
for key, value in pairs(QBCore.Players) do
local identifiers = GetPlayerIdentifiers(key)
for _, id in pairs(identifiers) do
if identifier == id then
return key
end
end
end
return 0
end
-- Example
local identifier = QBCore.Functions.GetIdentifier(source, 'license')
local playerSource = QBCore.Functions.GetSource(identifier)
print(playerSource)
- Get a player by their source and access their data
function QBCore.Functions.GetPlayer(source)
local src = source
if type(src) == 'number' then
return QBCore.Players[src]
else
return QBCore.Players[QBCore.Functions.GetSource(src)]
end
end
-- Example
local Player = QBCore.Functions.GetPlayer(source)
print(QBCore.Debug(Player))
OR -- access some player data
local Player = QBCore.Functions.GetPlayer(source)
print(Player.PlayerData.citizenid)
- Get a player by their citizen id and access their data (must be online)
function QBCore.Functions.GetPlayerByCitizenId(citizenid)
for key, value in pairs(QBCore.Players) do
if QBCore.Players[key].PlayerData.citizenid == citizenid then
return QBCore.Players[key]
end
end
return nil
end
-- Example
local Player = QBCore.Functions.GetPlayerByCitizenId('ONZ55343')
print(QBCore.Debug(Player))
OR -- access some player data
local Player = QBCore.Functions.GetPlayerByCitizenId('ONZ55343')
print(Player.PlayerData.license)
- Get a player by their phone number (must be online)
function QBCore.Functions.GetPlayerByPhone(number)
for key, value in pairs(QBCore.Players) do
if QBCore.Players[key].PlayerData.charinfo.phone == number then
return QBCore.Players[key]
end
end
return nil
end
-- Example
local Player = QBCore.Functions.GetPlayerByPhone('1264756087')
print(QBCore.Debug(Player))
OR -- access some player data
local Player = QBCore.Functions.GetPlayerByPhone('1264756087')
print(Player.PlayerData.license)
- Get all player IDs in the server (deprecated method)
function QBCore.Functions.GetPlayers()
local sources = {}
for key, value in pairs(QBCore.Players) do
sources[#sources + 1] = key
end
return sources
end
-- Example
local Players = QBCore.Functions.GetPlayers()
print(QBCore.Debug(Players))
- Access the table of all active players on the server (preferred to above)
function QBCore.Functions.GetQBPlayers()
return QBCore.Players
end
-- Example
local Players = QBCore.Functions.GetQBPlayers()
print(QBCore.Debug(Players))
- Creates a callback which is used on the client-side code with QBCore.Functions.TriggerCallback
function QBCore.Functions.CreateCallback(name, cb)
QBCore.ServerCallbacks[name] = cb
end
-- Example
QBCore.Functions.CreateCallback('callbackName', function(source, cb)
cb('Ok')
end)
- Register an item as usable in the core
function QBCore.Functions.CreateUseableItem(item, cb)
QBCore.UseableItems[item] = cb
end
-- Example
QBCore.Functions.CreateUseableItem('my_cool_item', function(source, item)
local Player = QBCore.Functions.GetPlayer(source)
if not Player.Functions.GetItemByName(item.name) then return end
-- Trigger code here for what item should do
end)
- Check if an item is registered as usable before attempting use
function QBCore.Functions.CanUseItem(item)
return QBCore.UseableItems[item]
end
-- Example
local canUse = QBCore.Functions.CanUseItem('my_cool_item')
print(canUse)
OR
local canUse = QBCore.Functions.CanUseItem('my_cool_item')
if not canUse then return end
-- Trigger code here
- Trigger an item to be used on the player
function QBCore.Functions.UseItem(source, item)
QBCore.UseableItems[item.name](source, item)
end
-- Example
local Player = QBCore.Functions.GetPlayer(source)
if not Player.Functions.GetItemByName('my_cool_item') then return end
QBCore.Functions.UseItem(source, 'my_cool_item')
- Kick a player from the server
function QBCore.Functions.Kick(source, reason, setKickReason, deferrals)
local src = source
reason = '\n'..reason..'\n🔸 Check our Discord for further information: '..QBCore.Config.Server.discord
if setKickReason then
setKickReason(reason)
end
CreateThread(function()
if deferrals then
deferrals.update(reason)
Wait(2500)
end
if src then
DropPlayer(src, reason)
end
local i = 0
while (i <= 4) do
i = i + 1
while true do
if src then
if(GetPlayerPing(src) >= 0) then
break
end
Wait(100)
CreateThread(function()
DropPlayer(src, reason)
end)
end
end
Wait(5000)
end
end)
end
-- Example
QBCore.Functions.Kick(playerId, 'You messed up', true, true)
- Give a player a specific permission level (per session only)
function QBCore.Functions.AddPermission(source, permission)
local license = QBCore.Functions.GetIdentifier(source, 'license')
ExecuteCommand(('add_principal identifier.%s qbcore.%s'):format(license, permission))
QBCore.Commands.Refresh(source)
end
-- Example
local Player = QBCore.Functions.GetPlayer(playerId)
local permission = 'admin'
QBCore.Functions.AddPermission(Player.PlayerData.source, permission)
- Remove all of the players permissions on the server (per session only)
function QBCore.Functions.RemovePermission(source, permission)
local src = source
local license = QBCore.Functions.GetIdentifier(src, 'license')
if permission then
if IsPlayerAceAllowed(src, permission) then
ExecuteCommand(('remove_principal identifier.%s qbcore.%s'):format(license, permission))
QBCore.Commands.Refresh(src)
end
else
for k,v in pairs(QBCore.Config.Server.Permissions) do
if IsPlayerAceAllowed(src, v) then
ExecuteCommand(('remove_principal identifier.%s qbcore.%s'):format(license, v))
QBCore.Commands.Refresh(src)
end
end
end
end
-- Example
local Player = QBCore.Functions.GetPlayer(playerId)
local permission = 'admin'
QBCore.Functions.RemovePermission(Player.PlayerData.source, permission)
- Check if a player has the permission level needed
function QBCore.Functions.HasPermission(source, permission)
if IsPlayerAceAllowed(source, permission) then return true end
return false
end
-- Example
local hasPerms = QBCore.Functions.HasPermission(source, 'admin')
print(hasPerms)
OR -- using as a condition
local hasPerms = QBCore.Functions.HasPermission(source, 'admin')
if not hasPerms then return end
-- Trigger code here
- Get a player's permission level
function QBCore.Functions.GetPermission(source)
local src = source
local perms = {}
for key, value in pairs (QBCore.Config.Server.Permissions) do
if IsPlayerAceAllowed(src, value) then
perms[value] = true
end
end
return perms
end
-- Example
local permissions = QBCore.Functions.GetPermission(source)
print(QBCore.Debug(permissions))
OR -- using as a condition
local permissions = QBCore.Functions.GetPermission(source)
for key, value in pairs(permissions) do
if value == true then
print(key)
end
end
- Check if a player is banned (used for connection)
function QBCore.Functions.IsPlayerBanned(source)
local plicense = QBCore.Functions.GetIdentifier(source, 'license')
local result = MySQL.Sync.fetchSingle('SELECT * FROM bans WHERE license = ?', { plicense })
if not result then return false end
if os.time() < result.expire then
local timeTable = os.date('*t', tonumber(result.expire))
return true, 'You have been banned from the server:\n' .. result.reason .. '\nYour ban expires ' .. timeTable.day .. '/' .. timeTable.month .. '/' .. timeTable.year .. ' ' .. timeTable.hour .. ':' .. timeTable.min .. '\n'
else
MySQL.Async.execute('DELETE FROM bans WHERE id = ?', { result.id })
end
return false
end
-- Example
local isBanned = QBCore.Functions.IsPlayerBanned(source)
print(isBanned)
- Prevent duplicate licenses on the server (used for connection)
function QBCore.Functions.IsLicenseInUse(license)
local players = GetPlayers()
for key, value in pairs(players) do
local identifiers = GetPlayerIdentifiers(value)
for _, id in pairs(identifiers) do
if string.find(id, 'license') then
if id == license then
return true
end
end
end
end
return false
end
-- Example
local license = QBCore.Functions.GetIdentifier(source, 'license')
local isUsed = QBCore.Functions.IsLicenseInUse(license)
print(isUsed)