Simple Robot v4.7.0 Help

Spring Boot

simbot Spring Boot starter 基于核心库实现,提供对 Spring Boot 应用的快速集成能力。

什么是 Spring Boot starter?

参考 官方文档 的说明:

启动器是一组方便的依赖描述符,你可以将它包含在你的应用程序中。

而 simbot Spring Boot starter 便是这样一组描述符:允许你将 simbot 的核心功能更快捷、简单地集成进你的 Spring 应用程序中。 除了核心功能的实现,simbot starter 还实现了 量子猫🐱 Quantcat (注解API), 你可以通过各类注解API更快速高效的编写你的事件处理逻辑 —— 与 Spring 应用一起。

安装

  1. 准备Java

    我们推荐您使用 Spring Boot 3.x。因此 Java 的版本至少为 Java17

  2. 准备 Spring Boot 项目

    前往 start.spring.io 选择、创建一个 Spring Boot 项目下载。 当然,你也可以选择其他任意可行方式来创建项目,例如借助IDE。

    更多参考:

  3. 添加 simbot starter 依赖

    使用 Spring Boot 3,确保项目的JDK版本大于等于 JDK17。

    implementation("love.forte.simbot:simbot-core-spring-boot-starter:4.7.0")
    implementation 'love.forte.simbot:simbot-core-spring-boot-starter:4.7.0'
    <dependency> <groupId>love.forte.simbot</groupId> <artifactId>simbot-core-spring-boot-starter</artifactId> <version>4.7.0</version> </dependency>
    implementation("love.forte.simbot:simbot-core-spring-boot-starter-v2:4.7.0")
    implementation 'love.forte.simbot:simbot-core-spring-boot-starter-v2:4.7.0'
    <dependency> <groupId>love.forte.simbot</groupId> <artifactId>simbot-core-spring-boot-starter-v2</artifactId> <version>4.7.0</version> </dependency>
  4. 添加组件及其要求的其他内容

    simbot的组件是功能的主要提供者,是重要的核心概念之一。 你可以前往 概述 选择你所需要的组件并添加它们,而它们的手册通常都会有各自相应的快速开始安装章节。

    你也可以使用任何可用的第三方组件,并参照它们各自的文档说明进行安装。

使用

启用 simbot

在你的启动类或任意配置类上标记 @EnableSimbot 注解来在 Spring 中启用 simbot。

@EnableSimbot // 启用 simbot @SpringBootApplication class MyApplication fun main(args: Array<String>) { runApplicarion<MyApplication>(*args) }
@EnableSimbot // 启用 simbot @SpringBootApplication public class MyApplication { public static void main(String[] args) { SpringApplication.run(MyApplication.class, args); } }

编写事件处理器

在 Spring Boot 可扫描到 的范围内,创建任意类型,并将其标记为 Spring 的组件(component):

@Component // 交给 Spring 管理 class MyEventHandlers { @Listener // 标记事件处理函数 suspend fun handle1(event: Event) { // 处理事件... } @Listener // 标记事件处理函数 @Filter("你好") // 快捷的注解过滤匹配条件 suspend fun handle2(event: Event) { // 处理事件... } // 更多... }
@Component // 交给 Spring 管理 public class MyEventHandlers { @Listener // 标记事件处理函数 public void handle1(Event event) { // 处理事件... } @Listener // 标记事件处理函数 @Filter("你好") // 快捷的注解过滤匹配条件 public void handle2(Event event) { // 处理事件... } // 更多... }

可配置项

starter 提供了一些可用的 spring 配置项。

以在 application.properties 文件中为例。

# simbot.application: 与 Application 相关的配置 simbot.application.application-launch-mode=NONE # simbot.bots: 与 bot 配置相关的属性。 simbot.bots.auto-registration-failure-policy=ERROR simbot.bots.auto-registration-mismatch-configurable-bot-manager-policy=ERROR_LOG simbot.bots.auto-registration-resource-load-failure-policy=ERROR simbot.bots.auto-start-bots=true simbot.bots.auto-start-mode=ASYNC simbot.bots.configuration-json-resources[0]=classpath:simbot-bots/*.bot.json # simbot.components: 组件相关的配置信息。 simbot.components.auto-install-providers=true simbot.components.auto-install-provider-configures=true # simbot.plugins: 插件相关的配置信息。 simbot.plugins.auto-install-providers=true simbot.plugins.auto-install-provider-configures=true

以在 application.yaml 文件中为例。

simbot: # simbot.application: 与 Application 相关的配置 application: application-launch-mode: none # simbot.bots: 与 bot 配置相关的属性。 bots: auto-registration-failure-policy: ERROR auto-registration-mismatch-configurable-bot-manager-policy: ERROR_LOG auto-registration-resource-load-failure-policy: ERROR auto-start-bots: true auto-start-mode: ASYNC configuration-json-resources: - 'classpath:simbot-bots/*.bot.json' # simbot.components: 组件相关的配置信息。 components: auto-install-providers: true auto-install-provider-configures: true # simbot.plugins: 插件相关的配置信息。 plugins: auto-install-providers: true auto-install-provider-configures: true
simbot.application.application-launch-mode

