From cc592599d84e23fd41ff06e5344a5e6930104a0d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?To=CF=80?= Date: Thu, 12 Oct 2023 01:27:14 +0200 Subject: [PATCH] implement default lavalink plugin repository --- LavalinkServer/application.yml.example | 11 +++++-- .../server/bootstrap/PluginManager.kt | 5 +++- .../server/bootstrap/PluginsConfig.kt | 5 +++- PLUGINS.md | 30 +++++++++++++++++++ 4 files changed, 46 insertions(+), 5 deletions(-) diff --git a/LavalinkServer/application.yml.example b/LavalinkServer/application.yml.example index 39d2ab0d9..91e697f4b 100644 --- a/LavalinkServer/application.yml.example +++ b/LavalinkServer/application.yml.example @@ -1,15 +1,20 @@ server: # REST and WS server port: 2333 address: 0.0.0.0 + http2: + enabled: false # Whether to enable HTTP/2 support plugins: # name: # Name of the plugin # some_key: some_value # Some key-value pair for the plugin # another_key: another_value lavalink: plugins: -# - dependency: "group:artifact:version" -# repository: "repository" - pluginsDir: "./plugins" +# - dependency: "com.github.example:example-plugin:1.0.0" # required, the dependency to your plugin +# repository: "https://maven.example.com/releases" # optional, defaults to the Lavalink release repository +# snapshot: false # optional, defaults to false, used to tell Lavalink to use the snapshot repository instead of the release repository +# pluginsDir: "./plugins" # optional, defaults to "./plugins" +# defaultPluginRepository: "https://maven.example.com/releases" # optional, defaults to the Lavalink release repository +# defaultPluginSnapshotRepository: "https://maven.example.com/snapshots" # optional, defaults to the Lavalink snapshot repository server: password: "youshallnotpass" sources: diff --git a/LavalinkServer/src/main/java/lavalink/server/bootstrap/PluginManager.kt b/LavalinkServer/src/main/java/lavalink/server/bootstrap/PluginManager.kt index 44429644a..b058aa5e9 100644 --- a/LavalinkServer/src/main/java/lavalink/server/bootstrap/PluginManager.kt +++ b/LavalinkServer/src/main/java/lavalink/server/bootstrap/PluginManager.kt @@ -47,7 +47,10 @@ class PluginManager(val config: PluginsConfig) { data class Declaration(val group: String, val name: String, val version: String, val repository: String) val declarations = config.plugins.map { declaration -> - if (declaration.dependency == null || declaration.repository == null) throw RuntimeException("Illegal declaration $declaration") + if (declaration.dependency == null) throw RuntimeException("Illegal dependency declaration: null") + if (declaration.repository == null) { + declaration.repository = if (declaration.snapshot) config.defaultSnapshotRepo else config.defaultRepo + } val fragments = declaration.dependency!!.split(":") if (fragments.size != 3) throw RuntimeException("Invalid dependency \"${declaration.dependency}\"") val repository = diff --git a/LavalinkServer/src/main/java/lavalink/server/bootstrap/PluginsConfig.kt b/LavalinkServer/src/main/java/lavalink/server/bootstrap/PluginsConfig.kt index aaeac29cc..5f6bd0421 100644 --- a/LavalinkServer/src/main/java/lavalink/server/bootstrap/PluginsConfig.kt +++ b/LavalinkServer/src/main/java/lavalink/server/bootstrap/PluginsConfig.kt @@ -8,9 +8,12 @@ import org.springframework.stereotype.Component class PluginsConfig { var plugins: List = emptyList() var pluginsDir: String = "./plugins" + var defaultPluginRepository: String = "https://maven.lavalink.dev/releases" + var defaultPluginSnapshotRepository: String = "https://maven.lavalink.dev/snapshots" } data class PluginDeclaration( var dependency: String? = null, - var repository: String? = null + var repository: String? = null, + var snapshot: Boolean = false ) \ No newline at end of file diff --git a/PLUGINS.md b/PLUGINS.md index 08e27ca5c..7e1134b18 100644 --- a/PLUGINS.md +++ b/PLUGINS.md @@ -19,6 +19,36 @@ for instructions. You can add your own plugin by submitting a pull-request to this file. +## Official plugin repository + +The official plugin repository is hosted on https://maven.lavalink.dev. If you want to publish your plugin there, please reach out to us via [Discord](https://discord.gg/ZW4s47Ppw4) for credentials. +The repository has a release (https://maven.lavalink.dev/releases) and snapshot (https://maven.lavalink.dev/snapshots) repository which you can use to publish your plugin. +By default, Lavalink will look for the plugin in the Lavalink repository, but you can also specify a custom repository for each plugin in your `application.yml` file. + +```yaml + +lavalink: + plugins: + - dependency: "com.github.example:example-plugin:1.0.0" # required, the dependency to your plugin + repository: "https://maven.example.com/releases" # optional, defaults to the Lavalink release repository + snapshot: false # optional, defaults to false, used to tell Lavalink to use the snapshot repository instead of the release repository +``` + +The default repository can also be overwritten in your `application.yml` file. + +```yaml +lavalink: + defaultPluginRepository: "https://maven.example.com/releases" # optional, defaults to the Lavalink release repository + defaultPluginSnapshotRepository: "https://maven.example.com/snapshots" # optional, defaults to the Lavalink snapshot repository +``` + +Additionally, you can overwrite the default plugin folder where Lavalink saves the downloaded plugins, or loads them from. + +```yaml +lavalink: + pluginsDir: "./lavalink-plugins" # optional, defaults to "./plugins" +``` + ## Developing your own plugin > **Note:**