mirror of
https://github.com/NapNeko/NapCatQQ.git
synced 2026-02-06 13:05:09 +00:00
feat: sysMessage oldProto adapter
This commit is contained in:
@@ -46,7 +46,7 @@ import { OB11GroupRecallNoticeEvent } from '@/onebot/event/notice/OB11GroupRecal
|
||||
import { LRUCache } from '@/common/lru-cache';
|
||||
import { NodeIKernelRecentContactListener } from '@/core/listeners/NodeIKernelRecentContactListener';
|
||||
import { Native } from '@/native';
|
||||
//import { decodeMessage, decodeRecallGroup } from '@/core/packet/proto/old/Message';
|
||||
import { decodeMessage, decodeRecallGroup } from "@/core/helper/adaptSysMessageDecoder";
|
||||
import { BotOfflineEvent } from './event/notice/BotOfflineEvent';
|
||||
|
||||
//OneBot实现类
|
||||
@@ -83,25 +83,24 @@ export class NapCatOneBot11Adapter {
|
||||
async registerNative(core: NapCatCore, context: InstanceContext) {
|
||||
try {
|
||||
this.nativeCore = new Native(context.pathWrapper.binaryPath);
|
||||
// if (!this.nativeCore.inited) throw new Error('Native Not Init');
|
||||
if (!this.nativeCore.inited) throw new Error('Native Not Init');
|
||||
this.nativeCore.registerRecallCallback(async (hex: string) => {
|
||||
try {
|
||||
// TODO: refactor!
|
||||
// const data = decodeMessage(Buffer.from(hex, 'hex'));
|
||||
// //data.MsgHead.BodyInner.MsgType SubType
|
||||
// const bodyInner = data.msgHead?.bodyInner;
|
||||
// //context.logger.log("[appNative] Parse MsgType:" + bodyInner.msgType + " / SubType:" + bodyInner.subType);
|
||||
// if (bodyInner && bodyInner.msgType == 732 && bodyInner.subType == 17) {
|
||||
// const RecallData = Buffer.from(data.msgHead.noifyData.innerData);
|
||||
// //跳过 4字节 群号 + 不知道的1字节 +2字节 长度
|
||||
// const uid = RecallData.readUint32BE();
|
||||
// const buffer = Buffer.from(RecallData.toString('hex').slice(14), 'hex');
|
||||
// const seq: number = decodeRecallGroup(buffer).recallDetails.subDetail.msgSeq;
|
||||
// const peer: Peer = { chatType: ChatType.KCHATTYPEGROUP, peerUid: uid.toString() };
|
||||
// context.logger.log("[Native] 群消息撤回 Peer: " + uid.toString() + " / MsgSeq:" + seq);
|
||||
// const msgs = await core.apis.MsgApi.queryMsgsWithFilterExWithSeq(peer, seq.toString());
|
||||
// this.recallMsgCache.put(msgs.msgList[0].msgId, msgs.msgList[0]);
|
||||
// }
|
||||
const data = decodeMessage(Buffer.from(hex, 'hex'));
|
||||
//data.MsgHead.BodyInner.MsgType SubType
|
||||
const bodyInner = data.msgHead?.bodyInner;
|
||||
//context.logger.log("[appNative] Parse MsgType:" + bodyInner.msgType + " / SubType:" + bodyInner.subType);
|
||||
if (bodyInner && bodyInner.msgType == 732 && bodyInner.subType == 17 && data?.msgHead?.noifyData?.innerData) {
|
||||
const RecallData = Buffer.from(data?.msgHead?.noifyData?.innerData);
|
||||
//跳过 4字节 群号 + 不知道的1字节 +2字节 长度
|
||||
const uid = RecallData.readUint32BE();
|
||||
const buffer = Buffer.from(RecallData.toString('hex').slice(14), 'hex');
|
||||
const seq: number = decodeRecallGroup(buffer).recallDetails.subDetail.msgSeq;
|
||||
const peer: Peer = { chatType: ChatType.KCHATTYPEGROUP, peerUid: uid.toString() };
|
||||
context.logger.log("[Native] 群消息撤回 Peer: " + uid.toString() + " / MsgSeq:" + seq);
|
||||
const msgs = await core.apis.MsgApi.queryMsgsWithFilterExWithSeq(peer, seq.toString());
|
||||
this.recallMsgCache.put(msgs.msgList[0].msgId, msgs.msgList[0]);
|
||||
}
|
||||
} catch (error: any) {
|
||||
context.logger.logWarn("[Native] Error:", (error as Error).message, ' HEX:', hex);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user