项目地址:https://github.com/MrXiaoM/CommandYouWant
「你想要的插件」系列作品
重定向命令,统一机器人命令格式。
经济系统支持灵感来源于 Minecraft 服务端插件 OhMyCmd
本插件支持使用经济系统(可选) Mirai Economy Core,
如有需要使用金钱功能,请自行安装。若不需要金钱功能可不安装,不影响使用。
各大插件作者对于机器人命令的命名方式各不相同,
同时,有的插件年久失修,且没有提供命令修改方法。
这时,CommandYouWant 派上了用场,你可以逐一部署
各个命令的别名,将这个命令的参数任意映射到另一个命令上。
到 Releases 下载插件并放入 plugins 文件夹进行安装
使用方法和示例保证你的 mirai 版本大于或等于 2.11.0
下载 CommandYouWant-*.mirai2.jar
安装完毕后,编辑配置文件作出你想要的修改。在控制台执行 /cmduw reload 重载配置即可~
以调用 cssxsh 大佬的 NovelAi Helper 为例,先到文件夹 config/top.mrxiaom.commandyouwant/commands,第一次启动这个插件会创建这个文件夹并把示例配置 sample.yml 放进去。首先把 sample.yml 复制一份,取任意名放在同一文件夹中。然后打开编辑:
# 是否使用事件模式 # 有些插件并不是标准地注册命令,故需要伪造发送消息事件让插件响应 # 警告: 这可能会干扰聊天记录类的插件 event-mode: false perm: test perm-desc: 获取图片 deny-tips: '权限不足' keyword: '{at:bot}画画 {next}' # 参数屏蔽词 keyword-block: # 第二个参数 {next} 中禁止出现的字符列表 1: - '#' keyword-block-tips: 你输入的参数不合规 actions: - 'cmd:/nai {1}' - 'send:可以像这样一次执行多条指令' # false 的时候忽略执行以上两条命令的权限检查 is-action-check-perm: false # 执行命令所需金钱的货币类型 # 留空为不花费金钱 # 该功能需要安装 mirai-economy-core 插件生效 cost-money-currency: mirai-coin #执行命令所需金钱 cost-money: 10.0 # 是否从全局上下文扣除金钱 # 若关闭该项,将在用户执行命令所在群的上下文扣除金钱 # 私聊执行命令将强制使用全局上下文 cost-money-global: false # 执行命令金钱不足提醒 # $at 为 @ 发送者,$quote 为回复发送者,$cost 为需要花费的金钱 cost-money-not-enough: "$quote你没有足够的 Mirai 币 ($cost) 来执行该命令!"首先我们设置权限,比如将 perm 设为 test,填写后用户需要有权限 top.mrxiaom.commandyouwant:command.test 才能执行这个命令。
然后,我们需要定义用户要怎样才能触发这个命令,将格式写到 keyword 里
在 keyword 中插入 {} 包围的内容作为命令参数,如图中的例子,有两个参数 {at:bot} 和 {next} (都能填什么参数可以在后面的表格看到),用户需要发「@机器人 画画 初音未来 可爱(任意字符都行)」,插件就会把其中的参数提取出来,按顺序排好,这里的参数是
索引 内容 0 @机器人 1 "初音未来 可爱(任意字符都行)"然后,插件会将这些参数替换掉 actions 里的 {索引} 然后模拟用户执行命令。
说白了,就是给其他插件的命令套壳。
写要执行的命令到 actions 之前,需要添加前缀。不添加前缀将默认以 cmd: 方式执行。
在 actions 中,你可以使用这些基础变量,如有需要其他变量,欢迎 PR。
变量(不区分大小写) 说明 {at} @发送命令的人,好友消息时将为空白 {quote} 回复消息 {botId} 机器人QQ号 {groupId} 群号,好友消息时将为空白 {friendId} 好友QQ号,群消息时将为空白 {senderId} 命令发送者QQ号 {subjectId} 好友消息时为QQ号,群消息时为群号如果无法通过索引补充参数到要模拟执行的命令里,将会在后台报错。如果你有特别需求忽略这个错误,请在后面再加个 ?,如 {0}?
在完成了命令的基础设置后,你可以更改一些进阶设置,注释在默认配置文件里都有。
keyword/keywords 所有可用的参数如下
内容 解释 {arg} 单个文字参数,识别到空格就终止 {next} 长段文字参数,识别到其他类型的消息元素或消息末尾就终止 {at} @某人,@所有人都可以 {at:QQ号} @某人,只能@特定某个人 {at:bot} @机器人 {img} 图片 {face} 表情希望你能看懂这份教程。
捐助前往 爱发电 捐助我。
...来自群组: SkyNet1748