lia.command

Registration, parsing, and handling of commands.

Commands can be ran through the chat with slash commands or they can be executed through the console. Commands can be manually restricted to certain usergroups using a CAMI-compliant admin mod.

If you are looking for the command structure, you can find it here.

Functions

extractArgs(text)

Returns a table of arguments from a given string. Words separated by spaces will be considered one argument. To have an argument containing multiple words, they must be contained within quotation marks.

Parameters

  • text String

    String to extract arguments from

Returns

  • table

    Arguments extracted from string

Example Usage

PrintTable(lia.command.extractArgs("these are \"some arguments\""))
> 1 = these
> 2 = are
> 3 = some arguments

findFaction(client, name)

Attempts to find a faction by an identifier.

Parameters

  • client Player

    to give a notification to if the faction could not be found

  • name String

    Search query

Returns

  • table

    Faction that matches the given search query

  • OR
  • nil

    If a faction could not be found

findPlayer(client, name)

Attempts to find a player by an identifier. If unsuccessful, a notice will be displayed to the specified player. The search criteria is derived from lia.command.findPlayer.

Parameters

  • client Player

    Player The client to give a notification to if the player could not be found.

  • name String

    Search query

Returns

  • player or nil

    Player that matches the given search query, or nil if a player could not be found

See Also

findPlayerSilent(client, name)

Attempts to find a player by an identifier silently.

Parameters

  • client Player

    to give a notification to if the player could not be found

  • name String

    Search query

Returns

  • player or nil

    Player that matches the given search query, or nil if not found

hasAccess(client, command, data)

Internal

This is an internal function! You are able to use it, but you risk unintended side effects if used incorrectly.

Checks if a player has access to execute a specific command. This function determines whether a player is authorized to run a given command based on privileges, admin-only or superadmin-only restrictions, and any custom hooks.

Parameters

  • client Player

    The player to check access for.

  • command String

    The name of the command to check access for.

  • data Table optional

    The command data. If not provided, the function retrieves the data from lia.command.list.

Returns

  • bool

    Whether or not the player has access to the command.

  • string

    The privilege associated with the command.

Example Usage

local canUse, privilege = lia.command.hasAccess(player, "ban")
if canUse then
    print("Player can run the command:", privilege)
else
    print("Player does not have access to the command:", privilege)
end

parse(client, text, realCommand, arguments)

Internal

This is an internal function! You are able to use it, but you risk unintended side effects if used incorrectly.

Parses a command from an input string and executes it.

Parameters

  • client Player

    The player who is executing the command

  • text String

    Input string to search for the command format

  • realCommand String optional

    Specific command to check for. If specified, it will only try to run this command

  • arguments Table optional

    Array of arguments to pass to the command. If not specified, it will try to extract them from the text

Returns

  • any

    bool Whether or not a command has been found and executed

Example Usage

lia.command.parse(player.GetByID(1), "/roll 10")

run(client, command, arguments)

Forces a player to execute a command by name.

Parameters

  • client Player

    who is executing the command

  • command String

    Full name of the command to be executed. This string gets lowered, but it's good practice to stick with the exact name of the command

  • arguments Table

    Array of arguments to be passed to the command

Example Usage

lia.command.run(player.GetByID(1), "Roll", {10})

send(command, ...)

Request the server to run a command. This mimics similar functionality to the client typing /CommandName in the chatbox.

Parameters

  • command String

    Unique ID of the command

  • ... Table

    Arguments to pass to the command

Example Usage

lia.command.send("roll")

Tables

CommandStructure

When registering commands with lia.command.add, you'll need to pass in a valid command structure. This is simply a table with various fields defined to describe the functionality of the command.

Fields

  • onRun function

    This function is called when the command has passed all the checks and can execute. The arguments will be the calling player and subsequent argument list.

  • adminOnly bool default: false

    Provides an additional check to see if the user is an admin before running.

  • superAdminOnly bool default: false

    Provides an additional check to see if the user is a superadmin before running.

  • privilege string default: nil

    Manually specify a privilege name for this command. It will always be prefixed with "Commands - ". This is used in the case that you want to group commands under the same privilege, or use a privilege that you've already defined (i.e grouping /charban and /charunban into the Commands - Ban Characters privilege).

  • onCheckAccess function default: nil

    This callback checks whether or not the player is allowed to run the command. This callback should NOT be used in conjunction with adminOnly or superAdminOnly, as populating those fields create a custom onCheckAccess callback for you internally. This is used in cases where you want more fine-grained access control for your command. Consider this example command:

    lia.command.add("slap", {
        adminOnly = true,
        privilege = "Can Slap",
        onRun = function(client, arguments)
            -- WHAM!
        end
    })
    

    Creates a new command.

  • command String

    Name of the command (recommended in UpperCamelCase)

  • data Table

    Data describing the command

See Also