const Mirai = require('node-mirai-sdk')
const { default: NodeMiraiArknights } = require('node-mirai-arknights')
const bot = new Mirai({/* ... */});
/**
* 可以传入配置对象或保存了配置对象的 `json` 文件.
* 使用 `presist: true` 会在内部保存和更新配置, 使用后必须用 `arknights.setConfig`
* 修改配置, 否则配置文件可能被覆盖, 使用 `json` 文件时会自动写入配置, 也能在检测到
* 手动修改后自动更新.
* 使用对象配置 `presist` 模式只推荐用于调试, 在调试好后应该改用 `json` 文件.
*/
// const arknight = NodeMiraiArknights('/path/to/your/config.json')
const arknights = NodeMiraiArknights({
presist: true, // 由 NodeMiraiArknights 保存配置
sync: {
enable: true, // 允许自动更新数据库
},
group: {
whiteList: [ // 为 `false` 禁用白名单模式
1234, // 白名单群号
],
blackList: false, // 禁用黑名单, 为数组时启用黑名单模式
},
atBot: false, // 是否仅响应 at 机器人的指令
prefix: '#', // 指令前缀
logMessage: true, // 是否在控制台打印聊天记录
masters: [ // 超级管理员列表
1234,
],
manage: {
updater: { // 通过在聊天中发送指令更新
enable: true,
group: true, // 允许在群聊发送更新
owner: true, // 允许由群主(即使不是超级管理员)发送更新指令
},
},
gacha: { // 模拟十连配置
enable: true,
cooldown: 60_000, // 每个人的抽卡间隔, 单位毫秒
recall: true, // 是否撤回结果以防刷屏
recallTime: 30_000, // 撤回延迟
},
});
// 应用插件
bot.use(arknights.plugin);
// 在运行时修改配置
arknights.setConfig({/* ... */});
// 自定义组件
const { Component, addCustomComponent, removeCustomComponent } = require('node-mirai-arknights');
const myComponent = new Component(
'myComponent', // 组件名
[{ // 功能
rules: [ // 匹配规则, 任一匹配即生效
/测试/, // 可以是正则
({ msg }) => msg.includes('试测'), // 或返回 boolean 的函数
],
command: true, // 可选, 匹配正则前移除指令前缀
handler ({ msg, reply }) { // 成功匹配时调用
reply('你发送了:', msg);
},
}, {
// ... 其他功能
}],
true, // 可选, 成功匹配时是否跳过其他组件, 为 true 时跳过
);
// 添加组件
addCustomComponent(myComponent);
// 移除组件
removeCustomComponent(myComponent);
bot.listen('all')