mirai/backend/mirai-console
2020-08-27 23:18:36 +08:00
..
src Support custom data classes in PluginData 2020-08-27 23:18:36 +08:00
build.gradle.kts Introduce PluginData and PluginConfig 2020-08-25 22:43:31 +08:00
README.md Introduce PluginData and PluginConfig 2020-08-25 22:43:31 +08:00

mirai-console backend

欢迎来到 mirai-console 后端开发文档。

包结构

基础

Plugin 模块

Console 支持拥有强扩展性的插件加载器。内建 JVM 插件支持 (JarPluginLoader)。

插件加载器 PluginLoader插件管理器

Console 本身是一套高扩展性的「框架」,拥有通用的 插件加载器

Console 内置 JarPluginLoader,支持加载使用 Kotlin、 Java或其他 JVM 平台编程语言并打包为 jar 的插件 (详见下文 JvmPlugin)。

扩展的 插件加载器 可以由一个特别的 JVM 插件 提供。

服务器启动过程中的插件加载流程

在服务器启动过程中, Console 首先加载那些提供扩展 插件加载器 的插件. 并允许它们 注册扩展加载器
随后对插件按依赖顺序调用 onLoad(), 告知插件主类加载完毕, 相关依赖解决完毕.
当所有插件的 onLoad() 都被调用后, PluginManager 按依赖顺序依次调用 onEnable()

如果 A 依赖 B, B 依赖 C. 那么启动时的调用顺序为:
C.onLoad() -> B.onLoad() -> A.onLoad() -> C.onEnable -> B.onEnable() -> A.onEnable()

Plugin

所有 Console 插件都必须实现 Plugin 接口。

Plugin 很通用,它只拥有很少的成员:

interface Plugin : CommandOwner {
    val isEnabled: Boolean
    val loader: PluginLoader<*, *> // 能处理这个 Plugin 的 PluginLoader
}

Plugin 可在相应 插件加载器 PluginLoader 的帮助下,成为任何语言实现的插件与 Console 建立联系的桥梁。

JVM 插件

JvmPlugin
interface JvmPlugin : Plugin, CoroutineScope, PluginFileExtensions, ResourceContainer, AutoSavePluginDataHolder {
    val logger: MiraiLogger
    val description: JvmPluginDescription
    val loader: JarPluginLoader
    fun <T : PluginData> loadPluginData(clazz: Class<T>): T
    fun <T : PluginConfig> loadPluginConfig(clazz: Class<T>): T
    fun onLoad()
    fun onEnable()
    fun onDisable()
}
plugin.yml

JVM 插件, 通常需要打包为 jar 后才能被加载. jar 中根目录需要包含一个 plugin.yml, 他将会被读取为 JvmPluginDescription.

注意:

plugin.yml 的内容如下:

# 必须. 插件名称, 允许空格, 允许中文, 不允许 ':'
name: "MyTestPlugin"

# 必须. 插件主类, 即继承 KotlinPlugin 或 JavaPlugin 的类
main: org.example.MyPluginMain

# 必须. 插件版本. 遵循《语义化版本 2.0.0》规范
version: 0.1.0

# 可选. 插件种类.
# 'NORMAL': 表示普通插件 
# 'LOADER': 表示提供扩展插件加载器的插件 
kind: NORMAL 

# 可选. 插件描述
info: "这是一个测试插件"

# 可选. 插件作者
author: "Mirai Example"

# 可选. 插件依赖列表. 两种指定方式均可.
dependencies: 
  - name: "the"  # 依赖的插件名
    version: null # 依赖的版本号, 支持 Apache Ivy 格式. 为 null 或不指定时不限制版本
    isOptional: true # `true` 表示插件在找不到此依赖时也能正常加载
  - "SamplePlugin" # 名称为 SamplePlugin 的插件, 不限制版本, isOptional=false
  - "TestPlugin:1.0.0+" # 名称为 ExamplePlugin 的插件, 版本至少为 1.0.0, isOptional=false
  - "ExamplePlugin:1.5.0+?" # 名称为 ExamplePlugin 的插件, 版本至少为 1.5.0, 末尾 `?` 表示 isOptional=true 
  - "Another test plugin:[1.0.0, 2.0.0)" # 名称为 Another test plugin 的插件, 版本要求大于等于 1.0.0, 小于 2.0.0, isOptional=false 

实现 Kotlin 插件

在完成上述 plugin.yml 之后, 创建 main 中指定的插件主类, 继承 KotlinPlugin

实现 Java 插件