Server Exports
Misc
GetConfig
local config = exports["lb-phone"]:GetConfig()
FormatNumber
-- phoneNumber: string
local formattedNumber = exports["lb-phone"]:FormatNumber(phoneNumber)
AirShare
-- sender: number - The source of the player sending the share
-- target: number - The source of the player receiving the share
-- shareType: "image" | "contact" | "location" | "note" | "voicememo"
-- shareData: table
exports["lb-phone"]:AirShare(sender, target, shareType, shareData)
The shareData should be:
image
{
isVideo: boolean;
src: string; // link to the image/video
timestamp?: number; // timestamp in ms, defaults to current time
}
contact
{
number: string;
firstname: string;
lastname?: string;
email?: string;
address?: string;
avatar?: string;
}
location
{
name: string;
location: [number, number]; // [y, x]
}
note
{
title: string;
content: string;
}
voicememo
{
title: string;
src: string; // link to the audio file
duration: string; // audio file duration in seconds
}
ContainsBlacklistedWord
Checks if a string contains a blacklisted word defined in the config.
-- source: number
-- text: string
-- return: boolean
local containsBlacklistedWord = exports["lb-phone"]:ContainsBlacklistedWord(source, text)
Social media
ToggleVerified
-- app: "birdy" | "instapic" | "trendy"
-- username: string
-- verified: boolean
exports["lb-phone"]:ToggleVerified(app, username, verified)
IsVerified
-- app: "birdy" | "instapic" | "trendy"
-- username: string
-- return: boolean
exports["lb-phone"]:IsVerified(app, username)
ChangePassword
-- app: "birdy" | "instapic" | "trendy" | "mail" | "darkchat"
-- username: string
-- password: string
-- return: boolean
local success = exports["lb-phone"]:ChangePassword(app, username, password)
PostBirdy
-- username: string
-- content?: string
-- attachments?: string[]
-- replyTo?: string -- the id of the post to reply to
-- hashtags?: string[]
-- return: success boolean
-- return?: id string
local success, id = exports["lb-phone"]:PostBirdy(username, content, attachments, replyTo, hashtags)
GetBirdyPost
Used to get a post on birdy
-- id: string
-- return: table
local post = exports["lb-phone"]:GetBirdyPost(id)
Handle phone & user
FactoryReset
-- phoneNumber: string
exports["lb-phone"]:FactoryReset(phoneNumber)
GetEquippedPhoneNumber
-- source: number | string - the player source or identifier
-- return: string?
local phoneNumber = exports["lb-phone"]:GetEquippedPhoneNumber(source)
GetSourceFromNumber
-- phoneNumber: string
-- return: number?
local source = exports["lb-phone"]:GetSourceFromNumber(phoneNumber)
SendNotification
-- sourceOrNumber: string | number - The player source or phone number
-- data: { app?: string, title: string, content?: string, thumbnail?: string, avatar?: string, showAvatar?: boolean }
-- app: string - Identifier of the app that sent the notification, optional
-- title: string - Title of the notification
-- content: string - Content of the notification, optional
-- thumbnail: string - Thumbnail URL, optional
-- avatar: string - Avatar URL, optional
-- showAvatar: boolean - Whether to show an avatar placeholder if no avatar was sent, optional
exports["lb-phone"]:SendNotification(sourceOrNumber, {
app = "Settings",
title = "Test",
content = "This is a test notification",
})
NotifyEveryone
-- notify: "all" | "online" -- all = everyone (saved to db), online = only online players (not saved to db)
-- data: { app: string, title: string, content?: string, thumbnail?: string, avatar?: string, showAvatar?: boolean }
-- app: string - Identifier of the app that sent the notification
-- title: string - Title of the notification
-- content: string - Content of the notification, optional
-- thumbnail: string - Thumbnail URL, optional
-- avatar: string - Avatar URL, optional
-- showAvatar: boolean - Whether to show an avatar placeholder if no avatar was sent, optional
exports["lb-phone"]:NotifyEveryone("online", {
app = "Settings",
title = "Test",
content = "This is a test notification",
})
EmergencyNotification
-- sourceOrNumber: number - The player source
-- data: table, the notification data
exports["lb-phone"]:EmergencyNotification(source, {
title = "Emergency Alert",
content = "This is a test emergency alert",
icon = "warning", -- the icon of the notification (optional), "warning" or "danger"
})
AddContact
-- phoneNumber: string - the phone number to add the contact to
-- data: { number: string, firstname: string, lastname?: string, avatar?: string, email?: string, address?: string }
exports["lb-phone"]:AddContact(phoneNumber, {
number = "01234567890",
firstname = "John",
lastname = "Doe", -- optional
avatar = "https://example.com/avatar", -- optional
email = "[email protected]", -- optional
address = "Eclipse Towers, Penthouse Suite 1", -- optional
})
Wallet app
AddTransaction
-- phoneNumber: string - the phone number to add the transaction to
-- amount: number - the amount of the transaction
-- title: string - the title of the transaction
-- image: string? - the image URL of the transaction
exports["lb-phone"]:AddTransaction(phoneNumber, amount, title, image)
Security
GetPin
-- phoneNumber: string
-- return: string
local pin = exports["lb-phone"]:GetPin(phoneNumber)
ResetSecurity
-- phoneNumber: string
exports["lb-phone"]:ResetSecurity(phoneNumber)
CreateMailAccount
-- address: string
-- password: string
-- cb?: function
-- return: { success: boolean, error?: string }
local result = exports["lb-phone"]:CreateMailAccount(address, password)
if not result.success then
return print("Failed to create mail account:", result.error)
end
GetEmailAddress
-- phoneNumber: string
-- return?: string
exports["lb-phone"]:GetEmailAddress(phoneNumber)
SendMail
-- data: { to: string, sender?: string, subject: string, message: string, attachments?: string[], actions?: { label: string, data: { event: string, isServer: boolean, data: any } }[] }
-- to: string - The email address to send the mail to
-- sender: string - The sender of the email, optional
-- subject: string - The subject of the email
-- message: string - The message of the email
-- attachments: string[] - URLs of the attachments, optional
-- actions: { label: string, data: { event: string, isServer: boolean, data: any } }[] - Actions (buttons) that the user can interact with, optional
-- return: success: boolean, id?: string
local success, id = exports["lb-phone"]:SendMail(data)
DeleteMail
-- id: string
-- return: boolean
exports["lb-phone"]:DeleteMail(id)
Messages/SMS
SendMessage
-- from: string - The sender's phone number
-- to: string - The recipient's phone number
-- message: string - The message content
-- attachments?: string[] - URLs of the attachments, optional
-- cb?: function - The callback function
-- channelId?: number - The channel ID to send the message to, optional
-- return?: { channelId: number, messageId: number }
local result = exports["lb-phone"]:SendMessage(from, to, message, attachments, cb, channelId)
SentMoney
Used to send a message to a player indicating that they have received money
-- from: string - The sender's phone number
-- to: string - The recipient's phone number
-- amount: number - The amount of money sent
exports["lb-phone"]:SentMoney(from, to, amount)
SendCoords
-- from: string - The sender's phone number
-- to: string - The recipient's phone number
-- coords: vector2
exports["lb-phone"]:SendCoords(from, to, coords)
DarkChat
SendDarkChatMessage
-- username: string
-- channel: string
-- message: string
-- cb?: function(success: boolean)
-- return: boolean
local success = exports["lb-phone"]:SendDarkChatMessage(username, channel, message, cb?)
SendDarkChatLocation
-- username: string
-- channel: string
-- coords: vector2
-- cb?: function(success: boolean)
local success = exports["lb-phone"]:SendDarkChatLocation(username, channel, coords, cb?)
Battery
SaveBattery
-- phoneNumber: string
exports["lb-phone"]:SaveBattery(phoneNumber)
SaveAllBatteries
exports["lb-phone"]:SaveAllBatteries()
IsPhoneDead
-- phoneNumber: string
-- return: boolean
local dead = exports["lb-phone"]:IsPhoneDead(phoneNumber)
Calls
CreateCall
Creates a call that is not shown on the phone UI, e.g. for payphones
-- caller: { source: number, phoneNumber: string }
-- callee?: string - The phone number of the person being called
-- options?: { requirePhone?: boolean, hideNumber?: boolean, company?: string }
-- return: number
local callId = exports["lb-phone"]:CreateCall({
phoneNumber = "Abc 123",
source = src
}, number, {
requirePhone = false,
hideNumber = true
})
GetCall
-- callId: number
-- return: table
local call = exports["lb-phone"]:GetCall(callId)
if call then
print(json.encode(call, { indent = true }))
end
EndCall
-- source: number
exports["lb-phone"]:EndCall(source)
IsInCall
-- source: number
-- return: boolean
local inCall = exports["lb-phone"]:IsInCall(source)
Crypto
AddCrypto
-- source: number
-- coin: string
-- amount: number
-- return boolean
local success = exports["lb-phone"]:AddCrypto(source, coin, amount)
RemoveCrypto
-- source: number
-- coin: string
-- amount: number
-- return boolean
local success = exports["lb-phone"]:RemoveCrypto(source, coin, amount)
AddCustomCoin
-- id: string
-- name: string
-- symbol: string
-- image: string
-- currentPrice: number
-- prices: number[]
-- change24h: number
exports["lb-phone"]:AddCustomCoin(id, name, symbol, image, currentPrice, prices, change24h)
GetCoin
-- id: string
-- return: { id: string, name: string, symbol: string, image: string, current_price: number, prices: number[], change_24h: number }
local value = exports["lb-phone"]:GetCoinValue(id)