Single command conversion
Often, you don't want to convert every single command that a plugin declares, and instead you only want to convert a few commands that a plugin has.
The CommandAPI has two ways of doing this:
- Plugin command conversion: This converts a command which is declared in a plugin's
plugin.yml
file - Arbitrary command conversion: This converts a command which is not declared in a plugin's
plugin.yml
file
Plugin command conversion
To convert a single command, you need to first populate the config.yml
with the name of the plugin and commands to be converted. To illustrate this, we'll use an example:
Example – Converting plugin commands
Example – Converting plugin commands
Say we're using EssentialsX on our server and we want to be able to use /afk
and /hat
in command blocks. This would allow us to use (for example) the following commands in command blocks:
/execute as @p run afk
/execute as @p run hat
To do this, we need to add Essentials
to our config.yml
file, and include the commands afk
and hat
as the commands to be converted from the Essentials plugin. This would then make our config.yml
file look like this:
verbose-outputs: true
create-dispatcher-json: false
plugins-to-convert:
- Essentials:
- hat
- afk
Developer's Note:
Note that the commands hat
and afk
are used, as opposed to an alias such as head
. The CommandAPI is only able to convert plugin commands that are declared in a plugin's plugin.yml
file. For example, if we take a look at the EssentialsX plugin.yml
file, we can see the commands afk
and hat
have been declared and thus, are the commands which must be used in the CommandAPI's config.yml
file:
name: Essentials
main: com.earth2me.essentials.Essentials
version: 2.18.0.0
website: http://tiny.cc/EssentialsCommands
description: Provides an essential, core set of commands for Bukkit.
softdepend: [ Vault, LuckPerms ]
authors: [ Zenexer, ementalo, Aelux, Brettflan, KimKandor, snowleo, ceulemans, Xeology, KHobbits, md_5, Iaccidentally, drtshock, vemacs, SupaHam, md678685 ]
api-version: "1.13"
commands:
afk:
description: Marks you as away-from-keyboard.
usage: /<command> [player/message...]
aliases: [ eafk,away,eaway ]
# (other config options omitted)
hat:
description: Get some cool new headgear.
usage: /<command> [remove]
aliases: [ ehat,head,ehead ]
# (other config options omitted)
Arbitrary command conversion
Some commands which are registered by plugins aren’t present in the plugin's plugin.yml
file. Due to this, the CommandAPI can’t link a command to its respective plugin for command conversion. In order to deal with this, the CommandAPI can link arbitrary commands via the other-commands-to-convert
option in the CommandAPI's config.yml
file.
This can be used for any of the following (and more):
- Commands created using Skript
- Commands created using MyCommand
- Commands which are not registered in a
plugin.yml
, such as WorldEdit commands
To add commands to be converted, simply add them under the other-command-to-convert
section in the CommandAPI's config.yml
.
Example – Converting arbitrary commands
Example – Converting arbitrary commands
In this example, we want to convert the //set
command from WorldEdit, as well as a custom command /mycommand
. Note that since WorldEdit's //set
command has two forward slashes, we ignore the first one (because that is the symbol used to start commands), but must make sure that we include the second one as that is part of WorldEdit's command syntax. This is the following config.yml
that you would need:
verbose-outputs: false
create-dispatcher-json: false
plugins-to-convert: []
skip-sender-proxy: []
other-commands-to-convert:
- /set
- mycommand