Simple Robot v4.10.0 Help

组件标识 Component

组件标识 指的是 simbot-api 模块中对外提供的接口类型 Component 。它的定义大致如下:

public interface Component { /** * 一个组件的ID。 * 组件id建议使用类似于Java包路径的格式, * 例如 `org.example.Sample` 并尽量避免重复。 */ public val id: String /** * 组件对外提供的统合所有所需的序列化信息。 * 通常为 message 类型的序列化或文件配置类的序列化信息。 */ public val serializersModule: SerializersModule // 其他省略... }
id

此组件的一个唯一ID标识。

serializersModule

此组件的各种序列化信息, 例如消息元素、可序列化的 Bot 配置类等。

使用组件标识

组件标识用于构建 Application 的过程中, 先注册组件标识, 用来告知后续步骤将要被注册的 插件 并为它提供一些可能的配置。

首先我们假设有如下这样的一个 Component 实现:

class FooComponent : Component { override val id: String = "example.foo" override val serializersModule: SerializersModule = EmptySerializersModule() companion object Factory : ComponentFactory<FooComponent, Unit> { override val key: ComponentFactory.Key = object : ComponentFactory.Key {} override fun create(context: ComponentConfigureContext, configurer: ConfigurerFunction<Unit>): FooComponent { return FooComponent() } } }

安装

接下来我们要在 Application安装(install) 这个假设出来的 FooComponent:

launchSimpleApplication { install(FooComponent) }
Applications.launchApplicationAsync(Simple.INSTANCE, configurer -> { configurer.install(FooComponent.Factory); });
Applications.launchApplicationBlocking(Simple.INSTANCE, configurer -> { configurer.install(FooComponent.Factory); });

配置

假如 FooComponent 有可配置的信息的话, 也可以使用 DSL/Lambda 对其进行配置:

launchSimpleApplication { install(FooComponent) { // 配置... } }
Applications.launchApplicationAsync(Simple.INSTANCE, configurer -> { configurer.install(FooComponent.Factory, conf -> { // 配置... }); });
Applications.launchApplicationBlocking(Simple.INSTANCE, configurer -> { configurer.install(FooComponent.Factory, conf -> { // 配置... }); });

事后获取

当我们注册完成、并启动了一个 Application 之后, 如果想要获取注册过的组件, 则可以在 Application 中找到它们:

val app = launchSimpleApplication { install(FooComponent) } app.components.forEach { component -> // 所有注册了的组件 }
Applications.launchApplicationAsync(Simple.INSTANCE, configurer -> { configurer.install(FooComponent.Factory); }).asFuture().thenAccept(app -> { for (var component : app.getComponents()) { // 所有注册了的组件... } });
var app = Applications.launchApplicationBlocking(Simple.INSTANCE, configurer -> { configurer.install(FooComponent.Factory); }); for (var component : app.getComponents()) { // 所有注册了的组件... }
Last modified: 18 January 2025