B 站直播订阅。在主播上下播时进行提醒。
开发者信息
Original plugin by Dragon-Fish 824399619@qq.com
Original repository: https://github.com/koishijs/koishi-plugin-blive
Refactored by i'DLisT me@idl.ist (https://idl.ist/)
通过网页控制台安装此插件,或通过命令行:
npm i koishi-plugin-blive
然后在配置文件或入口文件中将插件添加至你的机器人中。
使用 -help blive
可以在 bot 内查看帮助。
这个插件有 使用数据库 与 不使用数据库 两种模式,默认使用数据库。
id
: 房间号
需要 2 级权限。
新增订阅。仅在使用数据库时可用。
id
: 房间号
需要 2 级权限。
移除订阅。仅在使用数据库时可用。
page
: 列表页码
显示订阅列表。
keyword
: 关键字
搜索主播 / 直播间。
--room
, -r
: 使用房间号进行搜索(默认行为)。此时 keyword
为房间号。
--uid
, -u
: 使用主播 UID 进行搜索。此时 keyword
为 UID。
--name
, -n
: 使用用户名进行搜索。此时 keyword
为用户名关键字,默认将显示前 10 条结果,可使用配置项更改显示条数。
这个插件现在似乎不需要配置就可以使用,并提供了一些可能用得到的配置项。
配置项 | 默认值 | 说明 |
---|---|---|
useDatabase |
true |
是否使用数据库。 *1 |
pollInterval |
60000 | 访问 B 站 API 的时间间隔(单位毫秒)*2 |
showIcon |
true |
在主播上下播时是否同时发送头像。使用搜索指令时不受此选项的影响。 |
pageLimit |
10 | 分页显示群内订阅主播时,每页的最多显示条数。 |
searchPageLimit |
10 | 在使用用户名搜索主播时的最多显示条数。 |
maxSubsPerChannel |
10 | 每个群 / 频道最大订阅数量。仅在使用数据库时有效。 |
subscriptions |
[] |
订阅列表。仅在不使用数据库时有效。*3 |
*1 在没有配置数据库的情况下,即使这个选项设置为 true
也无法启用数据库。
*2 API 捅得地太频繁会被返回 429 (too many requests)。
*3 这个列表为一个数组,每一项遵循以下格式:
interface SubscriptionItem {
platform: string // 用于推送的机器人的平台。QQ 则为 `onebot`。
assignee: string // 用于推送的机器人 ID。
room: string // 主播房间号。
channel: string // 订阅此主播的群号。
guild?: string // 订阅此主播的服务器号。仅 QQ 频道或开黑啦需要此项。
}
例如:
{
platform: 'onebot',
assignee: '114514',
room: '364364',
channel: '12345678',
// 因为不是 QQ 频道所以不填写 guild。
}
在安装了 sharp
、node-canvas
或 skia-canvas
的情况下,这个插件会用其缩小主播头像。优先级为 sharp
> skia-canvas
> node-canvas
> 什么也没有装。
因为并没有多 bot 和对 QQ 频道的测试环境,所以对这些情况的支持可能会有问题。
v1.0 (用于 Koishi v4)
- 删除了多余的
console.log
。 - 修复了一个会导致查询用户时永远显示该主播为开播的 bug。
- 换用 wbi 鉴权接口以维持功能正常。SESSDATA 鉴权似乎不再必要,相关配置项被移除。如果哪天又要了就再加回来罢。
- 新增
package.json
中的koishi
字段。
此插件需要 Koishi 版本至少为 v4.9。如有需要,请使用 v1.3.3。
- 由于
template
API 于 Koishi 4.9 被移除,而新的ctx.i18n
对主动推送的支持难度较高,因此字符串自定义功能被放弃。如果有此类需求请考虑 Fork 或提出对ctx.i18n
进行支持的 Pull Request。 - 重载逻辑使用的事件从
service
变更为internal/service
,以及ctx.bots.get()
变更为ctx.bots[]
。
此版本没有上传到 npm,如需要使用请直接下载源码
- [Breaking] 由于三相之力指示器事件,B 站对部分接口增加了 Cookie(SESSDATA)鉴权,导致此插件必须取得此内容才能正常工作。对应的配置项为
sessdata
。
- 尝试移除 axios 而改用内置的 ctx.http。
- 尝试修复了更新 Koishi 4.7 之后报检测到重复插件的错误。现在不报了,但是重载逻辑不一定对,希望是对的。
- 尝试增加对 QQ 频道的支持。
- [Breaking] 修改了无数据库模式的格式,对于网页控制台更加友好了。考虑到其实并没有什么人使用无数据库模式,就不升大版本号了。
- 修复了
Ctrl + F
重构结果有几个变量没重命名到,导致多个群关注同一主播时推送不正常的问题。 - 增加了一些
logger.debug
,可能查错会更加方便了(虽然本身JS
插件无需转译,直接源码调试也方便)
- 修复了
console.log
忘了删的问题。
- 新增了自动更新数据库中储存的主播的用户名的功能。
- 修复了使用
sharp
的情况下头像无法被发出的问题。 - 新增配置项
showIcon
,可以设置在开关播时是否同时发送头像了。 - 支持了
Schema
,虽然配置项subscriptions
因为形状太复杂而暂时无法支持。
- 修复了指令注册的机制,现在应该会正常识别有无数据库的情况了。
- 简单地适配了 v4,同时本地模式下
subscriptions
的格式有更改,需要手动指定assignee
(即手动指定由哪个 bot 推送消息)了。
如果需要继续在 v3 使用,请使用 v0.3。