koishi-plugin-bilibili-notify 3.2.5-alpha.9 → 3.2.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/index.d.mts +1 -0
- package/lib/index.d.ts +1 -0
- package/lib/index.js +36 -23
- package/lib/index.mjs +36 -23
- package/package.json +2 -2
- package/readme.md +6 -0
package/lib/index.d.mts
CHANGED
package/lib/index.d.ts
CHANGED
package/lib/index.js
CHANGED
|
@@ -552,7 +552,7 @@ var ComRegister = class {
|
|
|
552
552
|
subManager = [];
|
|
553
553
|
dynamicTimelineManager = /* @__PURE__ */ new Map();
|
|
554
554
|
liveStatusManager = /* @__PURE__ */ new Map();
|
|
555
|
-
|
|
555
|
+
pushArrMap = /* @__PURE__ */ new Map();
|
|
556
556
|
loginDBData;
|
|
557
557
|
privateBot;
|
|
558
558
|
dynamicJob;
|
|
@@ -797,7 +797,6 @@ var ComRegister = class {
|
|
|
797
797
|
});
|
|
798
798
|
}
|
|
799
799
|
initPushRecord(subs) {
|
|
800
|
-
const pushRecord = {};
|
|
801
800
|
for (const sub of subs) {
|
|
802
801
|
const atAllArr = [];
|
|
803
802
|
const dynamicArr = [];
|
|
@@ -809,16 +808,15 @@ var ComRegister = class {
|
|
|
809
808
|
if (channel.live) liveArr.push(`${platform.platform}:${channel.channelId}`);
|
|
810
809
|
if (channel.liveGuardBuy) liveGuardBuyArr.push(`${platform.platform}:${channel.channelId}`);
|
|
811
810
|
}
|
|
812
|
-
|
|
811
|
+
this.pushArrMap.set(sub.uid, {
|
|
813
812
|
atAllArr,
|
|
814
813
|
dynamicArr,
|
|
815
814
|
liveArr,
|
|
816
815
|
liveGuardBuyArr
|
|
817
|
-
};
|
|
816
|
+
});
|
|
818
817
|
}
|
|
819
|
-
this.pushRecord = pushRecord;
|
|
820
818
|
this.logger.info("初始化推送群组/频道信息:");
|
|
821
|
-
this.logger.info(this.
|
|
819
|
+
this.logger.info(this.pushArrMap);
|
|
822
820
|
}
|
|
823
821
|
checkAllBotsAreReady() {
|
|
824
822
|
return !this.ctx.bots.some((bot) => bot.status !== koishi.Universal.Status.ONLINE);
|
|
@@ -832,33 +830,37 @@ var ComRegister = class {
|
|
|
832
830
|
return;
|
|
833
831
|
}
|
|
834
832
|
this.logger.info(`本次推送对象:${uid},推送类型:${PushTypeMsg[type]}`);
|
|
835
|
-
const record = this.
|
|
833
|
+
const record = this.pushArrMap.get(uid);
|
|
836
834
|
this.logger.info("本次推送目标:");
|
|
837
835
|
if (type === PushType.StartBroadcasting && record.atAllArr?.length >= 1) {
|
|
838
836
|
this.logger.info(record.atAllArr);
|
|
837
|
+
const atAllArr = structuredClone(record.atAllArr);
|
|
839
838
|
const success = await withRetry(async () => {
|
|
840
|
-
return await this.ctx.broadcast(
|
|
839
|
+
return await this.ctx.broadcast(atAllArr, /* @__PURE__ */ (0, __satorijs_element_jsx_runtime.jsx)("message", { children: /* @__PURE__ */ (0, __satorijs_element_jsx_runtime.jsx)("at", { type: "all" }) }));
|
|
841
840
|
}, 1);
|
|
842
841
|
this.logger.info(`成功推送全体成员消息群组/频道:${success}`);
|
|
843
842
|
}
|
|
844
843
|
if (type === PushType.Dynamic && record.dynamicArr?.length >= 1) {
|
|
845
844
|
this.logger.info(record.dynamicArr);
|
|
845
|
+
const dynamicArr = structuredClone(record.dynamicArr);
|
|
846
846
|
const success = await withRetry(async () => {
|
|
847
|
-
return await this.ctx.broadcast(
|
|
847
|
+
return await this.ctx.broadcast(dynamicArr, /* @__PURE__ */ (0, __satorijs_element_jsx_runtime.jsx)("message", { children: content }));
|
|
848
848
|
}, 1);
|
|
849
849
|
this.logger.info(`成功推送动态消息群组/频道:${success}`);
|
|
850
850
|
}
|
|
851
851
|
if ((type === PushType.Live || type === PushType.StartBroadcasting) && record.liveArr?.length >= 1) {
|
|
852
852
|
this.logger.info(record.liveArr);
|
|
853
|
+
const liveArr = structuredClone(record.liveArr);
|
|
853
854
|
const success = await withRetry(async () => {
|
|
854
|
-
return await this.ctx.broadcast(
|
|
855
|
+
return await this.ctx.broadcast(liveArr, /* @__PURE__ */ (0, __satorijs_element_jsx_runtime.jsx)("message", { children: content }));
|
|
855
856
|
}, 1);
|
|
856
857
|
this.logger.info(`成功推送直播消息群组/频道:${success}`);
|
|
857
858
|
}
|
|
858
859
|
if (type === PushType.LiveGuardBuy && record.liveGuardBuyArr?.length >= 1) {
|
|
859
860
|
this.logger.info(record.liveGuardBuyArr);
|
|
861
|
+
const liveGuardBuyArr = structuredClone(record.liveGuardBuyArr);
|
|
860
862
|
const success = await withRetry(async () => {
|
|
861
|
-
return await this.ctx.broadcast(
|
|
863
|
+
return await this.ctx.broadcast(liveGuardBuyArr, /* @__PURE__ */ (0, __satorijs_element_jsx_runtime.jsx)("message", { children: content }));
|
|
862
864
|
}, 1);
|
|
863
865
|
this.logger.info(`成功推送上舰消息群组/频道:${success}`);
|
|
864
866
|
}
|
|
@@ -912,15 +914,15 @@ var ComRegister = class {
|
|
|
912
914
|
}, 1).catch(async (e$1) => {
|
|
913
915
|
if (e$1.message === "直播开播动态,不做处理") return;
|
|
914
916
|
if (e$1.message === "出现关键词,屏蔽该动态") {
|
|
915
|
-
if (this.config.filter.notify) await this.broadcastToTargets(sub.uid,
|
|
917
|
+
if (this.config.filter.notify) await this.broadcastToTargets(sub.uid, /* @__PURE__ */ (0, __satorijs_element_jsx_runtime.jsxs)("message", { children: [name$3, "发布了一条含有屏蔽关键字的动态"] }), PushType.Dynamic);
|
|
916
918
|
return;
|
|
917
919
|
}
|
|
918
920
|
if (e$1.message === "已屏蔽转发动态") {
|
|
919
|
-
if (this.config.filter.notify) await this.broadcastToTargets(sub.uid,
|
|
921
|
+
if (this.config.filter.notify) await this.broadcastToTargets(sub.uid, /* @__PURE__ */ (0, __satorijs_element_jsx_runtime.jsxs)("message", { children: [name$3, "转发了一条动态,已屏蔽"] }), PushType.Dynamic);
|
|
920
922
|
return;
|
|
921
923
|
}
|
|
922
924
|
if (e$1.message === "已屏蔽专栏动态") {
|
|
923
|
-
if (this.config.filter.notify) await this.broadcastToTargets(sub.uid,
|
|
925
|
+
if (this.config.filter.notify) await this.broadcastToTargets(sub.uid, /* @__PURE__ */ (0, __satorijs_element_jsx_runtime.jsxs)("message", { children: [name$3, "投稿了一条专栏,已屏蔽"] }), PushType.Dynamic);
|
|
924
926
|
return;
|
|
925
927
|
}
|
|
926
928
|
this.logger.error(`dynamicDetect generateDynamicImg() 推送卡片发送失败,原因:${e$1.message}`);
|
|
@@ -934,7 +936,7 @@ var ComRegister = class {
|
|
|
934
936
|
} else dUrl = `${name$3}发布了新视频:https:${item.modules.module_dynamic.major.archive.jump_url}`;
|
|
935
937
|
else dUrl = `${name$3}发布了一条动态:https://t.bilibili.com/${item.id_str}`;
|
|
936
938
|
this.logger.info("推送动态中...");
|
|
937
|
-
await this.broadcastToTargets(sub.uid, /* @__PURE__ */ (0, __satorijs_element_jsx_runtime.jsxs)(
|
|
939
|
+
await this.broadcastToTargets(sub.uid, /* @__PURE__ */ (0, __satorijs_element_jsx_runtime.jsxs)("message", { children: [koishi.h.image(buffer, "image/jpeg"), dUrl] }), PushType.Dynamic);
|
|
938
940
|
if (this.config.pushImgsInDynamic) {
|
|
939
941
|
if (item.type === "DYNAMIC_TYPE_DRAW") {
|
|
940
942
|
const pics = item.modules?.module_dynamic?.major?.opus?.pics;
|
|
@@ -1017,15 +1019,15 @@ var ComRegister = class {
|
|
|
1017
1019
|
}, 1).catch(async (e$1) => {
|
|
1018
1020
|
if (e$1.message === "直播开播动态,不做处理") return;
|
|
1019
1021
|
if (e$1.message === "出现关键词,屏蔽该动态") {
|
|
1020
|
-
if (this.config.filter.notify) await this.broadcastToTargets(sub.uid,
|
|
1022
|
+
if (this.config.filter.notify) await this.broadcastToTargets(sub.uid, /* @__PURE__ */ (0, __satorijs_element_jsx_runtime.jsxs)("message", { children: [name$3, "发布了一条含有屏蔽关键字的动态"] }), PushType.Dynamic);
|
|
1021
1023
|
return;
|
|
1022
1024
|
}
|
|
1023
1025
|
if (e$1.message === "已屏蔽转发动态") {
|
|
1024
|
-
if (this.config.filter.notify) await this.broadcastToTargets(sub.uid,
|
|
1026
|
+
if (this.config.filter.notify) await this.broadcastToTargets(sub.uid, /* @__PURE__ */ (0, __satorijs_element_jsx_runtime.jsxs)("message", { children: [name$3, "转发了一条动态,已屏蔽"] }), PushType.Dynamic);
|
|
1025
1027
|
return;
|
|
1026
1028
|
}
|
|
1027
1029
|
if (e$1.message === "已屏蔽专栏动态") {
|
|
1028
|
-
if (this.config.filter.notify) await this.broadcastToTargets(sub.uid,
|
|
1030
|
+
if (this.config.filter.notify) await this.broadcastToTargets(sub.uid, /* @__PURE__ */ (0, __satorijs_element_jsx_runtime.jsxs)("message", { children: [name$3, "投稿了一条专栏,已屏蔽"] }), PushType.Dynamic);
|
|
1029
1031
|
return;
|
|
1030
1032
|
}
|
|
1031
1033
|
this.logger.error(`dynamicDetect generateDynamicImg() 推送卡片发送失败,原因:${e$1.message}`);
|
|
@@ -1044,7 +1046,7 @@ var ComRegister = class {
|
|
|
1044
1046
|
this.logger.info("动态链接生成成功!");
|
|
1045
1047
|
}
|
|
1046
1048
|
this.logger.info("推送动态中...");
|
|
1047
|
-
await this.broadcastToTargets(sub.uid, /* @__PURE__ */ (0, __satorijs_element_jsx_runtime.jsxs)(
|
|
1049
|
+
await this.broadcastToTargets(sub.uid, /* @__PURE__ */ (0, __satorijs_element_jsx_runtime.jsxs)("message", { children: [koishi.h.image(buffer, "image/jpeg"), dUrl] }), PushType.Dynamic);
|
|
1048
1050
|
if (this.config.pushImgsInDynamic) {
|
|
1049
1051
|
this.logger.info("需要发送动态中的图片,开始发送...");
|
|
1050
1052
|
if (item.type === "DYNAMIC_TYPE_DRAW") {
|
|
@@ -1116,7 +1118,7 @@ var ComRegister = class {
|
|
|
1116
1118
|
this.logger.error(`liveDetect generateLiveImg() 推送卡片生成失败,原因:${e$1.message}`);
|
|
1117
1119
|
});
|
|
1118
1120
|
if (!buffer) return await this.sendPrivateMsgAndStopService();
|
|
1119
|
-
const msg = /* @__PURE__ */ (0, __satorijs_element_jsx_runtime.jsxs)(
|
|
1121
|
+
const msg = /* @__PURE__ */ (0, __satorijs_element_jsx_runtime.jsxs)("message", { children: [koishi.h.image(buffer, "image/jpeg"), liveNotifyMsg || ""] });
|
|
1120
1122
|
return await this.broadcastToTargets(uid, msg, liveType === LiveType.StartBroadcasting ? PushType.StartBroadcasting : PushType.Live);
|
|
1121
1123
|
}
|
|
1122
1124
|
async liveDetectWithListener(roomId, uid, cardStyle) {
|
|
@@ -1181,7 +1183,15 @@ var ComRegister = class {
|
|
|
1181
1183
|
watchedNum = body.text_small;
|
|
1182
1184
|
},
|
|
1183
1185
|
onGuardBuy: ({ body }) => {
|
|
1184
|
-
const content =
|
|
1186
|
+
const content = /* @__PURE__ */ (0, __satorijs_element_jsx_runtime.jsxs)("message", { children: [
|
|
1187
|
+
"【",
|
|
1188
|
+
masterInfo.username,
|
|
1189
|
+
"的直播间】",
|
|
1190
|
+
body.user.uname,
|
|
1191
|
+
"加入了大航海(",
|
|
1192
|
+
body.gift_name,
|
|
1193
|
+
")"
|
|
1194
|
+
] });
|
|
1185
1195
|
this.broadcastToTargets(uid, content, PushType.LiveGuardBuy);
|
|
1186
1196
|
},
|
|
1187
1197
|
onLiveStart: async () => {
|
|
@@ -1584,7 +1594,7 @@ var ComRegister = class {
|
|
|
1584
1594
|
}
|
|
1585
1595
|
}
|
|
1586
1596
|
enableDynamicDetect() {
|
|
1587
|
-
this.dynamicJob = new cron.CronJob(
|
|
1597
|
+
this.dynamicJob = new cron.CronJob(this.config.dynamicCron, this.config.dynamicDebugMode ? this.debug_dynamicDetect() : this.dynamicDetect());
|
|
1588
1598
|
this.logger.info("动态监测已开启");
|
|
1589
1599
|
this.dynamicJob.start();
|
|
1590
1600
|
}
|
|
@@ -1640,6 +1650,7 @@ var ComRegister = class {
|
|
|
1640
1650
|
customLive: koishi.Schema.string(),
|
|
1641
1651
|
customLiveEnd: koishi.Schema.string().required(),
|
|
1642
1652
|
dynamicUrl: koishi.Schema.boolean().required(),
|
|
1653
|
+
dynamicCron: koishi.Schema.string().required(),
|
|
1643
1654
|
dynamicVideoUrlToBV: koishi.Schema.boolean().required(),
|
|
1644
1655
|
filter: koishi.Schema.object({
|
|
1645
1656
|
enable: koishi.Schema.boolean(),
|
|
@@ -58056,7 +58067,7 @@ var require_helpers$1 = __commonJS$1({ "node_modules/socks/build/common/helpers.
|
|
|
58056
58067
|
}
|
|
58057
58068
|
function ipv4ToInt32(ip) {
|
|
58058
58069
|
const address = new ip_address_1$1.Address4(ip);
|
|
58059
|
-
return address.toArray().reduce((acc, part) => (acc << 8) + part, 0);
|
|
58070
|
+
return address.toArray().reduce((acc, part) => (acc << 8) + part, 0) >>> 0;
|
|
58060
58071
|
}
|
|
58061
58072
|
exports.ipv4ToInt32 = ipv4ToInt32;
|
|
58062
58073
|
function int32ToIpv4(int32) {
|
|
@@ -95031,6 +95042,7 @@ var ServerManager = class extends koishi.Service {
|
|
|
95031
95042
|
customLive: globalConfig.customLive,
|
|
95032
95043
|
customLiveEnd: globalConfig.customLiveEnd,
|
|
95033
95044
|
dynamicUrl: globalConfig.dynamicUrl,
|
|
95045
|
+
dynamicCron: globalConfig.dynamicCron,
|
|
95034
95046
|
dynamicVideoUrlToBV: globalConfig.dynamicVideoUrlToBV,
|
|
95035
95047
|
filter: globalConfig.filter,
|
|
95036
95048
|
dynamicDebugMode: globalConfig.dynamicDebugMode
|
|
@@ -95128,6 +95140,7 @@ const Config = koishi.Schema.object({
|
|
|
95128
95140
|
}).collapse()).collapse().description("输入订阅信息,自定义订阅内容; uid: 订阅用户UID,dynamic: 是否需要订阅动态,live: 是否需要订阅直播"),
|
|
95129
95141
|
dynamic: koishi.Schema.object({}).description("动态推送设置"),
|
|
95130
95142
|
dynamicUrl: koishi.Schema.boolean().default(false).description("发送动态时是否同时发送链接。注意:如果使用的是QQ官方机器人不能开启此项!"),
|
|
95143
|
+
dynamicCron: koishi.Schema.string().default("*/2 * * * *").description("动态监测时间,请填入cron表达式,请勿填入过短时间"),
|
|
95131
95144
|
dynamicVideoUrlToBV: koishi.Schema.boolean().default(false).description("如果推送的动态是视频动态,且开启了发送链接选项,开启此选项则会将链接转换为BV号以便其他用途"),
|
|
95132
95145
|
pushImgsInDynamic: koishi.Schema.boolean().default(false).description("是否推送动态中的图片,默认不开启。开启后会单独推送动态中的图片,该功能容易导致QQ风控"),
|
|
95133
95146
|
live: koishi.Schema.object({}).description("直播推送设置"),
|
package/lib/index.mjs
CHANGED
|
@@ -554,7 +554,7 @@ var ComRegister = class {
|
|
|
554
554
|
subManager = [];
|
|
555
555
|
dynamicTimelineManager = /* @__PURE__ */ new Map();
|
|
556
556
|
liveStatusManager = /* @__PURE__ */ new Map();
|
|
557
|
-
|
|
557
|
+
pushArrMap = /* @__PURE__ */ new Map();
|
|
558
558
|
loginDBData;
|
|
559
559
|
privateBot;
|
|
560
560
|
dynamicJob;
|
|
@@ -799,7 +799,6 @@ var ComRegister = class {
|
|
|
799
799
|
});
|
|
800
800
|
}
|
|
801
801
|
initPushRecord(subs) {
|
|
802
|
-
const pushRecord = {};
|
|
803
802
|
for (const sub of subs) {
|
|
804
803
|
const atAllArr = [];
|
|
805
804
|
const dynamicArr = [];
|
|
@@ -811,16 +810,15 @@ var ComRegister = class {
|
|
|
811
810
|
if (channel.live) liveArr.push(`${platform.platform}:${channel.channelId}`);
|
|
812
811
|
if (channel.liveGuardBuy) liveGuardBuyArr.push(`${platform.platform}:${channel.channelId}`);
|
|
813
812
|
}
|
|
814
|
-
|
|
813
|
+
this.pushArrMap.set(sub.uid, {
|
|
815
814
|
atAllArr,
|
|
816
815
|
dynamicArr,
|
|
817
816
|
liveArr,
|
|
818
817
|
liveGuardBuyArr
|
|
819
|
-
};
|
|
818
|
+
});
|
|
820
819
|
}
|
|
821
|
-
this.pushRecord = pushRecord;
|
|
822
820
|
this.logger.info("初始化推送群组/频道信息:");
|
|
823
|
-
this.logger.info(this.
|
|
821
|
+
this.logger.info(this.pushArrMap);
|
|
824
822
|
}
|
|
825
823
|
checkAllBotsAreReady() {
|
|
826
824
|
return !this.ctx.bots.some((bot) => bot.status !== Universal.Status.ONLINE);
|
|
@@ -834,33 +832,37 @@ var ComRegister = class {
|
|
|
834
832
|
return;
|
|
835
833
|
}
|
|
836
834
|
this.logger.info(`本次推送对象:${uid},推送类型:${PushTypeMsg[type]}`);
|
|
837
|
-
const record = this.
|
|
835
|
+
const record = this.pushArrMap.get(uid);
|
|
838
836
|
this.logger.info("本次推送目标:");
|
|
839
837
|
if (type === PushType.StartBroadcasting && record.atAllArr?.length >= 1) {
|
|
840
838
|
this.logger.info(record.atAllArr);
|
|
839
|
+
const atAllArr = structuredClone(record.atAllArr);
|
|
841
840
|
const success = await withRetry(async () => {
|
|
842
|
-
return await this.ctx.broadcast(
|
|
841
|
+
return await this.ctx.broadcast(atAllArr, /* @__PURE__ */ jsx("message", { children: /* @__PURE__ */ jsx("at", { type: "all" }) }));
|
|
843
842
|
}, 1);
|
|
844
843
|
this.logger.info(`成功推送全体成员消息群组/频道:${success}`);
|
|
845
844
|
}
|
|
846
845
|
if (type === PushType.Dynamic && record.dynamicArr?.length >= 1) {
|
|
847
846
|
this.logger.info(record.dynamicArr);
|
|
847
|
+
const dynamicArr = structuredClone(record.dynamicArr);
|
|
848
848
|
const success = await withRetry(async () => {
|
|
849
|
-
return await this.ctx.broadcast(
|
|
849
|
+
return await this.ctx.broadcast(dynamicArr, /* @__PURE__ */ jsx("message", { children: content }));
|
|
850
850
|
}, 1);
|
|
851
851
|
this.logger.info(`成功推送动态消息群组/频道:${success}`);
|
|
852
852
|
}
|
|
853
853
|
if ((type === PushType.Live || type === PushType.StartBroadcasting) && record.liveArr?.length >= 1) {
|
|
854
854
|
this.logger.info(record.liveArr);
|
|
855
|
+
const liveArr = structuredClone(record.liveArr);
|
|
855
856
|
const success = await withRetry(async () => {
|
|
856
|
-
return await this.ctx.broadcast(
|
|
857
|
+
return await this.ctx.broadcast(liveArr, /* @__PURE__ */ jsx("message", { children: content }));
|
|
857
858
|
}, 1);
|
|
858
859
|
this.logger.info(`成功推送直播消息群组/频道:${success}`);
|
|
859
860
|
}
|
|
860
861
|
if (type === PushType.LiveGuardBuy && record.liveGuardBuyArr?.length >= 1) {
|
|
861
862
|
this.logger.info(record.liveGuardBuyArr);
|
|
863
|
+
const liveGuardBuyArr = structuredClone(record.liveGuardBuyArr);
|
|
862
864
|
const success = await withRetry(async () => {
|
|
863
|
-
return await this.ctx.broadcast(
|
|
865
|
+
return await this.ctx.broadcast(liveGuardBuyArr, /* @__PURE__ */ jsx("message", { children: content }));
|
|
864
866
|
}, 1);
|
|
865
867
|
this.logger.info(`成功推送上舰消息群组/频道:${success}`);
|
|
866
868
|
}
|
|
@@ -914,15 +916,15 @@ var ComRegister = class {
|
|
|
914
916
|
}, 1).catch(async (e$1) => {
|
|
915
917
|
if (e$1.message === "直播开播动态,不做处理") return;
|
|
916
918
|
if (e$1.message === "出现关键词,屏蔽该动态") {
|
|
917
|
-
if (this.config.filter.notify) await this.broadcastToTargets(sub.uid,
|
|
919
|
+
if (this.config.filter.notify) await this.broadcastToTargets(sub.uid, /* @__PURE__ */ jsxs("message", { children: [name$3, "发布了一条含有屏蔽关键字的动态"] }), PushType.Dynamic);
|
|
918
920
|
return;
|
|
919
921
|
}
|
|
920
922
|
if (e$1.message === "已屏蔽转发动态") {
|
|
921
|
-
if (this.config.filter.notify) await this.broadcastToTargets(sub.uid,
|
|
923
|
+
if (this.config.filter.notify) await this.broadcastToTargets(sub.uid, /* @__PURE__ */ jsxs("message", { children: [name$3, "转发了一条动态,已屏蔽"] }), PushType.Dynamic);
|
|
922
924
|
return;
|
|
923
925
|
}
|
|
924
926
|
if (e$1.message === "已屏蔽专栏动态") {
|
|
925
|
-
if (this.config.filter.notify) await this.broadcastToTargets(sub.uid,
|
|
927
|
+
if (this.config.filter.notify) await this.broadcastToTargets(sub.uid, /* @__PURE__ */ jsxs("message", { children: [name$3, "投稿了一条专栏,已屏蔽"] }), PushType.Dynamic);
|
|
926
928
|
return;
|
|
927
929
|
}
|
|
928
930
|
this.logger.error(`dynamicDetect generateDynamicImg() 推送卡片发送失败,原因:${e$1.message}`);
|
|
@@ -936,7 +938,7 @@ var ComRegister = class {
|
|
|
936
938
|
} else dUrl = `${name$3}发布了新视频:https:${item.modules.module_dynamic.major.archive.jump_url}`;
|
|
937
939
|
else dUrl = `${name$3}发布了一条动态:https://t.bilibili.com/${item.id_str}`;
|
|
938
940
|
this.logger.info("推送动态中...");
|
|
939
|
-
await this.broadcastToTargets(sub.uid, /* @__PURE__ */ jsxs(
|
|
941
|
+
await this.broadcastToTargets(sub.uid, /* @__PURE__ */ jsxs("message", { children: [h.image(buffer, "image/jpeg"), dUrl] }), PushType.Dynamic);
|
|
940
942
|
if (this.config.pushImgsInDynamic) {
|
|
941
943
|
if (item.type === "DYNAMIC_TYPE_DRAW") {
|
|
942
944
|
const pics = item.modules?.module_dynamic?.major?.opus?.pics;
|
|
@@ -1019,15 +1021,15 @@ var ComRegister = class {
|
|
|
1019
1021
|
}, 1).catch(async (e$1) => {
|
|
1020
1022
|
if (e$1.message === "直播开播动态,不做处理") return;
|
|
1021
1023
|
if (e$1.message === "出现关键词,屏蔽该动态") {
|
|
1022
|
-
if (this.config.filter.notify) await this.broadcastToTargets(sub.uid,
|
|
1024
|
+
if (this.config.filter.notify) await this.broadcastToTargets(sub.uid, /* @__PURE__ */ jsxs("message", { children: [name$3, "发布了一条含有屏蔽关键字的动态"] }), PushType.Dynamic);
|
|
1023
1025
|
return;
|
|
1024
1026
|
}
|
|
1025
1027
|
if (e$1.message === "已屏蔽转发动态") {
|
|
1026
|
-
if (this.config.filter.notify) await this.broadcastToTargets(sub.uid,
|
|
1028
|
+
if (this.config.filter.notify) await this.broadcastToTargets(sub.uid, /* @__PURE__ */ jsxs("message", { children: [name$3, "转发了一条动态,已屏蔽"] }), PushType.Dynamic);
|
|
1027
1029
|
return;
|
|
1028
1030
|
}
|
|
1029
1031
|
if (e$1.message === "已屏蔽专栏动态") {
|
|
1030
|
-
if (this.config.filter.notify) await this.broadcastToTargets(sub.uid,
|
|
1032
|
+
if (this.config.filter.notify) await this.broadcastToTargets(sub.uid, /* @__PURE__ */ jsxs("message", { children: [name$3, "投稿了一条专栏,已屏蔽"] }), PushType.Dynamic);
|
|
1031
1033
|
return;
|
|
1032
1034
|
}
|
|
1033
1035
|
this.logger.error(`dynamicDetect generateDynamicImg() 推送卡片发送失败,原因:${e$1.message}`);
|
|
@@ -1046,7 +1048,7 @@ var ComRegister = class {
|
|
|
1046
1048
|
this.logger.info("动态链接生成成功!");
|
|
1047
1049
|
}
|
|
1048
1050
|
this.logger.info("推送动态中...");
|
|
1049
|
-
await this.broadcastToTargets(sub.uid, /* @__PURE__ */ jsxs(
|
|
1051
|
+
await this.broadcastToTargets(sub.uid, /* @__PURE__ */ jsxs("message", { children: [h.image(buffer, "image/jpeg"), dUrl] }), PushType.Dynamic);
|
|
1050
1052
|
if (this.config.pushImgsInDynamic) {
|
|
1051
1053
|
this.logger.info("需要发送动态中的图片,开始发送...");
|
|
1052
1054
|
if (item.type === "DYNAMIC_TYPE_DRAW") {
|
|
@@ -1118,7 +1120,7 @@ var ComRegister = class {
|
|
|
1118
1120
|
this.logger.error(`liveDetect generateLiveImg() 推送卡片生成失败,原因:${e$1.message}`);
|
|
1119
1121
|
});
|
|
1120
1122
|
if (!buffer) return await this.sendPrivateMsgAndStopService();
|
|
1121
|
-
const msg = /* @__PURE__ */ jsxs(
|
|
1123
|
+
const msg = /* @__PURE__ */ jsxs("message", { children: [h.image(buffer, "image/jpeg"), liveNotifyMsg || ""] });
|
|
1122
1124
|
return await this.broadcastToTargets(uid, msg, liveType === LiveType.StartBroadcasting ? PushType.StartBroadcasting : PushType.Live);
|
|
1123
1125
|
}
|
|
1124
1126
|
async liveDetectWithListener(roomId, uid, cardStyle) {
|
|
@@ -1183,7 +1185,15 @@ var ComRegister = class {
|
|
|
1183
1185
|
watchedNum = body.text_small;
|
|
1184
1186
|
},
|
|
1185
1187
|
onGuardBuy: ({ body }) => {
|
|
1186
|
-
const content =
|
|
1188
|
+
const content = /* @__PURE__ */ jsxs("message", { children: [
|
|
1189
|
+
"【",
|
|
1190
|
+
masterInfo.username,
|
|
1191
|
+
"的直播间】",
|
|
1192
|
+
body.user.uname,
|
|
1193
|
+
"加入了大航海(",
|
|
1194
|
+
body.gift_name,
|
|
1195
|
+
")"
|
|
1196
|
+
] });
|
|
1187
1197
|
this.broadcastToTargets(uid, content, PushType.LiveGuardBuy);
|
|
1188
1198
|
},
|
|
1189
1199
|
onLiveStart: async () => {
|
|
@@ -1586,7 +1596,7 @@ var ComRegister = class {
|
|
|
1586
1596
|
}
|
|
1587
1597
|
}
|
|
1588
1598
|
enableDynamicDetect() {
|
|
1589
|
-
this.dynamicJob = new CronJob(
|
|
1599
|
+
this.dynamicJob = new CronJob(this.config.dynamicCron, this.config.dynamicDebugMode ? this.debug_dynamicDetect() : this.dynamicDetect());
|
|
1590
1600
|
this.logger.info("动态监测已开启");
|
|
1591
1601
|
this.dynamicJob.start();
|
|
1592
1602
|
}
|
|
@@ -1642,6 +1652,7 @@ var ComRegister = class {
|
|
|
1642
1652
|
customLive: Schema.string(),
|
|
1643
1653
|
customLiveEnd: Schema.string().required(),
|
|
1644
1654
|
dynamicUrl: Schema.boolean().required(),
|
|
1655
|
+
dynamicCron: Schema.string().required(),
|
|
1645
1656
|
dynamicVideoUrlToBV: Schema.boolean().required(),
|
|
1646
1657
|
filter: Schema.object({
|
|
1647
1658
|
enable: Schema.boolean(),
|
|
@@ -58058,7 +58069,7 @@ var require_helpers$1 = __commonJS$1({ "node_modules/socks/build/common/helpers.
|
|
|
58058
58069
|
}
|
|
58059
58070
|
function ipv4ToInt32(ip) {
|
|
58060
58071
|
const address = new ip_address_1$1.Address4(ip);
|
|
58061
|
-
return address.toArray().reduce((acc, part) => (acc << 8) + part, 0);
|
|
58072
|
+
return address.toArray().reduce((acc, part) => (acc << 8) + part, 0) >>> 0;
|
|
58062
58073
|
}
|
|
58063
58074
|
exports.ipv4ToInt32 = ipv4ToInt32;
|
|
58064
58075
|
function int32ToIpv4(int32) {
|
|
@@ -95033,6 +95044,7 @@ var ServerManager = class extends Service {
|
|
|
95033
95044
|
customLive: globalConfig.customLive,
|
|
95034
95045
|
customLiveEnd: globalConfig.customLiveEnd,
|
|
95035
95046
|
dynamicUrl: globalConfig.dynamicUrl,
|
|
95047
|
+
dynamicCron: globalConfig.dynamicCron,
|
|
95036
95048
|
dynamicVideoUrlToBV: globalConfig.dynamicVideoUrlToBV,
|
|
95037
95049
|
filter: globalConfig.filter,
|
|
95038
95050
|
dynamicDebugMode: globalConfig.dynamicDebugMode
|
|
@@ -95130,6 +95142,7 @@ const Config = Schema.object({
|
|
|
95130
95142
|
}).collapse()).collapse().description("输入订阅信息,自定义订阅内容; uid: 订阅用户UID,dynamic: 是否需要订阅动态,live: 是否需要订阅直播"),
|
|
95131
95143
|
dynamic: Schema.object({}).description("动态推送设置"),
|
|
95132
95144
|
dynamicUrl: Schema.boolean().default(false).description("发送动态时是否同时发送链接。注意:如果使用的是QQ官方机器人不能开启此项!"),
|
|
95145
|
+
dynamicCron: Schema.string().default("*/2 * * * *").description("动态监测时间,请填入cron表达式,请勿填入过短时间"),
|
|
95133
95146
|
dynamicVideoUrlToBV: Schema.boolean().default(false).description("如果推送的动态是视频动态,且开启了发送链接选项,开启此选项则会将链接转换为BV号以便其他用途"),
|
|
95134
95147
|
pushImgsInDynamic: Schema.boolean().default(false).description("是否推送动态中的图片,默认不开启。开启后会单独推送动态中的图片,该功能容易导致QQ风控"),
|
|
95135
95148
|
live: Schema.object({}).description("直播推送设置"),
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "koishi-plugin-bilibili-notify",
|
|
3
3
|
"description": "Koishi bilibili notify plugin",
|
|
4
|
-
"version": "3.2.5
|
|
4
|
+
"version": "3.2.5",
|
|
5
5
|
"contributors": [
|
|
6
6
|
"Akokko <admin@akokko.com>"
|
|
7
7
|
],
|
|
@@ -48,7 +48,7 @@
|
|
|
48
48
|
"tough-cookie": "^5.1.2"
|
|
49
49
|
},
|
|
50
50
|
"devDependencies": {
|
|
51
|
-
"@biomejs/biome": "1.9.4",
|
|
51
|
+
"@biomejs/biome": "^1.9.4",
|
|
52
52
|
"@koishijs/cache": "^2.1.0",
|
|
53
53
|
"@koishijs/client": "^5.30.8",
|
|
54
54
|
"@koishijs/plugin-help": "^2.4.5",
|
package/readme.md
CHANGED
|
@@ -288,6 +288,12 @@ uid为必填参数,为要推送的UP主的UID,index为可选参数,为要
|
|
|
288
288
|
> - ver 3.2.5-alpha.7 测试版本
|
|
289
289
|
> - ver 3.2.5-alpha.8 测试版本
|
|
290
290
|
> - ver 3.2.5-alpha.9 测试版本
|
|
291
|
+
> - ver 3.2.5-alpha.10 测试版本
|
|
292
|
+
> - ver 3.2.5-alpha.11 测试版本
|
|
293
|
+
> - ver 3.2.5-alpha.12 测试版本
|
|
294
|
+
> - ver 3.2.5-alpha.13 测试版本
|
|
295
|
+
|
|
296
|
+
- ver 3.2.5 重构:消息推送逻辑; 新增:选项 `dynamicCron`;
|
|
291
297
|
|
|
292
298
|
## 交流群
|
|
293
299
|
|