Appearance
Plugin API
请注意
框架仍处于测试阶段, 插件的 API 可能发生较大的更改, 请勿用于生产环境。
Plugin
类的 API 说明如下。
Plugin()插件主类
实例化一个 Plugin
。
函数签名:Plugin(name, version, [conf])
参数说明:
name
:string
类型, 必填, 插件名, 建议英文version
:string
类型, 必填, 插件版本号, 建议英文conf
:PluginConf
类型, 可选, 插件初始化配置
返回值:Plugin
实例
ts
// PluginConf 类型定义
interface PluginConf {
enableGroups?: number[]
enableFriends?: number[]
}
const plugin = new Plugin('demo', '0.1.0')
plugin.name 属性
实例化 Plugin
时传入的插件名, string
类型。
ts
const plugin = new Plugin('demo', '0.1.0')
plugin.onMounted(() => {
plugin.log(plugin.name) // demo
})
plugin.version 属性
实例化 Plugin
时传入的插件版本号, string
类型。
ts
const plugin = new Plugin('demo', '0.1.0')
plugin.onMounted(() => {
plugin.log(plugin.version) // 0.1.0
})
小提示
建议引入 package.json
的版本号作为插件版本以便统一管理, 如:
js
const { version } = require('./package.json')
const plugin = new Plugin('demo', version)
plugin.dataDir 属性
插件数据存放目录, data/plugins/[name]
(绝对路径) 注意这里的 name
是实例化插件的时候传入的 name
, string
类型。
ts
const plugin = new Plugin('demo', '0.1.0')
plugin.onMounted(() => {
plugin.log(plugin.dataDir) // [框架目录]/data/plugins/demo
})
plugin.logger 属性
log4js 的 Logger
实例, 专用来给插件规范化输出调试日志, 可以调用其上的各种不同等级(level
)的调试函数打印日志。详情参考 log4js 官方文档。
ts
const plugin = new Plugin('demo', '0.1.0')
plugin.logger.debug('调试信息')
plugin.logger.info('常规日志')
plugin.logger.warn('警告信息')
plugin.logger.error('错误信息')
plugin.logger.fatal('致命错误')
plugin.bot 属性
movo 的 Client
实例, 可以调用各种 Bot API, 仅在 onMounted
和 onUnmounted
中(即被挂载了之后)才能被访问到, Client
类型。
ts
plugin.onMounted(() => {
plugin.log(plugin.bot.uin) // Bot 的 QQ 账号
})
plugin.admins getter 属性
Bot 管理员列表, number[]
类型。
ts
plugin.onMounted(() => {
plugin.log(plugin.admins) // [1141284758]
})
plugin.mainAdmin getter 属性
小提示
等价于 plugin.admins[0]
Bot 主管理员, number
类型。
ts
plugin.onMounted(() => {
plugin.log(plugin.mainAdmin) // Bot 主管理员
})
plugin.subAdmins getter 属性
小提示
等价于 plugin.admins.slice(1)
Bot 副管理员列表, number[]
类型。
ts
plugin.onMounted(() => {
plugin.log(plugin.subAdmins) // Bot 副管理员列表
})
plugin.onMounted() 方法
插件的生命周期函数, 插件被启用时, 传入的函数会被调用。
函数签名:onMounted(handler)
参数说明:
handler
: 类型(bot: Client, admins: number[]) => void
, 插件被启用的处理函数, 必填, 默认传入 Bot 实例(Client
类)和 Bot 管理员列表。插件主要逻辑请写在此函数体内。
无返回值
ts
const plugin = new Plugin('demo', '0.1.0')
plugin.onMounted((bot, admins) => {
plugin.log('插件被启用了!')
})
plugin.onUnmounted() 方法
插件的生命周期函数, 插件被禁用时, 传入的函数会被调用, 你可以在这里处理插件善后逻辑, 如关闭关闭数据库, 断开相关连接, 停止相关服务, 释放内存等。
函数签名:onUnmounted(handler)
参数说明:
handler
: 类型(bot: Client, admins: number[]) => void
, 插件被禁用的处理函数, 必填, 默认传入 Bot 实例(Client
类)和 Bot 管理员列表。
无返回值
ts
const plugin = new Plugin('demo', '0.1.0')
plugin.onUnmounted((bot, admins) => {
plugin.log('插件被禁用了!')
})
plugin.throwPluginError() 方法
抛出一个 PluginError
标准错误, 会被框架捕获并输出到控制台日志。
函数签名:throwPluginError(message)
参数说明:
message
:string
类型, 必填, 错误信息
无返回值
ts
plugin.onMounted(() => {
plugin.throwPluginError('插件出错了!')
})
plugin.saveConfig() 方法
将数据保存到插件数据目录(传入普通 JS 对象, 储存为 JSON 格式)
函数签名:saveConfig(data, [filepath], [options])
参数说明:
data
: 可转为JSON
的任何合法类型, 一般是普通对象, 必填filepath
:string
类型, 可选, 保存的配置文件路径, 默认为插件数据目录下的config.json
options
:fs.WriteOptions
类型, 可选, 写入配置的选项
返回值:boolean
是否写入成功
ts
plugin.saveConfig({ name: 'keli' }) // 可以在外层保存
plugin.onMounted(() => {
plugin.saveConfig({ name: 'keli' }) // 也可以在内部保存
})
最佳实践
如果你想设置默认配置的同时也支持用户手动配置, 只需在 onMounted
中这加上这行:
js
// 插件的默认配置, 必须是普通对象, 且不包含正则等无法正常转换为 JSON 的内置对象
const config = {}
plugin.onMounted(() => {
// 加载本地配置, 并覆盖默认配置(如果有)
plugin.saveConfig(Object.assign(config, plugin.loadConfig()))
// 插件主要逻辑写在这里
})
它会优先加载
data/plugins/[name]/config.json
) 中的配置
plugin.loadConfig() 方法
从插件数据目录加载保存的数据(储存为 JSON 格式, 读取为普通 JS 对象)
函数签名:loadConfig([filepath], [options])
参数说明:
filepath
:string
类型, 可选, 读取的配置文件路径, 默认为插件数据目录下的config.json
options
:fs.ReadOptions
类型, 可选, 读取配置的选项
返回值:解析后的数据对象
ts
const config = plugin.loadConfig() // 可以在外层读取
plugin.onMounted(() => {
const config = plugin.loadConfig() // 也可以在内部读取
})
最佳实践
如果你想设置默认配置的同时也支持用户手动配置, 只需在 onMounted
中这加上这行:
js
// 插件的默认配置
const config = {}
plugin.onMounted(() => {
// 加载本地配置, 并覆盖默认配置(如果有)
plugin.saveConfig(Object.assign(config, plugin.loadConfig()))
// 插件主要逻辑写在这里
})
它会优先加载
data/plugins/[name]/config.json
) 中的配置
plugin.onMessage() 方法
小提示
等价于 plugin.on('message', handler)
添加消息监听函数, 包括好友私聊、群消息以及讨论组消息, 通过 event.message_type
判断消息类型。如果只需要监听特定的消息类型, 请使用 plugin.on
监听。
函数签名:onMessage(handler)
参数说明:
handler
: 类型(event: AllMessageEvent, bot: Client) => void
, 消息处理函数, 必填, 默认传入消息事件数据(包含群、好友和讨论组消息)
无返回值
ts
plugin.onMounted(() => {
plugin.onMessage(event => {
event.reply('hi, ' + event.sender.user_id)
})
})
plugin.onGroupMessage() 方法
小提示
等价于 plugin.on('message.group', handler)
与 plugin.onMessage()
类似, 只不过只处理群聊消息。
plugin.onPrivateMessage() 方法
小提示
等价于 plugin.on('message.private', handler)
与 plugin.onMessage()
类似, 只不过只处理私聊消息。
plugin.onMatch() 方法
消息匹配函数, 传入字符串或正则, 或字符串和正则的数组, 进行精确匹配, 匹配成功则调用函数。
函数签名:onMatch(matches, handler)
参数说明:
matches
: 字符串或正则或字符串和正则的数组, 必填, 待匹配内容, 对整个消息进行匹配handler
: 类型(event: AllMessageEvent, bot: Client) => void
, 消息处理函数, 必填, 默认传入消息事件数据(包含群、好友和讨论组消息)
无返回值
ts
plugin.onMounted(() => {
plugin.onMatch('hello', (event) => {
event.reply('world')
})
plugin.onMatch(/^hello/i, event => {
event.reply('hi')
})
plugin.onMatch([/morning/i, 'evening'], event => {
event.reply('you too')
})
})
plugin.onGroupMatch() 方法
与 plugin.onMatch
类似, 不同之处在于 onGroupMatch
只会处理群消息。
plugin.onPrivateMatch() 方法
与 plugin.onMatch
类似, 不同之处在于 onPrivateMatch
只会处理私聊消息。
plugin.onAdminMatch() 方法
与 plugin.onMatch
类似, 不同之处在于 onAdminMatch
只会处理所有 Bot 管理员消息。
plugin.onCmd() 方法
添加命令监听函数, 使用 minimist 进行命令、参数和选项的解析.
函数签名:onCmd(cmds, handler)
参数说明:
cmds
: 字符串或正则或字符串和正则的数组, 必填, 待匹配的命令handler
: 类型(event: AllMessageEvent, params: string[], options: { [string]: string }) => void
, 消息处理函数, 必填, 默认传入消息事件数据(包含群、好友和讨论组消息)和 minimist 解析后的参数和选项
无返回值
ts
plugin.onMounted(() => {
// 收到的消息格式应符合: "点歌 稻香 --type qq --n 2"
plugin.onCmd('点歌', (event, params, options) => {
const [songName, ...otherParams] = params
const { n, type } = options
event.reply(`你点的歌是${type}平台的第${n}首${songName}`)
})
plugin.onCmd([/morning/i, 'evening'], (event, params, options) => {
event.reply('you too')
})
})
plugin.onAdminCmd() 方法
与 plugin.onCmd
类似, 不同之处在于 onAdminCmd
只会处理所有 Bot 管理员消息。
plugin.cron() 方法
使用 cron
语法创建定时消息任务, 内部使用 node-cron 实现。使用此方式添加的定时任务会在插件被禁用时自动取消, 无需手动处理。
cron
语法说明参考这里
函数签名:cron(cronExpression, handler)
参数说明:
cronExpression
:string
类型, 必填,cron
表达式handler
: 类型(bot: Client, admins: number[]) => void
, 定时任务函数, 默认传入 Bot 实例(Client
类)和 Bot 管理员列表
返回值: node-cron
的 Task
实例, 可以调用其上的 stop
方法取消定时任务。
ts
plugin.onMounted((bot, admins) => {
// 每 3 秒钟触发
const task = plugin.cron('*/3 * * * * *', () => {
bot.pickFriend(plugin.mainAdmin).sendMsg('cron trigger!')
})
// task.stop()
})
plugin.log() 方法
小提示
等价于 plugin.logger.log()
打印消息到控制台, 可用于插件调试与错误输出等。
plugin.debug() 方法
小提示
等价于 plugin.logger.debug()
同 plugin.log()
, 只不过仅在 debug
及更低的 log level 下可见,可用于插件开发调试,并在正式环境(默认 log level 为 info)下不可见。
plugin.on() 方法
监听 movo
标准事件, 并使用 hander
处理。
函数签名:on(eventName, handler)
不同事件的 handler
的事件回调参数不同, 请参考 movo
标准事件中的对应事件说明。
小提示
plugin.on()
和 plugin.once()
监听的事件不需要在 plugin.onUnmounted()
中手动取消监听, 插件会自动收集监听函数和定时任务等, 在插件被禁用的时候自动将其移除。
请注意
插件不会自动处理 bot
监听的事件, 非特殊需要, 请勿使用 bot.on()
和 bot.once()
等进行事件监听, 否则需要在 plugin.onUnmounted()
中手动取消监听, 不然在插件被禁用后, 无法自动取消这些已监听的事件。
监听“好友申请”事件并自动同意的实例:
js
plugin.onMounted(() => {
plugin.on('request.friend.add', event => {
event.approve(true)
})
})
plugin.off() 方法
取消监听 movo
标准事件。
函数签名:off(eventName, handler)
不同事件的 handler
的事件回调参数不同, 请参考 movo
标准事件中的对应事件说明。
plugin.once() 方法
单次监听 movo
标准事件, 并使用 hander
处理。
函数签名:on(eventName, handler)
不同事件的 handler
的事件回调参数不同, 请参考 movo
标准事件中的对应事件说明。