mirror of
https://github.com/InsanusMokrassar/MicroUtils.git
synced 2024-11-01 14:03:50 +00:00
93 lines
2.7 KiB
Markdown
93 lines
2.7 KiB
Markdown
|
# Startup Plugin Launcher
|
||
|
|
||
|
This module contains tools to start your plugin system.
|
||
|
|
||
|
## Config
|
||
|
|
||
|
Base config is pretty simple:
|
||
|
|
||
|
```json
|
||
|
{
|
||
|
"plugins": [
|
||
|
"dev.inmo.micro_utils.startup.launcher.HelloWorldPlugin"
|
||
|
]
|
||
|
}
|
||
|
```
|
||
|
|
||
|
So, `"dev.inmo.micro_utils.startup.launcher.HelloWorldPlugin"` is the fully qualified name of plugin you wish to be
|
||
|
included in the server.
|
||
|
|
||
|
> JS note: In JS there are no opportunity to determine object type by its full name. Because of it, in JS developers
|
||
|
> should prefer to use `Config` in their kotlin code directly instead of json config passing. More info see in [JS](#js)
|
||
|
> section
|
||
|
|
||
|
## JVM
|
||
|
|
||
|
For JVM target you may use main class by path: `dev.inmo.micro_utils.startup.launcher.MainKt`
|
||
|
|
||
|
It is expected, that you will pass the main ONE argument with path to the config json. Sample of launching:
|
||
|
|
||
|
```bash
|
||
|
./gradlew run --args="sample.config.json"
|
||
|
```
|
||
|
|
||
|
Content of `sample.config.json` described in [Config](#config) section.
|
||
|
|
||
|
You may build runnable app using:
|
||
|
|
||
|
```bash
|
||
|
./gradlew assembleDist
|
||
|
```
|
||
|
|
||
|
In that case in `build/distributions` folder you will be able to find zip and tar files with all required
|
||
|
tools for application running (via their `bin/app_name` binary). In that case yoy will not need to pass
|
||
|
`--args=...` and launch will look like `./bin/app_name sample.config.json`
|
||
|
|
||
|
## JS
|
||
|
|
||
|
In JS for starting of your plugins app, you should use `PluginsStarter` in your code:
|
||
|
|
||
|
```kotlin
|
||
|
PluginsStarter.startPlugins(
|
||
|
Config(HelloWorldPlugin)
|
||
|
)
|
||
|
```
|
||
|
|
||
|
`Config` here is deserialized variant from [Config](#config) section. As was said in [Config](#config) section, in JS
|
||
|
there is no way to find classes/objects by their full qualifiers. Because of it you should use some way to register your
|
||
|
plugins in `StartPluginSerializer` or use the code like in the snippet above: there plugins will be registered
|
||
|
automatically.
|
||
|
|
||
|
In case you wish to register your plugins manually and run server from config, you should use one of the ways to register
|
||
|
plugin on start.
|
||
|
|
||
|
Sample with `EagerInitialization`: [Kotlin JS doc about lazy initialization](https://kotlinlang.org/docs/js-ir-compiler.html#incremental-compilation-for-development-binaries),
|
||
|
[@EagerInitialization docs](https://kotlinlang.org/api/latest/jvm/stdlib/kotlin.js/-eager-initialization/):
|
||
|
|
||
|
```kotlin
|
||
|
@ExperimentalStdlibApi
|
||
|
@EagerInitialization
|
||
|
val plugin = createStartupPluginAndRegister("PluginNameToUseInConfig") {
|
||
|
// Your plugin creation. For example:
|
||
|
HelloWorldPlugin
|
||
|
}
|
||
|
```
|
||
|
|
||
|
So, in that case you will be able to load plugins list as `JsonObject` from anywhere and start plugins app with it:
|
||
|
|
||
|
```kotlin
|
||
|
PluginsStarter.startPlugins(
|
||
|
jsonObject
|
||
|
)
|
||
|
```
|
||
|
|
||
|
It will load `HelloWorldPlugin` if `jsonObject` have next content:
|
||
|
|
||
|
```json
|
||
|
{
|
||
|
"plugins": [
|
||
|
"PluginNameToUseInConfig"
|
||
|
]
|
||
|
}
|
||
|
```
|