refactor: MemberInfo-1

This commit is contained in:
手瓜一十雪 2024-05-28 20:08:40 +08:00
parent 75ad495b98
commit 07cee90c7a
8 changed files with 96 additions and 97 deletions

View File

@ -2,7 +2,7 @@ import sqlite3 from "sqlite3";
import { logError, logDebug } from "@/common/utils/log"; import { logError, logDebug } from "@/common/utils/log";
import { selfInfo } from "@/core/data"; import { selfInfo } from "@/core/data";
import { ob11Config } from "@/onebot11/config"; import { ob11Config } from "@/onebot11/config";
import LRU from "./LRUCache"; import LRU from "../../onebot11/action/group/LRUCache";
import path from "path"; import path from "path";
const dbPath = path.join( const dbPath = path.join(
@ -32,8 +32,7 @@ const createTableSQL = (groupId: number) =>
);`; );`;
async function createTableIfNotExist(groupId: number) { async function createTableIfNotExist(groupId: number) {
// 未开启本地记录
if (!ob11Config.localDB) return;
logDebug("检测数据表存在", groupId); logDebug("检测数据表存在", groupId);
if (groupIds.includes(groupId)) { if (groupIds.includes(groupId)) {
@ -63,9 +62,6 @@ export async function insertJoinTime(
userId: number, userId: number,
time: number time: number
) { ) {
// 未开启本地记录
if (!ob11Config.localDB) return;
logDebug("插入入群时间", userId, groupId); logDebug("插入入群时间", userId, groupId);
await createTableIfNotExist(groupId); await createTableIfNotExist(groupId);
remberDb.all( remberDb.all(
@ -183,6 +179,5 @@ export function insertLastSentTime(
userId: number, userId: number,
time: number time: number
) { ) {
if (!ob11Config.localDB) return;
LURCache.set(groupId, userId,time) LURCache.set(groupId, userId,time)
} }

View File

@ -145,6 +145,7 @@ export function migrateConfig(oldConfig: any) {
musicSignUrl: oldConfig.musicSignUrl, musicSignUrl: oldConfig.musicSignUrl,
reportSelfMessage: oldConfig.reportSelfMessage, reportSelfMessage: oldConfig.reportSelfMessage,
token: oldConfig.token, token: oldConfig.token,
GroupLocalTimeRecord: []
}; };
return newConfig; return newConfig;
} }

View File

@ -1,4 +1,4 @@
import { getGroup, groupMembers } from '@/core/data'; import { getGroup, getGroupMember, groupMembers, selfInfo } from '@/core/data';
import { OB11GroupMember } from '../../types'; import { OB11GroupMember } from '../../types';
import { OB11Constructor } from '../../constructor'; import { OB11Constructor } from '../../constructor';
import BaseAction from '../BaseAction'; import BaseAction from '../BaseAction';
@ -7,7 +7,8 @@ import { napCatCore, NTQQGroupApi, NTQQUserApi, SignMiniApp } from '@/core';
import { WebApi } from '@/core/apis/webapi'; import { WebApi } from '@/core/apis/webapi';
import { logDebug } from '@/common/utils/log'; import { logDebug } from '@/common/utils/log';
import { FromSchema, JSONSchema } from 'json-schema-to-ts'; import { FromSchema, JSONSchema } from 'json-schema-to-ts';
import { getLastSentTimeAndJoinTime }from "./LastSendAndJoinRemberLRU" import { getLastSentTimeAndJoinTime } from "../../../common/utils/LastSendAndJoinRemberLRU"
import { ob11Config } from '@/onebot11/config';
const SchemaData = { const SchemaData = {
type: 'object', type: 'object',
@ -24,25 +25,30 @@ class GetGroupMemberList extends BaseAction<Payload, OB11GroupMember[]> {
actionName = ActionName.GetGroupMemberList; actionName = ActionName.GetGroupMemberList;
PayloadSchema = SchemaData; PayloadSchema = SchemaData;
protected async _handle(payload: Payload) { protected async _handle(payload: Payload) {
const MemberMap: Map<number, OB11GroupMember> = new Map<number, OB11GroupMember>(); const role = (await getGroupMember(payload.group_id, selfInfo.uin))?.role;
const webGroupMembers = await WebApi.getGroupMembers(payload.group_id.toString());
const group = await getGroup(payload.group_id.toString()); const group = await getGroup(payload.group_id.toString());
if (!group) { if (!group) {
throw (`${payload.group_id}不存在`); throw (`${payload.group_id}不存在`);
} }
// 从Data里面获取
let _groupMembers: OB11GroupMember[] = OB11Constructor.groupMembers(group);
if (payload.no_cache == true || payload.no_cache === 'true') { if (payload.no_cache == true || payload.no_cache === 'true') {
// webGroupMembers = await WebApi.getGroupMembers(payload.group_id.toString());' // webGroupMembers = await WebApi.getGroupMembers(payload.group_id.toString());'
const _groupMembers = await NTQQGroupApi.getGroupMembers(payload.group_id.toString()); const _groupMembers = await NTQQGroupApi.getGroupMembers(payload.group_id.toString());
groupMembers.set(group.groupCode, _groupMembers); groupMembers.set(group.groupCode, _groupMembers);
} }
const _groupMembers = OB11Constructor.groupMembers(group);
// 方便索引处理 const MemberMap: Map<number, OB11GroupMember> = new Map<number, OB11GroupMember>();
// 转为Map 方便索引
for (let i = 0, len = _groupMembers.length; i < len; i++) { for (let i = 0, len = _groupMembers.length; i < len; i++) {
MemberMap.set(_groupMembers[i].user_id, _groupMembers[i]); MemberMap.set(_groupMembers[i].user_id, _groupMembers[i]);
} }
// 合并数据
const isPrivilege = role === 3 || role === 4;
if (isPrivilege) {
const webGroupMembers = await WebApi.getGroupMembers(payload.group_id.toString());
for (let i = 0, len = webGroupMembers.length; i < len; i++) { for (let i = 0, len = webGroupMembers.length; i < len; i++) {
if (!webGroupMembers[i]?.uin) { if (!webGroupMembers[i]?.uin) {
continue; continue;
@ -56,24 +62,19 @@ class GetGroupMemberList extends BaseAction<Payload, OB11GroupMember[]> {
MemberMap.set(webGroupMembers[i]?.uin, MemberData); MemberMap.set(webGroupMembers[i]?.uin, MemberData);
} }
} }
// 还原Map到Array } else if ((ob11Config.GroupLocalTimeRecord as Array<number>).includes(payload.group_id)) {
const RetGroupMember: OB11GroupMember[] = Array.from(MemberMap.values()); const _sendAndJoinRember = await getLastSentTimeAndJoinTime(payload.group_id);
_sendAndJoinRember.forEach((element) => {
// 无管理员权限通过本地记录获取发言时间 let MemberData = MemberMap.get(element.user_id);
const haveAdmin = RetGroupMember[0].last_sent_time !== 0; if (MemberData) {
if (!haveAdmin) { MemberData.join_time = element.join_time;
//logDebug('没有管理员权限,使用本地记录'); MemberData.last_sent_time = element.last_sent_time;
const _sendAndJoinRember = await getLastSentTimeAndJoinTime(parseInt(group.groupCode));
_sendAndJoinRember.forEach((rember) => {
const member = RetGroupMember.find(member=>member.user_id == rember.user_id);
if(member){
member.last_sent_time = rember.last_sent_time;
member.join_time = rember.join_time;
} }
}) });
} }
// 还原索引到Array 一同返回
return RetGroupMember; _groupMembers = Array.from(MemberMap.values());
return _groupMembers;
} }
} }

View File

@ -33,7 +33,7 @@ export interface OB11Config {
reportSelfMessage: boolean; reportSelfMessage: boolean;
token: string; token: string;
localDB: boolean; GroupLocalTimeRecord: Array<string>;
read(): OB11Config; read(): OB11Config;
@ -67,7 +67,7 @@ class Config extends ConfigBase<OB11Config> implements OB11Config {
reportSelfMessage = false; reportSelfMessage = false;
token = ''; token = '';
localDB = true; GroupLocalTimeRecord = [];
getConfigPath() { getConfigPath() {
return path.join(this.getConfigDir(), `onebot11_${selfInfo.uin}.json`); return path.join(this.getConfigDir(), `onebot11_${selfInfo.uin}.json`);

View File

@ -35,7 +35,7 @@ import { Data as SysData } from '@/proto/SysMessage';
import { Data as DeviceData } from '@/proto/SysMessage.DeviceChange'; import { Data as DeviceData } from '@/proto/SysMessage.DeviceChange';
import { OB11FriendPokeEvent, OB11GroupPokeEvent } from './event/notice/OB11PokeEvent'; import { OB11FriendPokeEvent, OB11GroupPokeEvent } from './event/notice/OB11PokeEvent';
import { isEqual } from '@/common/utils/helper'; import { isEqual } from '@/common/utils/helper';
import { insertLastSentTime } from "./action/group/LastSendAndJoinRemberLRU" import { insertLastSentTime } from "../common/utils/LastSendAndJoinRemberLRU"
//下面几个其实应该移进Core-Data 缓存实现 但是现在在这里方便 //下面几个其实应该移进Core-Data 缓存实现 但是现在在这里方便
// //

View File

@ -26,6 +26,7 @@ export interface OB11Config {
musicSignUrl: ''; musicSignUrl: '';
reportSelfMessage: boolean; reportSelfMessage: boolean;
token: ''; token: '';
GroupLocalTimeRecord: [];
} }
class WebUiApiOB11ConfigWrapper { class WebUiApiOB11ConfigWrapper {

View File

@ -108,7 +108,7 @@ class WebUiApiOB11ConfigWrapper {
this.retCredential = Credential; this.retCredential = Credential;
} }
async GetOB11Config() { async GetOB11Config() {
let ConfigResponse = await fetch("/api/OB11Config/GetConfig", { const ConfigResponse = await fetch("/api/OB11Config/GetConfig", {
method: "POST", method: "POST",
headers: { headers: {
Authorization: "Bearer " + this.retCredential, Authorization: "Bearer " + this.retCredential,
@ -116,7 +116,7 @@ class WebUiApiOB11ConfigWrapper {
} }
}); });
if (ConfigResponse.status == 200) { if (ConfigResponse.status == 200) {
let ConfigResponseJson = await ConfigResponse.json(); const ConfigResponseJson = await ConfigResponse.json();
if (ConfigResponseJson.code == 0) { if (ConfigResponseJson.code == 0) {
return ConfigResponseJson?.data; return ConfigResponseJson?.data;
} }
@ -124,7 +124,7 @@ class WebUiApiOB11ConfigWrapper {
return {}; return {};
} }
async SetOB11Config(config) { async SetOB11Config(config) {
let ConfigResponse = await fetch("/api/OB11Config/SetConfig", { const ConfigResponse = await fetch("/api/OB11Config/SetConfig", {
method: "POST", method: "POST",
headers: { headers: {
Authorization: "Bearer " + this.retCredential, Authorization: "Bearer " + this.retCredential,
@ -133,7 +133,7 @@ class WebUiApiOB11ConfigWrapper {
body: JSON.stringify({ config: JSON.stringify(config) }) body: JSON.stringify({ config: JSON.stringify(config) })
}); });
if (ConfigResponse.status == 200) { if (ConfigResponse.status == 200) {
let ConfigResponseJson = await ConfigResponse.json(); const ConfigResponseJson = await ConfigResponse.json();
if (ConfigResponseJson.code == 0) { if (ConfigResponseJson.code == 0) {
return true; return true;
} }
@ -142,10 +142,11 @@ class WebUiApiOB11ConfigWrapper {
} }
} }
const OB11ConfigWrapper = new WebUiApiOB11ConfigWrapper(); const OB11ConfigWrapper = new WebUiApiOB11ConfigWrapper();
async function onSettingWindowCreated(view) { async function onSettingWindowCreated(view) {
const isEmpty = (value) => value === void 0 || value === void 0 || value === ""; const isEmpty = (value) => value === void 0 || value === void 0 || value === "";
await OB11ConfigWrapper.Init(localStorage.getItem("auth")); await OB11ConfigWrapper.Init(localStorage.getItem("auth"));
let ob11Config = await OB11ConfigWrapper.GetOB11Config(); const ob11Config = await OB11ConfigWrapper.GetOB11Config();
const setOB11Config = (key, value) => { const setOB11Config = (key, value) => {
const configKey = key.split("."); const configKey = key.split(".");
if (configKey.length === 2) { if (configKey.length === 2) {
@ -289,18 +290,18 @@ async function onSettingWindowCreated(view) {
SettingList([ SettingList([
SettingItem( SettingItem(
"GitHub 仓库", "GitHub 仓库",
`https://github.com/NapNeko/NapCatQQ`, "https://github.com/NapNeko/NapCatQQ",
SettingButton("点个星星", "open-github") SettingButton("点个星星", "open-github")
), ),
SettingItem("NapCat 文档", ``, SettingButton("看看文档", "open-docs")), SettingItem("NapCat 文档", "", SettingButton("看看文档", "open-docs")),
SettingItem( SettingItem(
"Telegram 群", "Telegram 群",
`https://t.me/+nLZEnpne-pQ1OWFl`, "https://t.me/+nLZEnpne-pQ1OWFl",
SettingButton("进去逛逛", "open-telegram") SettingButton("进去逛逛", "open-telegram")
), ),
SettingItem( SettingItem(
"QQ 群", "QQ 群",
`545402644`, "545402644",
SettingButton("我要进去", "open-qq-group") SettingButton("我要进去", "open-qq-group")
) )
]), ]),
@ -413,7 +414,7 @@ async function onSettingWindowCreated(view) {
dom.removeAttribute("is-active"); dom.removeAttribute("is-active");
if (!isEmpty(dom.dataset.controlDisplayId)) { if (!isEmpty(dom.dataset.controlDisplayId)) {
const displayDom = document.querySelector( const displayDom = document.querySelector(
//@ts-ignore 等待修复 //@ts-expect-error 等待修复
`#${dom.dataset.controlDisplayId}` `#${dom.dataset.controlDisplayId}`
); );
if (active) if (active)