ApplicationLaunchMode 枚举, 保持 Application 活跃的策略。

默认为 NONE

如果你的 Spring Boot 应用中没有可以保持程序活跃的内容 (最常见的例如 spring-web), 那么可以选择使用 THREAD

NONE

没有行为。

THREAD

使用一个独立的非守护线程保持程序活跃。

simbot.bots.configuration-json-resources

Set<String>, 需要加载的所有组件下它们对应的所有 JSON 格式 的 Bot 配置文件。

默认为 classpath:simbot-bots/*.bot.json, 即本项目中、资源目录下的 resources/simbot-bots 中的所有扩展名为 .bot.json 的配置文件。

simbot.bots.auto-registration-resource-load-failure-policy

BotConfigResourceLoadFailurePolicy 枚举, 当加载用于注册bot的配置文件出现错误时的处理策略。

默认为 ERROR

ERROR

当出现无法解析的资源文件时抛出异常来尝试中断整个处理流程。

ERROR_LOG

当出现无法解析的资源文件时输出 error 级别的日志来尝试中断整个处理流程。

WARN

当出现无法解析的资源文件时会输出 warn 日志。

IGNORE

当出现无法解析的资源文件时仅会输出 debug 调试日志。

simbot.bots.auto-registration-mismatch-configurable-bot-manager-policy

MismatchConfigurableBotManagerPolicy 枚举, 当无法为某个 SerializableBotConfiguration 找到任何可供其注册的 BotManager 时的处理策略。

默认为 ERROR

ERROR

当无法为配置类找到任何可供注册的 BotManager 时抛出异常来尝试中断整个处理流程。

ERROR_LOG

当无法为配置类找到任何可供注册的 BotManager 时输出 error 级别的日志来尝试中断整个处理流程。

WARN

当无法为配置类找到任何可供注册的 BotManager 时会输出 warn 日志。

IGNORE

当无法为配置类找到任何可供注册的 BotManager 时仅会输出 debug 调试日志。

simbot.bots.auto-start-bots

Boolean, 是否在自动扫描的 Bot 注册后使用 Bot.start 启动它们。

默认为 true

simbot.bots.auto-start-mode

BotAutoStartMode 枚举, 当 auto-start-botstrue 时, 批量启动 Bot 的方式。

默认为 ASYNC

SYNC

依次同步启动。

ASYNC

每个 Bot 独立地异步启动。 如果 auto-registration-failure-policyERROR, 则异步中任意 Bot 如果启动失败都会导致整体失败。

simbot.bots.auto-registration-failure-policy

BotRegistrationFailurePolicy, 当自动扫描的bot注册或启动失败时的处理策略。 默认为 ERROR ,直接异常以终止程序。

ERROR

当bot注册或启动过程中出现异常或bot最终无法注册时都会抛出异常并终止程序。 是建议的默认选择。

ERROR_LOG

当bot注册或启动过程中出现异常或bot最终无法注册时会输出带有异常信息的 error 日志。

WARN

当bot注册或启动过程中出现异常或bot最终无法注册时会输出带有异常信息的 warn 日志。

IGNORE

当bot注册或启动过程中出现异常或bot最终无法注册时仅会输出 debug 调试日志。

simbot.components.auto-install-providers

是否通过 SPI 自动加载所有可寻得的组件。

默认为 true

simbot.components.auto-install-provider-configures

是否在加载 SPI providers 时候也同时加载它们的前置配置。 auto-install-providerstrue 时有效。

默认为 true

simbot.plugins.auto-install-providers

是否通过 SPI 自动加载所有可寻得的插件。

simbot.plugins.auto-install-provider-configures

是否在加载 SPI providers 时候也同时加载它们的前置配置。 auto-install-providerstrue 时有效。

额外的定制化配置

starter 提供了大量的 *Configurer 类型来支持你对启动过程中的各个步骤添加额外的自定义配置。

SimbotApplicationConfigurationConfigurer

针对 Application 配置属性的额外配置器。

SimbotDispatcherConfigurer

针对 Spring 下的事件调度器 EventDispatcher 的额外配置器。

SimbotComponentInstaller

Component 组件安装器。

SimbotPluginInstaller

Plugin 插件安装器。

SimbotApplicationLauncherPreConfigurer

构建 Application 过程中, 安插在配置、安装其他内容之前的额外配置器。

SimbotApplicationLauncherPostConfigurer

构建 Application 过程中, 安插在配置、安装其他内容之后的额外配置器。

SimbotApplicationPreConfigurer

Application 构建完成后, (在一定范围内) 安插在其他配置之前的额外配置器。

SimbotApplicationPostConfigurer

Application 构建完成后, (在一定范围内) 安插在其他配置之后的额外配置器。

SimbotEventDispatcherPostConfigurer

Application 构建完成后, 针对 EventDispatcher 的额外配置器。

SimbotEventListenerRegistrarPostConfigurer

Application 构建完成后, 针对 EventListenerRegistrar 的额外配置器。

安装组件以及组件配置

你可以在上面的配置中看到,组件 ComponentPlugin 默认情况下都是通过 SPI 自动加载 的。

因此一般情况下, 你只需要前往 组件库 选择你想要使用的组件, 或者选择某个/些你想要使用的第三方组件, 然后将它们添加到你的运行时环境中即可。

如果你想要添加更多定制化的配置或注册额外的组件、插件, 可参考实现上面提到的 SimbotComponentInstallerSimbotPluginInstaller:

@Component // 交给 Spring 管理 open class MyComponentInstaller: SimbotComponentInstaller { override fun install(installer: ComponentInstaller) { // 配置或安装,同一个工厂实例的多次配置会被合并 installer.install(...) installer.install(...) { ... } } } @Component // 交给 Spring 管理 open class MyPluginInstaller: SimbotPluginInstaller { override fun install(installer: PluginInstaller) { // 配置或安装,同一个工厂实例的多次配置会被合并 installer.install(...) installer.install(...) { ... } } }
@Component // 交给 Spring 管理 public class MyComponentInstaller implements SimbotComponentInstaller { @Override public void install(@NotNull ComponentInstaller installer) { // 配置或安装,同一个工厂实例的多次配置会被合并 installer.install(...); installer.install(..., config -> { ... }); } } @Component // 交给 Spring 管理 public class MyPluginInstaller implements SimbotPluginInstaller { @Override public void install(@NotNull PluginInstaller installer) { // 配置或安装,同一个工厂实例的多次配置会被合并 installer.install(...); installer.install(..., config -> { ... }); } }

或者选择 SimbotApplicationLauncherPreConfigurerSimbotApplicationLauncherPostConfigurer, 直接添加一个在 Application 构建阶段的配置。

@Component // 交给 Spring 管理 public class MyComponentInstaller implements SimbotApplicationLauncherPreConfigurer { @Override override fun configure(configurer: ApplicationFactoryConfigurer<SpringApplicationBuilder, SpringApplicationEventRegistrar, SpringEventDispatcherConfiguration>) { // 配置或安装,同一个工厂实例的多次配置会被合并 configurer.install(...) installer.install(...) { ... } } }
@Component // 交给 Spring 管理 public class MyComponentInstaller implements SimbotApplicationLauncherPreConfigurer { @Override public void configure(@NotNull ApplicationFactoryConfigurer<SpringApplicationBuilder, SpringApplicationEventRegistrar, SpringEventDispatcherConfiguration> configurer) { // 配置或安装,同一个工厂实例的多次配置会被合并 configurer.install(...); installer.install(..., config -> { ... }); } }

注册Bot

对于大多数组件而言,它们都支持通过 *.bot.json 配置文件在自动扫描、注册、启动。 bot的配置文件路径默认为 classpath:simbot-bots/*.bot.json, 也就是资源目录下的 simbot-bots 文件夹内所有以 .bot.json 作为扩展名的文件。

每一个不同的组件,它们的配置文件的内容是不同的。你需要参照你所使用的对应组件的文档说明来编写。 以 OneBot组件为例,它的配置文件的最简化是这样的:

{ "component": "simbot.onebot11", "authorization": { "botUniqueId": "123456", "apiServerHost": "http://localhost:3000", "eventServerHost":"ws://localhost:3001" } }

各组件的手册内都会有有关 Bot配置文件 的说明章节,可前往对应的手册进行参考。

运行或打包

你可以参考 Spring Boot 针对不同构建工具的执行、打包或其他任何内容的详细说明手册:

如果是借助 start.spring.io 等工具生成的项目, 那么也可以参考项目目录中可能自带的 HELP.md 文档中的内容。

注意事项

常见问题

获取 Application、BotManager 或 Bot

在配合使用 Spring Boot 时,你可以直接通过bean注入的方式得到 Application 实例。

@Component class MyComponent @Autowired // 其实注解可以省略,这里只是为了让'注入'行为比较显眼儿 constructor( private val application: Application // 构造注入 Application ) { // ... }
@Component public class MyComponent { private final Application application; @Autowired // 其实注解可以省略,这里只是为了让'注入'行为比较显眼儿 public MyComponent(Application application) { // 构造注入 Application this.application = application; } // ... }

你也可以基于此间接地获取 BotManagerBot 等其他信息。

@Component class MyComponent( private val application: Application ) { // 假设这里是个定时任务 // 或者其他什么跟事件没关系的地方 fun runTask() { // 得到所有的BotManager并遍历 for (botManager in application.botManagers) { // ... // 得到每一个BotManager中的所有已注册且未被关闭的Bot并遍历 for (bot in botManager.all()) { // ... } } } }
@Component public class MyComponent { private final Application application; public MyComponent(Application application) { this.application = application; } // 假设这里是个定时任务 // 或者其他什么跟事件没关系的地方 public void runTask() { // 得到所有的BotManager并遍历 for (var botManager : application.getBotManagers()) { // ... // 得到每一个BotManager中的所有已注册且未被关闭的Bot并遍历 for (var it = botManager.all().iterator(); it.hasNext(); ) { var bot = it.next(); // ... } } } }

这通常用于主动获取已注册的 Bot,然后用于主动发送消息等。

Last modified: 15 November 2024