Warning: The plugin system is still in beta. Breaking changes may still be made to the plugin API if deemed necessary.
Lavalink supports third-party plugins to add additional functionality such as custom audio sources, custom filters, WebSocket handling, REST endpoints, and much more.
List of plugins:
- Google Cloud TTS A text to speech plugin using the google cloud tts api
- SponsorBlock for skipping sponsor segments in YouTube videos
- Topis Source Managers adds Spotify and Apple Music support
- DuncteBot plugin adds additional source managers that are not widely used
Lavalink loads all .jar files placed in the plugins
directory, which you may need to create yourself. Lavalink can
also download plugin .jar files automatically by editing the configuration file. See the respective plugin repository
for instructions.
You can add your own plugin by submitting a pull-request to this file.
Follow these steps to quickly get started with plugin development:
- Create a copy of https://github.com/freyacodes/lavalink-plugin-template
- Rename the directories
org/example/plugin/
undersrc/main/java/
to something more specific likeio/github/yourusername/yourplugin
- Rename
src/main/resources/lavalink-plugins/your-plugin.properties
to the name of your plugin. The file must end with.properties
. This is the plugin manifest. - Fill out the name, path, and version properties in the manifest. The path is where your classes will be loaded from,
e.g.
io.github.yourusername.yourplugin
.
Now you can start writing your plugin. You can test your plugin against Lavalink by running Gradle with the
:run
Gradle task. The Gradle documentation might be helpful.
Lavalink has a plugin API which you can integrate with. The API is provided as an artifact and is used by the template. It is also possible to integrate with internal parts og Lavalink, but this is not recommended. Instead, open an issue or pull-request to change the API.
Lavalink is configured by plugins using the Spring Boot framework using Spring annotations. For instance, you could define an extension to the WebSocket API by exposing a Spring bean like this:
@Service
class MyExtension implements WebSocketExtension {
// ...
}
You can also define custom REST endpoints and configuration file properties. See the Spring Boot documentation for Spring Web MVC and type-safe configuration.
If you simply want to add a Lavaplayer AudioSourceManager
to Lavalink it is sufficient to simply provide it as a bean.
For example:
import org.springframework.stereotype.Service;
@Service
class MyAudioSourceManager implements AudioSourceManager {
// ...
}