yz-yuki-plugin 2.0.6-5 → 2.0.6-7

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.
@@ -62,5 +62,9 @@ splitHeight: 8000
62
62
  # 直播动态是否@全体成员,默认 0 关闭,1 开启。开启前请检查 <机器人> 是否有 [管理员权限] 或 [聊天平台是否支持],某些聊天平台或类型不支持@全体成员,如qq官方机器人等。
63
63
  liveAtAll: 0
64
64
 
65
+ # 直播动态@全体成员的群组/聊天/私聊列表,默认为空即不在任何群于推送直播动态中执行@全体成员。开启liveAtAll后才会生效。
66
+ liveAtAllGroupList:
67
+ - 1234567890 # 示例群号
68
+
65
69
  # 直播动态@全体成员的共享冷却时间CD,单位秒,默认 1800 秒(30分钟),即每个群聊30分钟内不论多少条直播动态,只会@一次。注意,qq群有 @全体成员 10次/日 的限制,所以请合理设置。
66
70
  liveAtAllCD: 1800
package/lib/apps/weibo.js CHANGED
@@ -1,8 +1,8 @@
1
1
  import { Messages } from 'yunzaijs';
2
- import { WeiboQuery } from '../models/weibo/weibo.query.js';
3
- import { WeiboTask } from '../models/weibo/weibo.task.js';
2
+ import { WeiboQuery } from '../models/weibo/weibo.main.query.js';
3
+ import { WeiboTask } from '../models/weibo/weibo.main.task.js';
4
4
  import Config from '../utils/config.js';
5
- import { WeiboGetWebData } from '../models/weibo/weibo.get.web.data.js';
5
+ import { WeiboGetWebData } from '../models/weibo/weibo.main.get.web.data.js';
6
6
 
7
7
  const message = new Messages('message');
8
8
  let weiboPushData = Config.getConfigData('config', 'weibo', 'push');
package/lib/index.js CHANGED
@@ -5,7 +5,7 @@ import path from 'path';
5
5
  import { _paths } from './utils/paths.js';
6
6
  import * as index$1 from './apps/index.js';
7
7
  import { BiliTask } from './models/bilibili/bilibili.main.task.js';
8
- import { WeiboTask } from './models/weibo/weibo.task.js';
8
+ import { WeiboTask } from './models/weibo/weibo.main.task.js';
9
9
 
10
10
  const yukiPluginVersion = Config.getPackageJsonKey('version', path.join(_paths.pluginPath, 'package.json'));
11
11
  let biliConfigData = Config.getConfigData('config', 'bilibili', 'config');
