Skip to main content

Creating a Module

If you are interested in creating a module, this guide is for you. Note that you should be familiar with Java, Git, and the Gradle build system.

Cloning the template

There is a template you can use when creating a module. You can find it on GitHub here. You should fork this onto your local GitHub account. You can then clone the fork to your computer. Once you have it open in your IDE, try building it with Gradle to ensure everything works.

Changing the branding

In settings.gradle.kts, you should change the name to the name of the module you want. All modules follow the naming convention of Module-<name>.

You should also open the build.gradle.kts file and change the description to Module-<name> as well. You should also change the version from 1.0 to the current version of Plex available. If you are building against 1.5-SNAPSHOT, you should set your version to that as well.

You should also look for this block of code in your build.gradle.kts file:

build.gradle.kts
tasks.getByName<Jar>("jar") {
archiveBaseName.set("Module-ExampleModule")
archiveVersion.set("")
}

Change the Module-ExampleModule to the name of your module. Ensure you keep the Module- part. This is the name of your JAR file. If you change it, the auto updater may not work.

Finally, in /src/main/resources/module.yml, you should change this information to your liking. The version here should match the version you set in build.gradle.kts. The main property should be changed to the entrypoint for the module. This is very similar to the main JavaPlugin when creating a new Bukkit plugin.

Creating commands

Commands are created just like they are in Plex. There is an example command to help you get started. It is a good template to follow, and you can customize it based on your needs. You are able to access all the APIs and data from Plex.

When you create a new command, you should register it in your main class as follows

/src/main/java/ExampleModule.java
registerCommand(new ExampleCommand());

Make sure you replace the ExampleCommand class with your own class that the command is in. You should have one registerCommand(); call per class. Subcommands should be within each command class.

You'll want to make sure your class extends PlexCommand and implements both the execute(@NotNull CommandSender sender, @Nullable Player player, @NotNull String[] args) and smartTabComplete(@NotNull CommandSender sender, @NotNull String alias, @NotNull String[] args) methods.

You should implement the @CommandParameters and @CommandPermissions annotations instead of handling permissions for the main command inside the actual execute() block.

Creating listeners

Listeners function just like they do in Bukkit, they listen for events. You'll want to do two things. Make sure your listener extends the PlexListener class rather than the Bukkit default Listener class. The PlexListener class is a wrapper for the Listener class and has the same functionality as the Bukkit one. You'll also want to ensure you register the listener in the main class as follows:

/src/main/java/ExampleModule.java
registerListener(new ExampleListener());

Make sure you replace the ExampleListener class with your own class name.

You can listen for as many events as you like per class. An example to listen for an event when a player joins and send them a message is as follows:

/src/main/java/ExampleModule.java
@EventHandler
public void onPlayerJoin(PlayerJoinEvent event)
{
Player player = event.getPlayer();
player.sendMessage(Component.text("This is a message from Plex's example module!").color(NamedTextColor.GOLD));
}

Creating and using configuration files

To create a configuration file for your module, you should create a new folder in the /src/main/resources directory with the module name. An example for the example module would be /src/main/resources/examplemodule. Within the folder, you can create your config.yml file. In the main class, you should add a new ModuleConfig globally, and load it on the load() method.

/src/main/java/ExampleModule.java
public class ExampleModule extends PlexModule
{
@Getter
private static ExampleModule module;

@Getter
private ModuleConfig config;

@Override
public void load()
{
module = this;
config = new ModuleConfig(this, "examplemodule/config.yml", "config.yml");
config.load();
}
}

The "examplemodule/config.yml" part refers to where the configuration file is stored relative to /src/main/resources. The "config.yml" refers to where it should go inside the /plugins/Plex/modules/Module-Example folder.

You can then call values from the configuration with the following:

ExampleModule.getModule().getConfig().getString("module.test-message");