Compare commits

..

2 Commits

Author SHA1 Message Date
手瓜一十雪
e8d6f86458 feat: 修复一些问题 2025-11-07 19:35:35 +08:00
手瓜一十雪
a000ffdf0d fix: buddylist 2025-11-07 19:29:39 +08:00
8 changed files with 84 additions and 71 deletions

4
.gitignore vendored
View File

@@ -14,4 +14,6 @@ devconfig/*
*.db *.db
checkVersion.sh checkVersion.sh
bun.lockb bun.lockb
tests/run/ tests/run/
guild1.db-wal
guild1.db-shm

View File

@@ -17,8 +17,14 @@ export class NTQQFriendApi {
async getBuddyV2SimpleInfoMap () { async getBuddyV2SimpleInfoMap () {
const buddyService = this.context.session.getBuddyService(); const buddyService = this.context.session.getBuddyService();
const buddyListV2 = await buddyService.getBuddyListV2('0', BuddyListReqType.KNOMAL); let uids: string[] = [];
const uids = buddyListV2.data.flatMap(item => item.buddyUids); if (this.core.context.basicInfoWrapper.requireMinNTQQBuild('40990')) {
const buddyListV2NT = await buddyService.getBuddyListV2('0', true, BuddyListReqType.KNOMAL);
uids = buddyListV2NT.data.flatMap(item => item.buddyUids);
} else {
const buddyListV2 = await buddyService.getBuddyListV2('0', BuddyListReqType.KNOMAL);
uids = buddyListV2.data.flatMap(item => item.buddyUids);
}
return await this.core.eventWrapper.callNoListenerEvent( return await this.core.eventWrapper.callNoListenerEvent(
'NodeIKernelProfileService/getCoreAndBaseInfo', 'NodeIKernelProfileService/getCoreAndBaseInfo',
'nodeStore', 'nodeStore',

View File

@@ -3,122 +3,133 @@ import { NodeIKernelBuddyListener } from '@/core/listeners';
import { BuddyListReqType } from '@/core/types/user'; import { BuddyListReqType } from '@/core/types/user';
export interface NodeIKernelBuddyService { export interface NodeIKernelBuddyService {
getBuddyListV2(callFrom: string, reqType: BuddyListReqType): Promise<GeneralCallResult & { getBuddyListV2 (callFrom: string, reqType: BuddyListReqType): Promise<GeneralCallResult & {
data: Array<{ data: Array<{
categoryId: number, categoryId: number,
categorySortId: number, categorySortId: number,
categroyName: string, categroyName: string,
categroyMbCount: number, categroyMbCount: number,
onlineCount: number, onlineCount: number,
buddyUids: Array<string> buddyUids: Array<string>;
}> }>;
}>;
getBuddyListV2 (callFrom: string, isPullRefresh: boolean, reqType: BuddyListReqType): Promise<GeneralCallResult & {
data: Array<{
categoryId: number,
categorySortId: number,
categroyName: string,
categroyMbCount: number,
onlineCount: number,
buddyUids: Array<string>;
}>;
}>; }>;
getBuddyListFromCache(reqType: BuddyListReqType): Promise<Array<
{
categoryId: number, // 9999为特别关心
categorySortId: number, // 排序方式
categroyName: string, // 分类名
categroyMbCount: number, // 不懂
onlineCount: number, // 在线数目
buddyUids: Array<string>// Uids
}>>;
addKernelBuddyListener(listener: NodeIKernelBuddyListener): number; getBuddyListFromCache (reqType: BuddyListReqType): Promise<Array<
{
categoryId: number, // 9999为特别关心
categorySortId: number, // 排序方式
categroyName: string, // 分类名
categroyMbCount: number, // 不懂
onlineCount: number, // 在线数目
buddyUids: Array<string>;// Uids
}>>;
getAllBuddyCount(): number; addKernelBuddyListener (listener: NodeIKernelBuddyListener): number;
removeKernelBuddyListener(listenerId: number): void; getAllBuddyCount (): number;
removeKernelBuddyListener (listenerId: number): void;
// getBuddyList(nocache: boolean): Promise<GeneralCallResult>; // getBuddyList(nocache: boolean): Promise<GeneralCallResult>;
getBuddyNick(uid: number): string; getBuddyNick (uid: number): string;
getBuddyRemark(uid: number): string; getBuddyRemark (uid: number): string;
setBuddyRemark(param: { uid: string, remark: string, signInfo?: unknown }): void; setBuddyRemark (param: { uid: string, remark: string, signInfo?: unknown; }): void;
getAvatarUrl(uid: number): string; getAvatarUrl (uid: number): string;
isBuddy(uid: string): boolean; isBuddy (uid: string): boolean;
getCategoryNameWithUid(uid: number): string; getCategoryNameWithUid (uid: number): string;
getTargetBuddySetting(uid: number): unknown; getTargetBuddySetting (uid: number): unknown;
getTargetBuddySettingByType(uid: number, type: number): unknown; getTargetBuddySettingByType (uid: number, type: number): unknown;
getBuddyReqUnreadCnt(): number; getBuddyReqUnreadCnt (): number;
getBuddyReq(): Promise<GeneralCallResult>; getBuddyReq (): Promise<GeneralCallResult>;
delBuddyReq(uid: number): void; delBuddyReq (uid: number): void;
clearBuddyReqUnreadCnt(): Promise<GeneralCallResult>; clearBuddyReqUnreadCnt (): Promise<GeneralCallResult>;
reqToAddFriends(uid: number, msg: string): void; reqToAddFriends (uid: number, msg: string): void;
setSpacePermission(uid: number, permission: number): void; setSpacePermission (uid: number, permission: number): void;
approvalFriendRequest(arg: { approvalFriendRequest (arg: {
friendUid: string; friendUid: string;
reqTime: string; reqTime: string;
accept: boolean; accept: boolean;
}): Promise<void>; }): Promise<void>;
delBuddy(param: { delBuddy (param: {
friendUid: string; friendUid: string;
tempBlock: boolean; tempBlock: boolean;
tempBothDel: boolean; tempBothDel: boolean;
}): Promise<unknown>; }): Promise<unknown>;
delBatchBuddy(uids: number[]): void; delBatchBuddy (uids: number[]): void;
getSmartInfos(uid: number): unknown; getSmartInfos (uid: number): unknown;
setBuddyCategory(uid: number, category: number): void; setBuddyCategory (uid: number, category: number): void;
setBatchBuddyCategory(uids: number[], category: number): void; setBatchBuddyCategory (uids: number[], category: number): void;
addCategory(category: string): void; addCategory (category: string): void;
delCategory(category: string): void; delCategory (category: string): void;
renameCategory(oldCategory: string, newCategory: string): void; renameCategory (oldCategory: string, newCategory: string): void;
resortCategory(categorys: string[]): void; resortCategory (categorys: string[]): void;
pullCategory(uid: number, category: string): void; pullCategory (uid: number, category: string): void;
setTop(uid: number, isTop: boolean): void; setTop (uid: number, isTop: boolean): void;
SetSpecialCare(uid: number, isSpecialCare: boolean): void; SetSpecialCare (uid: number, isSpecialCare: boolean): void;
setMsgNotify(uid: number, isNotify: boolean): void; setMsgNotify (uid: number, isNotify: boolean): void;
hasBuddyList(): boolean; hasBuddyList (): boolean;
setBlock(uid: number, isBlock: boolean): void; setBlock (uid: number, isBlock: boolean): void;
isBlocked(uid: number): boolean; isBlocked (uid: number): boolean;
modifyAddMeSetting(setting: unknown): void; modifyAddMeSetting (setting: unknown): void;
getAddMeSetting(): unknown; getAddMeSetting (): unknown;
getDoubtBuddyReq(reqId: string, num: number, uk:string): Promise<GeneralCallResult>; getDoubtBuddyReq (reqId: string, num: number, uk: string): Promise<GeneralCallResult>;
getDoubtBuddyUnreadNum(): number; getDoubtBuddyUnreadNum (): number;
approvalDoubtBuddyReq(uid: string, str1: string, str2: string): void; approvalDoubtBuddyReq (uid: string, str1: string, str2: string): void;
delDoubtBuddyReq(uid: number): void; delDoubtBuddyReq (uid: number): void;
delAllDoubtBuddyReq(): Promise<GeneralCallResult>; delAllDoubtBuddyReq (): Promise<GeneralCallResult>;
reportDoubtBuddyReqUnread(): void; reportDoubtBuddyReqUnread (): void;
getBuddyRecommendContactArkJson(uid: string, phoneNumber: string): Promise<GeneralCallResult & { arkMsg: string }>; getBuddyRecommendContactArkJson (uid: string, phoneNumber: string): Promise<GeneralCallResult & { arkMsg: string; }>;
isNull(): boolean; isNull (): boolean;
} }

View File

@@ -1434,8 +1434,7 @@ export class OneBotMsgApi {
+await this.core.apis.UserApi.getUinByUidV2(groupInvite.invitorUid), +await this.core.apis.UserApi.getUinByUidV2(groupInvite.invitorUid),
'invite', 'invite',
'', '',
request_seq, request_seq
+await this.core.apis.UserApi.getUinByUidV2(groupInvite.invitorUid)
); );
} else if (SysMessage.contentHead.type === 528 && SysMessage.contentHead.subType === 39 && SysMessage.body?.msgContent) { } else if (SysMessage.contentHead.type === 528 && SysMessage.contentHead.subType === 39 && SysMessage.body?.msgContent) {
return await this.obContext.apis.UserApi.parseLikeEvent(SysMessage.body?.msgContent); return await this.obContext.apis.UserApi.parseLikeEvent(SysMessage.body?.msgContent);

View File

@@ -9,15 +9,13 @@ export class OB11GroupRequestEvent extends OB11BaseRequestEvent {
comment: string; comment: string;
flag: string; flag: string;
sub_type: string; sub_type: string;
invitor_id?: number;
constructor (core: NapCatCore, groupId: number, userId: number, sub_type: string, comment: string, flag: string, invitorId?: number) { constructor (core: NapCatCore, groupId: number, userId: number, sub_type: string, comment: string, flag: string) {
super(core); super(core);
this.group_id = groupId; this.group_id = groupId;
this.user_id = userId; this.user_id = userId;
this.sub_type = sub_type; this.sub_type = sub_type;
this.comment = comment; this.comment = comment;
this.flag = flag; this.flag = flag;
this.invitor_id = invitorId;
} }
} }

View File

@@ -466,15 +466,13 @@ export class NapCatOneBot11Adapter {
notify.status === GroupNotifyMsgStatus.KUNHANDLE notify.status === GroupNotifyMsgStatus.KUNHANDLE
) { ) {
this.context.logger.logDebug(`收到邀请我加群通知:${notify}`); this.context.logger.logDebug(`收到邀请我加群通知:${notify}`);
const inviterUin = +await this.core.apis.UserApi.getUinByUidV2(notify.user2.uid);
const groupInviteEvent = new OB11GroupRequestEvent( const groupInviteEvent = new OB11GroupRequestEvent(
this.core, this.core,
+notify.group.groupCode, +notify.group.groupCode,
inviterUin, +await this.core.apis.UserApi.getUinByUidV2(notify.user2.uid),
'invite', 'invite',
notify.postscript, notify.postscript,
flag, flag
inviterUin
); );
this.networkManager this.networkManager
.emitEvent(groupInviteEvent) .emitEvent(groupInviteEvent)
@@ -490,10 +488,9 @@ export class NapCatOneBot11Adapter {
this.core, this.core,
+notify.group.groupCode, +notify.group.groupCode,
+await this.core.apis.UserApi.getUinByUidV2(notify.user1.uid), +await this.core.apis.UserApi.getUinByUidV2(notify.user1.uid),
'invite', 'add',
notify.postscript, notify.postscript,
flag, flag
+await this.core.apis.UserApi.getUinByUidV2(notify.user2.uid)
); );
this.networkManager this.networkManager
.emitEvent(groupInviteEvent) .emitEvent(groupInviteEvent)

Binary file not shown.