@@ -37,6 +37,7 @@ class BiliTask {
37
37
  let biliConfigData = await Config.getUserConfig('bilibili', 'config');
38
38
  let biliPushData = await Config.getUserConfig('bilibili', 'push');
39
39
  let interval = biliConfigData?.interval || 7200;
40
+ logger.debug(`当前B站功能配置:${JSON.stringify(biliConfigData)}`);
40
41
  const uidMap = new Map(); // 存放group 和 private 对应所属 uid 与推送信息的映射
41
42
  const dynamicList = {}; // 存放获取的所有动态,键为 uid,值为动态数组
42
43
  await this.processBiliData(biliPushData, biliConfigData, uidMap, dynamicList);
@@ -172,9 +173,11 @@ class BiliTask {
172
173
  }
173
174
  if (sended)
174
175
  return; // 如果已经发送过,则直接返回
175
- let liveAtAll = biliConfigData.liveAtAll === true ? true : false; // 直播动态是否@全体成员,默认false
176
+ let liveAtAll = !!biliConfigData.liveAtAll === true ? true : false; // 直播动态是否@全体成员,默认false
176
177
  let liveAtAllCD = biliConfigData.liveAtAllCD || 1800; // 直播动态@全体成员 冷却时间CD,默认 30 分钟
177
178
  let liveAtAllMark = await Redis.get(`${markKey}${chatId}:liveAtAllMark`); // 直播动态@全体成员标记,默认 0
179
+ // 直播动态@全体成员的群组列表,默认空数组,为空则不进行@全体成员操作
180
+ let liveAtAllGroupList = new Set(Array.isArray(biliConfigData?.liveAtAllGroupList) ? Array.from(biliConfigData.liveAtAllGroupList).map(item => String(item)) : []);
178
181
  if (!!biliConfigData.pushMsgMode) {
179
182
  const { data, uid } = await BiliQuery.formatDynamicData(pushDynamicData); // 处理动态数据
180
183
  const extentData = { ...data };
@@ -206,7 +209,7 @@ class BiliTask {
206
209
  return;
207
210
  Redis.set(`${markKey}${chatId}:${id_str}`, '1', { EX: 3600 * 72 }); // 设置已发送标记
208
211
  global?.logger?.mark('优纪插件:B站动态执行推送');
209
- if (liveAtAll && liveAtAllMark && extentData?.type === 'DYNAMIC_TYPE_LIVE_RCMD') {
212
+ if (liveAtAll && !liveAtAllMark && extentData?.type === 'DYNAMIC_TYPE_LIVE_RCMD' && liveAtAllGroupList.has(String(chatId))) {
210
213
  try {
211
214
  await this.sendMessage(chatId, bot_id, chatType, Segment.at('all'));
212
215
  await Redis.set(`${markKey}${chatId}:liveAtAllMark`, 1, { EX: liveAtAllCD }); // 设置直播动态@全体成员标记为 1
@@ -237,9 +240,9 @@ class BiliTask {
237
240
  }
238
241
  }
239
242
  let mergeTextPic = !!biliConfigData.mergeTextPic === false ? false : true; // 是否合并文本和图片,默认为 true
240
- if (mergeTextPic) {
243
+ if (mergeTextPic === true) {
241
244
  const mergeMsg = [...dynamicMsg.msg, ...dynamicMsg.pics];
242
- if (liveAtAll && liveAtAllMark && dynamicMsg.dynamicType === 'DYNAMIC_TYPE_LIVE_RCMD') {
245
+ if (liveAtAll && !liveAtAllMark && dynamicMsg.dynamicType === 'DYNAMIC_TYPE_LIVE_RCMD' && liveAtAllGroupList.has(String(chatId))) {
243
246
  try {
244
247
  await this.sendMessage(chatId, bot_id, chatType, Segment.at('all'));
245
248
  await Redis.set(`${markKey}${chatId}:liveAtAllMark`, 1, { EX: liveAtAllCD }); // 设置直播动态@全体成员标记为 1
@@ -252,7 +255,7 @@ class BiliTask {
252
255
  await this.sendMessage(chatId, bot_id, chatType, mergeMsg);
253
256
  }
254
257
  else {
255
- if (liveAtAll && liveAtAllMark && dynamicMsg.dynamicType === 'DYNAMIC_TYPE_LIVE_RCMD') {
258
+ if (liveAtAll && !liveAtAllMark && dynamicMsg.dynamicType === 'DYNAMIC_TYPE_LIVE_RCMD' && liveAtAllGroupList.has(String(chatId))) {
256
259
  try {
257
260
  await this.sendMessage(chatId, bot_id, chatType, Segment.at('all'));
258
261
  await Redis.set(`${markKey}${chatId}:liveAtAllMark`, 1, { EX: liveAtAllCD }); // 设置直播动态@全体成员标记为 1
@@ -1,6 +1,6 @@
1
1
  import axios from 'axios';
2
- import { WeiboApi } from './weibo.api.js';
3
- import { WeiboQuery } from './weibo.query.js';
2
+ import { WeiboApi } from './weibo.main.api.js';
3
+ import { WeiboQuery } from './weibo.main.query.js';
4
4
 
5
5
  class WeiboGetWebData {
6
6
  e;
@@ -1,6 +1,6 @@
1
1
  import moment from 'moment';
2
2
  import fetch from 'node-fetch';
3
- import { WeiboApi } from './weibo.api.js';
3
+ import { WeiboApi } from './weibo.main.api.js';
4
4
  import { Segment } from 'yunzaijs';
5
5
  import { JSDOM } from 'jsdom';
6
6
 
@@ -2,8 +2,8 @@ import QRCode from 'qrcode';
2
2
  import { Redis, Segment, Bot } from 'yunzaijs';
3
3
  import Config from '../../utils/config.js';
4
4
  import { renderPage } from '../../utils/image.js';
5
- import { WeiboGetWebData } from './weibo.get.web.data.js';
6
- import { WeiboQuery } from './weibo.query.js';
5
+ import { WeiboGetWebData } from './weibo.main.get.web.data.js';
6
+ import { WeiboQuery } from './weibo.main.query.js';
7
7
 
8
8
  class WeiboTask {
9
9
  taskName;
@@ -19,6 +19,7 @@ class WeiboTask {
19
19
  let weiboConfigData = await Config.getUserConfig('weibo', 'config');
20
20
  let weiboPushData = await Config.getUserConfig('weibo', 'push');
21
21
  let interval = weiboConfigData.interval || 7200; // 推送间隔时间,单位为秒,默认2小时
22
+ logger.debug(`当前微博功能配置:${JSON.stringify(weiboConfigData)}`);
22
23
  const uidMap = new Map(); // 存放group 和 private 对应所属 uid 与推送信息的映射
23
24
  const dynamicList = {}; // 存放获取的所有动态,键为 uid,值为动态数组
24
25
  await this.processWeiboData(weiboPushData, uidMap, dynamicList);
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "yz-yuki-plugin",
3
- "version": "2.0.6-5",
3
+ "version": "2.0.6-7",
4
4
  "description": "优纪插件,yunzaijs 关于 微博推送、B站推送 等功能的拓展插件",
5
5
  "author": "snowtafir",
6
6
  "type": "module",