mirror of
				https://github.com/InsanusMokrassar/MicroUtils.git
				synced 2025-10-25 09:10:30 +00:00 
			
		
		
		
	add kdocs to the startup module
This commit is contained in:
		| @@ -1,9 +1,9 @@ | ||||
| package dev.inmo.micro_utils.startup.launcher | ||||
|  | ||||
| import dev.inmo.micro_utils.startup.plugin.ServerPlugin | ||||
| import dev.inmo.micro_utils.startup.plugin.StartPlugin | ||||
| import kotlinx.serialization.Serializable | ||||
|  | ||||
| @Serializable | ||||
| data class Config( | ||||
|     val plugins: List<ServerPlugin> | ||||
|     val plugins: List<StartPlugin> | ||||
| ) | ||||
|   | ||||
| @@ -2,10 +2,10 @@ package dev.inmo.micro_utils.startup.launcher | ||||
|  | ||||
| import dev.inmo.kslog.common.i | ||||
| import dev.inmo.kslog.common.logger | ||||
| import dev.inmo.micro_utils.startup.plugin.ServerPlugin | ||||
| import dev.inmo.micro_utils.startup.plugin.StartPlugin | ||||
| import org.koin.core.Koin | ||||
|  | ||||
| object HelloWorldPlugin : ServerPlugin { | ||||
| object HelloWorldPlugin : StartPlugin { | ||||
|     override suspend fun startPlugin(koin: Koin) { | ||||
|         super.startPlugin(koin) | ||||
|         logger.i("Hello world") | ||||
|   | ||||
| @@ -6,8 +6,15 @@ import org.koin.core.KoinApplication | ||||
| import org.koin.core.context.GlobalContext | ||||
| import org.koin.dsl.module | ||||
|  | ||||
| /** | ||||
|  * Will create [KoinApplication], init, load modules using [StartLauncherPlugin] and start plugins using the same base | ||||
|  * plugin | ||||
|  * | ||||
|  * @param rawConfig It is expected that this [JsonObject] will contain serialized [Config] ([StartLauncherPlugin] will | ||||
|  * deserialize it in its [StartLauncherPlugin.setupDI] | ||||
|  */ | ||||
| suspend fun start(rawConfig: JsonObject) { | ||||
|     with(StartupLauncherPlugin) { | ||||
|     with(StartLauncherPlugin) { | ||||
|         logger.i("Start initialization") | ||||
|         val koinApp = KoinApplication.init() | ||||
|         koinApp.modules( | ||||
|   | ||||
| @@ -4,23 +4,38 @@ import dev.inmo.kslog.common.i | ||||
| import dev.inmo.kslog.common.taggedLogger | ||||
| import dev.inmo.kslog.common.w | ||||
| import dev.inmo.micro_utils.coroutines.runCatchingSafely | ||||
| import dev.inmo.micro_utils.startup.plugin.ServerPlugin | ||||
| import dev.inmo.micro_utils.startup.plugin.StartPlugin | ||||
| import kotlinx.coroutines.CoroutineScope | ||||
| import kotlinx.coroutines.Dispatchers | ||||
| import kotlinx.coroutines.joinAll | ||||
| import kotlinx.coroutines.launch | ||||
| import kotlinx.serialization.SerialFormat | ||||
| import kotlinx.serialization.StringFormat | ||||
| import kotlinx.serialization.json.JsonObject | ||||
| import org.koin.core.Koin | ||||
| import org.koin.core.module.Module | ||||
| import org.koin.dsl.binds | ||||
| import org.koin.dsl.module | ||||
| 
 | ||||
| object StartupLauncherPlugin : ServerPlugin { | ||||
| /** | ||||
|  * Default startup plugin. See [setupDI] and [startPlugin] for more info | ||||
|  */ | ||||
| object StartLauncherPlugin : StartPlugin { | ||||
|     internal val logger = taggedLogger(this) | ||||
| 
 | ||||
|     /** | ||||
|      * Will deserialize [Config] from [config], register it in receiver [Module] (as well as [CoroutineScope] and | ||||
|      * [kotlinx.serialization.json.Json]) | ||||
|      * | ||||
|      * Besides, in this method will be called [StartPlugin.setupDI] on each plugin from [Config.plugins]. In case when | ||||
|      * some plugin will not be loaded correctly it will be reported throw the [logger] | ||||
|      */ | ||||
|     override fun Module.setupDI(config: JsonObject) { | ||||
|         val pluginsConfig = defaultJson.decodeFromJsonElement(Config.serializer(), config) | ||||
| 
 | ||||
|         single { pluginsConfig } | ||||
|         single { CoroutineScope(Dispatchers.Default) } | ||||
|         single { defaultJson } binds arrayOf(StringFormat::class, SerialFormat::class) | ||||
| 
 | ||||
|         includes( | ||||
|             pluginsConfig.plugins.mapNotNull { | ||||
| @@ -37,6 +52,10 @@ object StartupLauncherPlugin : ServerPlugin { | ||||
|         ) | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|      * Takes [CoroutineScope] and [Config] from the [koin], and call starting of each plugin from [Config.plugins] | ||||
|      * ASYNCHRONOUSLY. Just like in [setupDI], in case of fail in some plugin it will be reported using [logger] | ||||
|      */ | ||||
|     override suspend fun startPlugin(koin: Koin) { | ||||
|         val scope = koin.get<CoroutineScope>() | ||||
|         koin.get<Config>().plugins.map { plugin -> | ||||
		Reference in New Issue
	
	Block a user