repositories {
maven("https://repo.hypera.dev/snapshots/")
}
dependencies {
implementation("dev.lu15:luckperms-minestom:5.4-SNAPSHOT")
}
Path directory = Path.of("luckperms");
LuckPerms luckPerms = LuckPermsMinestom.builder(directory)
.commandRegistry(CommandRegistry.minestom()) // enables registration of LuckPerms commands
.contextProvider(new DummyContextProvider()) // provide additional custom contexts
.configurationAdapter(plugin -> new MultiConfigurationAdapter(plugin, // define the configuration
new EnvironmentVariableConfigAdapter(plugin), // use MultiConfigurationAdapter to load from multiple sources, in order
new HoconConfigurationAdapter(plugin)
)).permissionSuggestions("test.permission", "test.other") // add permission suggestions for commands and the web editor
.dependencyManager(true) // automatically download and classload dependencies
.enable();
LuckPerms is a permissions plugin for Minecraft servers. It allows server admins to control what features players can use by creating groups and assigning permissions.
The latest downloads, wiki & other useful links can be found on the project homepage at luckperms.net.
It is:
- fast - written with performance and scalability in mind.
- reliable - trusted by thousands of server admins, and the largest of server networks.
- easy to use - setup permissions using commands, directly in config files, or using the web editor.
- flexible - supports a variety of data storage options, and works on lots of different server types.
- extensive - a plethora of customization options and settings which can be changed to suit your server.
- free - available for download and usage at no cost, and permissively licensed so it can remain free forever.
For more information, see the wiki article on Why LuckPerms?
LuckPerms uses Gradle to handle dependencies & building.
- Java 21 JDK or newer
- Git
git clone https://github.com/LuckPerms/LuckPerms.git
cd LuckPerms/
./gradlew build
You can find the output jars in the loader/build/libs
or build/libs
directories.
There are some automated tests which run during each build.
- Unit tests are defined in
common/src/test
- Integration tests are defined in
standalone/src/test
.
If you make any changes or improvements to the plugin which you think would be beneficial to others, please consider making a pull request to merge your changes back into the upstream project. (especially if your changes are bug fixes!)
LuckPerms loosely follows the Google Java Style Guide. Generally, try to copy the style of code found in the class you're editing.
The project is split up into a few separate modules.
- API - The public, semantically versioned API used by other plugins wishing to integrate with and retrieve data from LuckPerms. This module (for the most part) does not contain any implementation itself, and is provided by the plugin.
- Common - The common module contains most of the code which implements the respective LuckPerms plugins. This abstract module reduces duplicated code throughout the project.
- Bukkit, BungeeCord, Fabric, Forge, Nukkit, Sponge & Velocity - Each use the common module to implement plugins on the respective server platforms.
LuckPerms is licensed under the permissive MIT license. Please see LICENSE.txt
for more info.