mirror of
https://github.com/LLOneBot/LLOneBot.git
synced 2024-11-22 01:56:33 +00:00
refactor
This commit is contained in:
@@ -5,7 +5,6 @@ import {
|
||||
CacheFileListItem,
|
||||
CacheFileType,
|
||||
CacheScanResult,
|
||||
ChatCacheList,
|
||||
ChatCacheListItemBasic,
|
||||
ChatType,
|
||||
ElementType,
|
||||
@@ -54,33 +53,16 @@ export class NTQQFileApi extends Service {
|
||||
{ downSourceType: 1, triggerType: 1 }
|
||||
)).urlResult.domainUrl[0]?.url
|
||||
} else {
|
||||
const data = await invoke<GeneralCallResult & {
|
||||
urlResult: {
|
||||
v4IpUrl: []
|
||||
v6IpUrl: []
|
||||
domainUrl: {
|
||||
url: string
|
||||
isHttps: boolean
|
||||
httpsDomain: string
|
||||
}[]
|
||||
videoCodecFormat: number
|
||||
}
|
||||
}>({
|
||||
methodName: 'nodeIKernelRichMediaService/getVideoPlayUrlV2',
|
||||
args: [
|
||||
{
|
||||
peer,
|
||||
msgId,
|
||||
elemId: elementId,
|
||||
videoCodecFormat: 0,
|
||||
exParams: {
|
||||
downSourceType: 1,
|
||||
triggerType: 1
|
||||
},
|
||||
},
|
||||
null,
|
||||
],
|
||||
})
|
||||
const data = await invoke('nodeIKernelRichMediaService/getVideoPlayUrlV2', [{
|
||||
peer,
|
||||
msgId,
|
||||
elemId: elementId,
|
||||
videoCodecFormat: 0,
|
||||
exParams: {
|
||||
downSourceType: 1,
|
||||
triggerType: 1
|
||||
},
|
||||
}, null])
|
||||
if (data.result !== 0) {
|
||||
this.ctx.logger.warn('getVideoUrl', data)
|
||||
}
|
||||
@@ -117,23 +99,18 @@ export class NTQQFileApi extends Service {
|
||||
file_uuid: ''
|
||||
})
|
||||
} else {
|
||||
mediaPath = await invoke<string>({
|
||||
methodName: NTMethod.MEDIA_FILE_PATH,
|
||||
args: [
|
||||
{
|
||||
path_info: {
|
||||
md5HexStr: fileMd5,
|
||||
fileName: fileName,
|
||||
elementType: elementType,
|
||||
elementSubType,
|
||||
thumbSize: 0,
|
||||
needCreate: true,
|
||||
downloadType: 1,
|
||||
file_uuid: '',
|
||||
},
|
||||
},
|
||||
],
|
||||
})
|
||||
mediaPath = await invoke(NTMethod.MEDIA_FILE_PATH, [{
|
||||
path_info: {
|
||||
md5HexStr: fileMd5,
|
||||
fileName: fileName,
|
||||
elementType: elementType,
|
||||
elementSubType,
|
||||
thumbSize: 0,
|
||||
needCreate: true,
|
||||
downloadType: 1,
|
||||
file_uuid: '',
|
||||
},
|
||||
}])
|
||||
}
|
||||
await fsPromise.copyFile(filePath, mediaPath)
|
||||
const fileSize = (await fsPromise.stat(filePath)).size
|
||||
@@ -209,9 +186,9 @@ export class NTQQFileApi extends Service {
|
||||
)
|
||||
filePath = data[1].filePath
|
||||
} else {
|
||||
const data = await invoke<{ notifyInfo: OnRichMediaDownloadCompleteParams }>({
|
||||
methodName: NTMethod.DOWNLOAD_MEDIA,
|
||||
args: [
|
||||
const data = await invoke<{ notifyInfo: OnRichMediaDownloadCompleteParams }>(
|
||||
NTMethod.DOWNLOAD_MEDIA,
|
||||
[
|
||||
{
|
||||
getReq: {
|
||||
fileModelId: '0',
|
||||
@@ -228,10 +205,12 @@ export class NTQQFileApi extends Service {
|
||||
},
|
||||
null,
|
||||
],
|
||||
cbCmd: ReceiveCmdS.MEDIA_DOWNLOAD_COMPLETE,
|
||||
cmdCB: payload => payload.notifyInfo.msgId === msgId,
|
||||
timeout
|
||||
})
|
||||
{
|
||||
cbCmd: ReceiveCmdS.MEDIA_DOWNLOAD_COMPLETE,
|
||||
cmdCB: payload => payload.notifyInfo.msgId === msgId,
|
||||
timeout
|
||||
}
|
||||
)
|
||||
filePath = data.notifyInfo.filePath
|
||||
}
|
||||
if (filePath.startsWith('\\')) {
|
||||
@@ -243,11 +222,13 @@ export class NTQQFileApi extends Service {
|
||||
}
|
||||
|
||||
async getImageSize(filePath: string) {
|
||||
return await invoke<{ width: number; height: number }>({
|
||||
className: NTClass.FS_API,
|
||||
methodName: NTMethod.IMAGE_SIZE,
|
||||
args: [filePath],
|
||||
})
|
||||
return await invoke<{ width: number; height: number }>(
|
||||
NTMethod.IMAGE_SIZE,
|
||||
[filePath],
|
||||
{
|
||||
className: NTClass.FS_API,
|
||||
}
|
||||
)
|
||||
}
|
||||
|
||||
async getImageUrl(element: PicElement) {
|
||||
@@ -289,15 +270,7 @@ export class NTQQFileCacheApi extends Service {
|
||||
}
|
||||
|
||||
async setCacheSilentScan(isSilent: boolean = true) {
|
||||
return await invoke<GeneralCallResult>({
|
||||
methodName: NTMethod.CACHE_SET_SILENCE,
|
||||
args: [
|
||||
{
|
||||
isSilent,
|
||||
},
|
||||
null,
|
||||
],
|
||||
})
|
||||
return await invoke<GeneralCallResult>(NTMethod.CACHE_SET_SILENCE, [{ isSilent }, null])
|
||||
}
|
||||
|
||||
getCacheSessionPathList() {
|
||||
@@ -306,110 +279,38 @@ export class NTQQFileCacheApi extends Service {
|
||||
key: string
|
||||
value: string
|
||||
}[]
|
||||
>({
|
||||
className: NTClass.OS_API,
|
||||
methodName: NTMethod.CACHE_PATH_SESSION,
|
||||
})
|
||||
}
|
||||
|
||||
clearCache(cacheKeys: Array<string> = ['tmp', 'hotUpdate']) {
|
||||
return invoke<any>({
|
||||
// TODO: 目前还不知道真正的返回值是什么
|
||||
methodName: NTMethod.CACHE_CLEAR,
|
||||
args: [
|
||||
{
|
||||
keys: cacheKeys,
|
||||
},
|
||||
null,
|
||||
],
|
||||
})
|
||||
}
|
||||
|
||||
addCacheScannedPaths(pathMap: object = {}) {
|
||||
return invoke<GeneralCallResult>({
|
||||
methodName: NTMethod.CACHE_ADD_SCANNED_PATH,
|
||||
args: [
|
||||
{
|
||||
pathMap: { ...pathMap },
|
||||
},
|
||||
null,
|
||||
],
|
||||
})
|
||||
>(NTMethod.CACHE_PATH_SESSION, [], { className: NTClass.OS_API })
|
||||
}
|
||||
|
||||
scanCache() {
|
||||
invoke<GeneralCallResult>({
|
||||
methodName: ReceiveCmdS.CACHE_SCAN_FINISH,
|
||||
classNameIsRegister: true,
|
||||
}).then()
|
||||
return invoke<CacheScanResult>({
|
||||
methodName: NTMethod.CACHE_SCAN,
|
||||
args: [null, null],
|
||||
timeout: 300 * Time.second,
|
||||
})
|
||||
invoke<GeneralCallResult>(ReceiveCmdS.CACHE_SCAN_FINISH, [], { classNameIsRegister: true })
|
||||
return invoke<CacheScanResult>(NTMethod.CACHE_SCAN, [null, null], { timeout: 300 * Time.second })
|
||||
}
|
||||
|
||||
getHotUpdateCachePath() {
|
||||
return invoke<string>({
|
||||
className: NTClass.HOTUPDATE_API,
|
||||
methodName: NTMethod.CACHE_PATH_HOT_UPDATE,
|
||||
})
|
||||
return invoke<string>(NTMethod.CACHE_PATH_HOT_UPDATE, [], { className: NTClass.HOTUPDATE_API })
|
||||
}
|
||||
|
||||
getDesktopTmpPath() {
|
||||
return invoke<string>({
|
||||
className: NTClass.BUSINESS_API,
|
||||
methodName: NTMethod.CACHE_PATH_DESKTOP_TEMP,
|
||||
})
|
||||
}
|
||||
|
||||
getChatCacheList(type: ChatType, pageSize: number = 1000, pageIndex: number = 0) {
|
||||
return new Promise<ChatCacheList>((res, rej) => {
|
||||
invoke<ChatCacheList>({
|
||||
methodName: NTMethod.CACHE_CHAT_GET,
|
||||
args: [
|
||||
{
|
||||
chatType: type,
|
||||
pageSize,
|
||||
order: 1,
|
||||
pageIndex,
|
||||
},
|
||||
null,
|
||||
],
|
||||
})
|
||||
.then((list) => res(list))
|
||||
.catch((e) => rej(e))
|
||||
})
|
||||
return invoke<string>(NTMethod.CACHE_PATH_DESKTOP_TEMP, [], { className: NTClass.BUSINESS_API })
|
||||
}
|
||||
|
||||
getFileCacheInfo(fileType: CacheFileType, pageSize: number = 1000, lastRecord?: CacheFileListItem) {
|
||||
const _lastRecord = lastRecord ? lastRecord : { fileType: fileType }
|
||||
|
||||
return invoke<CacheFileList>({
|
||||
methodName: NTMethod.CACHE_FILE_GET,
|
||||
args: [
|
||||
{
|
||||
fileType: fileType,
|
||||
restart: true,
|
||||
pageSize: pageSize,
|
||||
order: 1,
|
||||
lastRecord: _lastRecord,
|
||||
},
|
||||
null,
|
||||
],
|
||||
})
|
||||
return invoke<CacheFileList>(NTMethod.CACHE_FILE_GET, [{
|
||||
fileType: fileType,
|
||||
restart: true,
|
||||
pageSize: pageSize,
|
||||
order: 1,
|
||||
lastRecord: _lastRecord,
|
||||
}, null])
|
||||
}
|
||||
|
||||
async clearChatCache(chats: ChatCacheListItemBasic[] = [], fileKeys: string[] = []) {
|
||||
return await invoke<GeneralCallResult>({
|
||||
methodName: NTMethod.CACHE_CHAT_CLEAR,
|
||||
args: [
|
||||
{
|
||||
chats,
|
||||
fileKeys,
|
||||
},
|
||||
null,
|
||||
],
|
||||
})
|
||||
return await invoke<GeneralCallResult>(NTMethod.CACHE_CHAT_CLEAR, [{
|
||||
chats,
|
||||
fileKeys,
|
||||
}, null])
|
||||
}
|
||||
}
|
||||
|
@@ -28,12 +28,15 @@ export class NTQQFriendApi extends Service {
|
||||
categroyMbCount: number
|
||||
buddyList: Friend[]
|
||||
}[]
|
||||
}>({
|
||||
className: NTClass.NODE_STORE_API,
|
||||
methodName: 'getBuddyList',
|
||||
cbCmd: ReceiveCmdS.FRIENDS,
|
||||
afterFirstCmd: false,
|
||||
})
|
||||
}>(
|
||||
'getBuddyList',
|
||||
[],
|
||||
{
|
||||
className: NTClass.NODE_STORE_API,
|
||||
cbCmd: ReceiveCmdS.FRIENDS,
|
||||
afterFirstCmd: false,
|
||||
}
|
||||
)
|
||||
const _friends: Friend[] = []
|
||||
for (const item of data.data) {
|
||||
_friends.push(...item.buddyList)
|
||||
@@ -56,18 +59,13 @@ export class NTQQFriendApi extends Service {
|
||||
accept
|
||||
})
|
||||
} else {
|
||||
return await invoke({
|
||||
methodName: NTMethod.HANDLE_FRIEND_REQUEST,
|
||||
args: [
|
||||
{
|
||||
approvalInfo: {
|
||||
friendUid,
|
||||
reqTime,
|
||||
accept,
|
||||
},
|
||||
},
|
||||
],
|
||||
})
|
||||
return await invoke(NTMethod.HANDLE_FRIEND_REQUEST, [{
|
||||
approvalInfo: {
|
||||
friendUid,
|
||||
reqTime,
|
||||
accept,
|
||||
},
|
||||
}])
|
||||
}
|
||||
}
|
||||
|
||||
@@ -86,13 +84,15 @@ export class NTQQFriendApi extends Service {
|
||||
const data = await invoke<{
|
||||
buddyCategory: CategoryFriend[]
|
||||
userSimpleInfos: Record<string, SimpleInfo>
|
||||
}>({
|
||||
className: NTClass.NODE_STORE_API,
|
||||
methodName: 'getBuddyList',
|
||||
args: [refresh],
|
||||
cbCmd: ReceiveCmdS.FRIENDS,
|
||||
afterFirstCmd: false,
|
||||
})
|
||||
}>(
|
||||
'getBuddyList',
|
||||
[refresh],
|
||||
{
|
||||
className: NTClass.NODE_STORE_API,
|
||||
cbCmd: ReceiveCmdS.FRIENDS,
|
||||
afterFirstCmd: false,
|
||||
}
|
||||
)
|
||||
const categoryUids: Map<number, string[]> = new Map()
|
||||
for (const item of data.buddyCategory) {
|
||||
categoryUids.set(item.categoryId, item.buddyUids)
|
||||
@@ -119,13 +119,15 @@ export class NTQQFriendApi extends Service {
|
||||
const data = await invoke<{
|
||||
buddyCategory: CategoryFriend[]
|
||||
userSimpleInfos: Record<string, SimpleInfo>
|
||||
}>({
|
||||
className: NTClass.NODE_STORE_API,
|
||||
methodName: 'getBuddyList',
|
||||
args: [refresh],
|
||||
cbCmd: ReceiveCmdS.FRIENDS,
|
||||
afterFirstCmd: false,
|
||||
})
|
||||
}>(
|
||||
'getBuddyList',
|
||||
[refresh],
|
||||
{
|
||||
className: NTClass.NODE_STORE_API,
|
||||
cbCmd: ReceiveCmdS.FRIENDS,
|
||||
afterFirstCmd: false,
|
||||
}
|
||||
)
|
||||
for (const item of Object.values(data.userSimpleInfos)) {
|
||||
retMap.set(item.uin!, item.uid!)
|
||||
}
|
||||
@@ -158,13 +160,15 @@ export class NTQQFriendApi extends Service {
|
||||
const data = await invoke<{
|
||||
buddyCategory: CategoryFriend[]
|
||||
userSimpleInfos: Record<string, SimpleInfo>
|
||||
}>({
|
||||
className: NTClass.NODE_STORE_API,
|
||||
methodName: 'getBuddyList',
|
||||
args: [refresh],
|
||||
cbCmd: ReceiveCmdS.FRIENDS,
|
||||
afterFirstCmd: false,
|
||||
})
|
||||
}>(
|
||||
'getBuddyList',
|
||||
[refresh],
|
||||
{
|
||||
className: NTClass.NODE_STORE_API,
|
||||
cbCmd: ReceiveCmdS.FRIENDS,
|
||||
afterFirstCmd: false,
|
||||
}
|
||||
)
|
||||
const category: Map<number, Pick<CategoryFriend, 'buddyUids' | 'categroyName'>> = new Map()
|
||||
for (const item of data.buddyCategory) {
|
||||
category.set(item.categoryId, pick(item, ['buddyUids', 'categroyName']))
|
||||
@@ -186,13 +190,7 @@ export class NTQQFriendApi extends Service {
|
||||
if (session) {
|
||||
return session.getBuddyService().isBuddy(uid)
|
||||
} else {
|
||||
return await invoke<boolean>({
|
||||
methodName: 'nodeIKernelBuddyService/isBuddy',
|
||||
args: [
|
||||
{ uid },
|
||||
null,
|
||||
],
|
||||
})
|
||||
return await invoke('nodeIKernelBuddyService/isBuddy', [{ uid }, null])
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@@ -17,6 +17,8 @@ declare module 'cordis' {
|
||||
}
|
||||
|
||||
export class NTQQGroupApi extends Service {
|
||||
static inject = ['ntWindowApi']
|
||||
|
||||
private groupMembers: Map<string, Map<string, GroupMember>> = new Map<string, Map<string, GroupMember>>()
|
||||
|
||||
constructor(protected ctx: Context) {
|
||||
@@ -41,45 +43,29 @@ export class NTQQGroupApi extends Service {
|
||||
const result = await invoke<{
|
||||
updateType: number
|
||||
groupList: Group[]
|
||||
}>({
|
||||
className: NTClass.NODE_STORE_API,
|
||||
methodName: 'getGroupList',
|
||||
cbCmd: ReceiveCmdS.GROUPS_STORE,
|
||||
afterFirstCmd: false,
|
||||
})
|
||||
}>(
|
||||
'getGroupList',
|
||||
[],
|
||||
{
|
||||
className: NTClass.NODE_STORE_API,
|
||||
cbCmd: ReceiveCmdS.GROUPS_STORE,
|
||||
afterFirstCmd: false,
|
||||
}
|
||||
)
|
||||
return result.groupList
|
||||
}
|
||||
}
|
||||
|
||||
async getGroupMembers(groupQQ: string, num = 3000): Promise<Map<string, GroupMember>> {
|
||||
async getGroupMembers(groupCode: string, num = 3000): Promise<Map<string, GroupMember>> {
|
||||
const session = getSession()
|
||||
let result: Awaited<ReturnType<NodeIKernelGroupService['getNextMemberList']>>
|
||||
if (session) {
|
||||
const groupService = session.getGroupService()
|
||||
const sceneId = groupService.createMemberListScene(groupQQ, 'groupMemberList_MainWindow')
|
||||
const sceneId = groupService.createMemberListScene(groupCode, 'groupMemberList_MainWindow')
|
||||
result = await groupService.getNextMemberList(sceneId, undefined, num)
|
||||
} else {
|
||||
const sceneId = await invoke<string>({
|
||||
methodName: NTMethod.GROUP_MEMBER_SCENE,
|
||||
args: [
|
||||
{
|
||||
groupCode: groupQQ,
|
||||
scene: 'groupMemberList_MainWindow',
|
||||
},
|
||||
],
|
||||
})
|
||||
result = await invoke<
|
||||
ReturnType<NodeIKernelGroupService['getNextMemberList']>
|
||||
>({
|
||||
methodName: NTMethod.GROUP_MEMBERS,
|
||||
args: [
|
||||
{
|
||||
sceneId,
|
||||
num,
|
||||
},
|
||||
null,
|
||||
],
|
||||
})
|
||||
const sceneId = await invoke(NTMethod.GROUP_MEMBER_SCENE, [{ groupCode, scene: 'groupMemberList_MainWindow' }])
|
||||
result = await invoke(NTMethod.GROUP_MEMBERS, [{ sceneId, num }, null])
|
||||
}
|
||||
if (result.errCode !== 0) {
|
||||
throw ('获取群成员列表出错,' + result.errMsg)
|
||||
@@ -144,16 +130,16 @@ export class NTQQGroupApi extends Service {
|
||||
)
|
||||
return notifies
|
||||
} else {
|
||||
invoke({
|
||||
methodName: ReceiveCmdS.GROUP_NOTIFY,
|
||||
classNameIsRegister: true,
|
||||
})
|
||||
return (await invoke<GroupNotifies>({
|
||||
methodName: NTMethod.GET_GROUP_NOTICE,
|
||||
cbCmd: ReceiveCmdS.GROUP_NOTIFY,
|
||||
afterFirstCmd: false,
|
||||
args: [{ doubt: false, startSeq: '', number: num }, null],
|
||||
})).notifies
|
||||
invoke(ReceiveCmdS.GROUP_NOTIFY, [], { classNameIsRegister: true })
|
||||
return (await invoke<GroupNotifies>(
|
||||
NTMethod.GET_GROUP_NOTICE,
|
||||
[{ doubt: false, startSeq: '', number: num }, null],
|
||||
{
|
||||
|
||||
cbCmd: ReceiveCmdS.GROUP_NOTIFY,
|
||||
afterFirstCmd: false,
|
||||
}
|
||||
)).notifies
|
||||
}
|
||||
}
|
||||
|
||||
@@ -176,152 +162,87 @@ export class NTQQGroupApi extends Service {
|
||||
}
|
||||
})
|
||||
} else {
|
||||
return await invoke({
|
||||
methodName: NTMethod.HANDLE_GROUP_REQUEST,
|
||||
args: [
|
||||
{
|
||||
doubt: false,
|
||||
operateMsg: {
|
||||
operateType,
|
||||
targetMsg: {
|
||||
seq,
|
||||
type,
|
||||
groupCode,
|
||||
postscript: reason || ' ' // 仅传空值可能导致处理失败,故默认给个空格
|
||||
},
|
||||
},
|
||||
return await invoke(NTMethod.HANDLE_GROUP_REQUEST, [{
|
||||
doubt: false,
|
||||
operateMsg: {
|
||||
operateType,
|
||||
targetMsg: {
|
||||
seq,
|
||||
type,
|
||||
groupCode,
|
||||
postscript: reason || ' ' // 仅传空值可能导致处理失败,故默认给个空格
|
||||
},
|
||||
null,
|
||||
],
|
||||
})
|
||||
},
|
||||
}, null])
|
||||
}
|
||||
}
|
||||
|
||||
async quitGroup(groupQQ: string) {
|
||||
async quitGroup(groupCode: string) {
|
||||
const session = getSession()
|
||||
if (session) {
|
||||
return session.getGroupService().quitGroup(groupQQ)
|
||||
return session.getGroupService().quitGroup(groupCode)
|
||||
} else {
|
||||
return await invoke({
|
||||
methodName: NTMethod.QUIT_GROUP,
|
||||
args: [{ groupCode: groupQQ }, null],
|
||||
})
|
||||
return await invoke(NTMethod.QUIT_GROUP, [{ groupCode }, null])
|
||||
}
|
||||
}
|
||||
|
||||
async kickMember(
|
||||
groupQQ: string,
|
||||
groupCode: string,
|
||||
kickUids: string[],
|
||||
refuseForever = false,
|
||||
kickReason = '',
|
||||
) {
|
||||
const session = getSession()
|
||||
if (session) {
|
||||
return session.getGroupService().kickMember(groupQQ, kickUids, refuseForever, kickReason)
|
||||
return session.getGroupService().kickMember(groupCode, kickUids, refuseForever, kickReason)
|
||||
} else {
|
||||
return await invoke({
|
||||
methodName: NTMethod.KICK_MEMBER,
|
||||
args: [
|
||||
{
|
||||
groupCode: groupQQ,
|
||||
kickUids,
|
||||
refuseForever,
|
||||
kickReason,
|
||||
},
|
||||
],
|
||||
})
|
||||
return await invoke(NTMethod.KICK_MEMBER, [{ groupCode, kickUids, refuseForever, kickReason }])
|
||||
}
|
||||
}
|
||||
|
||||
async banMember(groupQQ: string, memList: Array<{ uid: string, timeStamp: number }>) {
|
||||
async banMember(groupCode: string, memList: Array<{ uid: string, timeStamp: number }>) {
|
||||
// timeStamp为秒数, 0为解除禁言
|
||||
const session = getSession()
|
||||
if (session) {
|
||||
return session.getGroupService().setMemberShutUp(groupQQ, memList)
|
||||
return session.getGroupService().setMemberShutUp(groupCode, memList)
|
||||
} else {
|
||||
return await invoke({
|
||||
methodName: NTMethod.MUTE_MEMBER,
|
||||
args: [
|
||||
{
|
||||
groupCode: groupQQ,
|
||||
memList,
|
||||
},
|
||||
],
|
||||
})
|
||||
return await invoke(NTMethod.MUTE_MEMBER, [{ groupCode, memList }])
|
||||
}
|
||||
}
|
||||
|
||||
async banGroup(groupQQ: string, shutUp: boolean) {
|
||||
async banGroup(groupCode: string, shutUp: boolean) {
|
||||
const session = getSession()
|
||||
if (session) {
|
||||
return session.getGroupService().setGroupShutUp(groupQQ, shutUp)
|
||||
return session.getGroupService().setGroupShutUp(groupCode, shutUp)
|
||||
} else {
|
||||
return await invoke({
|
||||
methodName: NTMethod.MUTE_GROUP,
|
||||
args: [
|
||||
{
|
||||
groupCode: groupQQ,
|
||||
shutUp,
|
||||
},
|
||||
null,
|
||||
],
|
||||
})
|
||||
return await invoke(NTMethod.MUTE_GROUP, [{ groupCode, shutUp }, null])
|
||||
}
|
||||
}
|
||||
|
||||
async setMemberCard(groupQQ: string, memberUid: string, cardName: string) {
|
||||
async setMemberCard(groupCode: string, memberUid: string, cardName: string) {
|
||||
const session = getSession()
|
||||
if (session) {
|
||||
return session.getGroupService().modifyMemberCardName(groupQQ, memberUid, cardName)
|
||||
return session.getGroupService().modifyMemberCardName(groupCode, memberUid, cardName)
|
||||
} else {
|
||||
return await invoke({
|
||||
methodName: NTMethod.SET_MEMBER_CARD,
|
||||
args: [
|
||||
{
|
||||
groupCode: groupQQ,
|
||||
uid: memberUid,
|
||||
cardName,
|
||||
},
|
||||
null,
|
||||
],
|
||||
})
|
||||
return await invoke(NTMethod.SET_MEMBER_CARD, [{ groupCode, uid: memberUid, cardName }, null])
|
||||
}
|
||||
}
|
||||
|
||||
async setMemberRole(groupQQ: string, memberUid: string, role: GroupMemberRole) {
|
||||
async setMemberRole(groupCode: string, memberUid: string, role: GroupMemberRole) {
|
||||
const session = getSession()
|
||||
if (session) {
|
||||
return session.getGroupService().modifyMemberRole(groupQQ, memberUid, role)
|
||||
return session.getGroupService().modifyMemberRole(groupCode, memberUid, role)
|
||||
} else {
|
||||
return await invoke({
|
||||
methodName: NTMethod.SET_MEMBER_ROLE,
|
||||
args: [
|
||||
{
|
||||
groupCode: groupQQ,
|
||||
uid: memberUid,
|
||||
role,
|
||||
},
|
||||
null,
|
||||
],
|
||||
})
|
||||
return await invoke(NTMethod.SET_MEMBER_ROLE, [{ groupCode, uid: memberUid, role }, null])
|
||||
}
|
||||
}
|
||||
|
||||
async setGroupName(groupQQ: string, groupName: string) {
|
||||
async setGroupName(groupCode: string, groupName: string) {
|
||||
const session = getSession()
|
||||
if (session) {
|
||||
return session.getGroupService().modifyGroupName(groupQQ, groupName, false)
|
||||
return session.getGroupService().modifyGroupName(groupCode, groupName, false)
|
||||
} else {
|
||||
return await invoke({
|
||||
methodName: NTMethod.SET_GROUP_NAME,
|
||||
args: [
|
||||
{
|
||||
groupCode: groupQQ,
|
||||
groupName,
|
||||
},
|
||||
null,
|
||||
],
|
||||
})
|
||||
return await invoke(NTMethod.SET_GROUP_NAME, [{ groupCode, groupName }, null])
|
||||
}
|
||||
}
|
||||
|
||||
@@ -336,15 +257,7 @@ export class NTQQGroupApi extends Service {
|
||||
canNotAtAllMsg: ''
|
||||
}
|
||||
}
|
||||
>({
|
||||
methodName: NTMethod.GROUP_AT_ALL_REMAIN_COUNT,
|
||||
args: [
|
||||
{
|
||||
groupCode,
|
||||
},
|
||||
null,
|
||||
],
|
||||
})
|
||||
>(NTMethod.GROUP_AT_ALL_REMAIN_COUNT, [{ groupCode }, null])
|
||||
}
|
||||
|
||||
/** 27187 TODO */
|
||||
@@ -378,42 +291,14 @@ export class NTQQGroupApi extends Service {
|
||||
}
|
||||
|
||||
async createGroupFileFolder(groupId: string, folderName: string) {
|
||||
return await invoke({
|
||||
methodName: 'nodeIKernelRichMediaService/createGroupFolder',
|
||||
args: [
|
||||
{
|
||||
groupId,
|
||||
folderName
|
||||
},
|
||||
null,
|
||||
],
|
||||
})
|
||||
return await invoke('nodeIKernelRichMediaService/createGroupFolder', [{ groupId, folderName }, null])
|
||||
}
|
||||
|
||||
async deleteGroupFileFolder(groupId: string, folderId: string) {
|
||||
return await invoke({
|
||||
methodName: 'nodeIKernelRichMediaService/deleteGroupFolder',
|
||||
args: [
|
||||
{
|
||||
groupId,
|
||||
folderId
|
||||
},
|
||||
null,
|
||||
],
|
||||
})
|
||||
return await invoke('nodeIKernelRichMediaService/deleteGroupFolder', [{ groupId, folderId }, null])
|
||||
}
|
||||
|
||||
async deleteGroupFile(groupId: string, fileIdList: string[]) {
|
||||
return await invoke({
|
||||
methodName: 'nodeIKernelRichMediaService/deleteGroupFile',
|
||||
args: [
|
||||
{
|
||||
groupId,
|
||||
busIdList: [102],
|
||||
fileIdList
|
||||
},
|
||||
null,
|
||||
],
|
||||
})
|
||||
return await invoke('nodeIKernelRichMediaService/deleteGroupFile', [{ groupId, busIdList: [102], fileIdList }, null])
|
||||
}
|
||||
}
|
||||
|
@@ -1,5 +1,5 @@
|
||||
import { invoke, NTMethod } from '../ntcall'
|
||||
import { GeneralCallResult, TmpChatInfoApi } from '../services'
|
||||
import { GeneralCallResult } from '../services'
|
||||
import { RawMessage, SendMessageElement, Peer, ChatType2 } from '../types'
|
||||
import { getSession } from '@/ntqqapi/wrapper'
|
||||
import { NTEventDispatch } from '@/common/utils/eventTask'
|
||||
@@ -23,6 +23,8 @@ function generateMsgId() {
|
||||
}
|
||||
|
||||
export class NTQQMsgApi extends Service {
|
||||
static inject = ['ntUserApi']
|
||||
|
||||
constructor(protected ctx: Context) {
|
||||
super(ctx, 'ntMsgApi', true)
|
||||
}
|
||||
@@ -32,41 +34,20 @@ export class NTQQMsgApi extends Service {
|
||||
if (session) {
|
||||
return session.getMsgService().getTempChatInfo(chatType, peerUid)
|
||||
} else {
|
||||
return await invoke<TmpChatInfoApi>({
|
||||
methodName: 'nodeIKernelMsgService/getTempChatInfo',
|
||||
args: [
|
||||
{
|
||||
chatType,
|
||||
peerUid,
|
||||
},
|
||||
null,
|
||||
],
|
||||
})
|
||||
return await invoke('nodeIKernelMsgService/getTempChatInfo', [{ chatType, peerUid }, null])
|
||||
}
|
||||
}
|
||||
|
||||
async setEmojiLike(peer: Peer, msgSeq: string, emojiId: string, set: boolean = true) {
|
||||
async setEmojiLike(peer: Peer, msgSeq: string, emojiId: string, setEmoji: boolean = true) {
|
||||
// nt_qq//global//nt_data//Emoji//emoji-resource//sysface_res/apng/ 下可以看到所有QQ表情预览
|
||||
// nt_qq\global\nt_data\Emoji\emoji-resource\face_config.json 里面有所有表情的id, 自带表情id是QSid, 标准emoji表情id是QCid
|
||||
// 其实以官方文档为准是最好的,https://bot.q.qq.com/wiki/develop/api-v2/openapi/emoji/model.html#EmojiType
|
||||
emojiId = emojiId.toString()
|
||||
const session = getSession()
|
||||
const emojiType = emojiId.length > 3 ? '2' : '1'
|
||||
if (session) {
|
||||
return session.getMsgService().setMsgEmojiLikes(peer, msgSeq, emojiId, emojiId.length > 3 ? '2' : '1', set)
|
||||
return session.getMsgService().setMsgEmojiLikes(peer, msgSeq, emojiId, emojiType, setEmoji)
|
||||
} else {
|
||||
return await invoke({
|
||||
methodName: NTMethod.EMOJI_LIKE,
|
||||
args: [
|
||||
{
|
||||
peer,
|
||||
msgSeq,
|
||||
emojiId,
|
||||
emojiType: emojiId.length > 3 ? '2' : '1',
|
||||
setEmoji: set,
|
||||
},
|
||||
null,
|
||||
],
|
||||
})
|
||||
return await invoke(NTMethod.EMOJI_LIKE, [{ peer, msgSeq, emojiId, emojiType, setEmoji }, null])
|
||||
}
|
||||
}
|
||||
|
||||
@@ -75,33 +56,16 @@ export class NTQQMsgApi extends Service {
|
||||
if (session) {
|
||||
return session.getMsgService().getMultiMsg(peer, rootMsgId, parentMsgId)
|
||||
} else {
|
||||
return await invoke<GeneralCallResult & { msgList: RawMessage[] }>({
|
||||
methodName: NTMethod.GET_MULTI_MSG,
|
||||
args: [
|
||||
{
|
||||
peer,
|
||||
rootMsgId,
|
||||
parentMsgId,
|
||||
},
|
||||
null,
|
||||
],
|
||||
})
|
||||
return await invoke(NTMethod.GET_MULTI_MSG, [{ peer, rootMsgId, parentMsgId }, null])
|
||||
}
|
||||
}
|
||||
|
||||
async activateChat(peer: Peer) {
|
||||
return await invoke<GeneralCallResult>({
|
||||
methodName: NTMethod.ACTIVE_CHAT_PREVIEW,
|
||||
args: [{ peer, cnt: 20 }, null],
|
||||
})
|
||||
return await invoke<GeneralCallResult>(NTMethod.ACTIVE_CHAT_PREVIEW, [{ peer, cnt: 20 }, null])
|
||||
}
|
||||
|
||||
async activateChatAndGetHistory(peer: Peer) {
|
||||
return await invoke<GeneralCallResult>({
|
||||
methodName: NTMethod.ACTIVE_CHAT_HISTORY,
|
||||
// 参数似乎不是这样
|
||||
args: [{ peer, cnt: 20 }, null],
|
||||
})
|
||||
return await invoke<GeneralCallResult>(NTMethod.ACTIVE_CHAT_HISTORY, [{ peer, cnt: 20 }, null])
|
||||
}
|
||||
|
||||
async getMsgsByMsgId(peer: Peer | undefined, msgIds: string[] | undefined) {
|
||||
@@ -111,60 +75,26 @@ export class NTQQMsgApi extends Service {
|
||||
if (session) {
|
||||
return session.getMsgService().getMsgsByMsgId(peer, msgIds)
|
||||
} else {
|
||||
return await invoke<GeneralCallResult & {
|
||||
msgList: RawMessage[]
|
||||
}>({
|
||||
methodName: 'nodeIKernelMsgService/getMsgsByMsgId',
|
||||
args: [
|
||||
{
|
||||
peer,
|
||||
msgIds,
|
||||
},
|
||||
null,
|
||||
],
|
||||
})
|
||||
return await invoke('nodeIKernelMsgService/getMsgsByMsgId', [{ peer, msgIds }, null])
|
||||
}
|
||||
}
|
||||
|
||||
async getMsgHistory(peer: Peer, msgId: string, count: number, isReverseOrder: boolean = false) {
|
||||
async getMsgHistory(peer: Peer, msgId: string, cnt: number, isReverseOrder: boolean = false) {
|
||||
const session = getSession()
|
||||
// 消息时间从旧到新
|
||||
if (session) {
|
||||
return session.getMsgService().getMsgsIncludeSelf(peer, msgId, count, isReverseOrder)
|
||||
return session.getMsgService().getMsgsIncludeSelf(peer, msgId, cnt, isReverseOrder)
|
||||
} else {
|
||||
return await invoke<GeneralCallResult & { msgList: RawMessage[] }>({
|
||||
methodName: NTMethod.HISTORY_MSG,
|
||||
args: [
|
||||
{
|
||||
peer,
|
||||
msgId,
|
||||
cnt: count,
|
||||
queryOrder: isReverseOrder,
|
||||
},
|
||||
null,
|
||||
],
|
||||
})
|
||||
return await invoke(NTMethod.HISTORY_MSG, [{ peer, msgId, cnt, queryOrder: isReverseOrder }, null])
|
||||
}
|
||||
}
|
||||
|
||||
async recallMsg(peer: Peer, msgIds: string[]) {
|
||||
const session = getSession()
|
||||
if (session) {
|
||||
return session.getMsgService().recallMsg({
|
||||
chatType: peer.chatType,
|
||||
peerUid: peer.peerUid
|
||||
}, msgIds)
|
||||
return session.getMsgService().recallMsg(peer, msgIds)
|
||||
} else {
|
||||
return await invoke({
|
||||
methodName: NTMethod.RECALL_MSG,
|
||||
args: [
|
||||
{
|
||||
peer,
|
||||
msgIds,
|
||||
},
|
||||
null,
|
||||
],
|
||||
})
|
||||
return await invoke(NTMethod.RECALL_MSG, [{ peer, msgIds }, null])
|
||||
}
|
||||
}
|
||||
|
||||
@@ -196,19 +126,9 @@ export class NTQQMsgApi extends Service {
|
||||
)
|
||||
msgList = data[1]
|
||||
} else {
|
||||
const data = await invoke<{ msgList: RawMessage[] }>({
|
||||
methodName: 'nodeIKernelMsgService/sendMsg',
|
||||
cbCmd: 'nodeIKernelMsgListener/onMsgInfoListUpdate',
|
||||
afterFirstCmd: false,
|
||||
cmdCB: payload => {
|
||||
for (const msgRecord of payload.msgList) {
|
||||
if (msgRecord.guildId === msgId && msgRecord.sendStatus === 2) {
|
||||
return true
|
||||
}
|
||||
}
|
||||
return false
|
||||
},
|
||||
args: [
|
||||
const data = await invoke<{ msgList: RawMessage[] }>(
|
||||
'nodeIKernelMsgService/sendMsg',
|
||||
[
|
||||
{
|
||||
msgId: '0',
|
||||
peer,
|
||||
@@ -217,8 +137,20 @@ export class NTQQMsgApi extends Service {
|
||||
},
|
||||
null
|
||||
],
|
||||
timeout
|
||||
})
|
||||
{
|
||||
cbCmd: 'nodeIKernelMsgListener/onMsgInfoListUpdate',
|
||||
afterFirstCmd: false,
|
||||
cmdCB: payload => {
|
||||
for (const msgRecord of payload.msgList) {
|
||||
if (msgRecord.guildId === msgId && msgRecord.sendStatus === 2) {
|
||||
return true
|
||||
}
|
||||
}
|
||||
return false
|
||||
},
|
||||
timeout
|
||||
}
|
||||
)
|
||||
msgList = data.msgList
|
||||
}
|
||||
const retMsg = msgList.find(msgRecord => {
|
||||
@@ -234,19 +166,13 @@ export class NTQQMsgApi extends Service {
|
||||
if (session) {
|
||||
return session.getMsgService().forwardMsg(msgIds, srcPeer, [destPeer], [])
|
||||
} else {
|
||||
return await invoke<GeneralCallResult>({
|
||||
methodName: NTMethod.FORWARD_MSG,
|
||||
args: [
|
||||
{
|
||||
msgIds: msgIds,
|
||||
srcContact: srcPeer,
|
||||
dstContacts: [destPeer],
|
||||
commentElements: [],
|
||||
msgAttributeInfos: new Map(),
|
||||
},
|
||||
null,
|
||||
],
|
||||
})
|
||||
return await invoke<GeneralCallResult>(NTMethod.FORWARD_MSG, [{
|
||||
msgIds,
|
||||
srcContact: srcPeer,
|
||||
dstContacts: [destPeer],
|
||||
commentElements: [],
|
||||
msgAttributeInfos: new Map(),
|
||||
}, null])
|
||||
}
|
||||
}
|
||||
|
||||
@@ -282,19 +208,9 @@ export class NTQQMsgApi extends Service {
|
||||
)
|
||||
msgList = data[1]
|
||||
} else {
|
||||
const data = await invoke<{ msgList: RawMessage[] }>({
|
||||
methodName: 'nodeIKernelMsgService/multiForwardMsgWithComment',
|
||||
cbCmd: 'nodeIKernelMsgListener/onMsgInfoListUpdate',
|
||||
afterFirstCmd: false,
|
||||
cmdCB: payload => {
|
||||
for (const msgRecord of payload.msgList) {
|
||||
if (msgRecord.peerUid == destPeer.peerUid && msgRecord.senderUid == selfUid) {
|
||||
return true
|
||||
}
|
||||
}
|
||||
return false
|
||||
},
|
||||
args: [
|
||||
const data = await invoke<{ msgList: RawMessage[] }>(
|
||||
'nodeIKernelMsgService/multiForwardMsgWithComment',
|
||||
[
|
||||
{
|
||||
msgInfos,
|
||||
srcContact: srcPeer,
|
||||
@@ -304,7 +220,19 @@ export class NTQQMsgApi extends Service {
|
||||
},
|
||||
null,
|
||||
],
|
||||
})
|
||||
{
|
||||
cbCmd: 'nodeIKernelMsgListener/onMsgInfoListUpdate',
|
||||
afterFirstCmd: false,
|
||||
cmdCB: payload => {
|
||||
for (const msgRecord of payload.msgList) {
|
||||
if (msgRecord.peerUid == destPeer.peerUid && msgRecord.senderUid == selfUid) {
|
||||
return true
|
||||
}
|
||||
}
|
||||
return false
|
||||
},
|
||||
}
|
||||
)
|
||||
msgList = data.msgList
|
||||
}
|
||||
for (const msg of msgList) {
|
||||
@@ -323,25 +251,17 @@ export class NTQQMsgApi extends Service {
|
||||
throw new Error('转发消息超时')
|
||||
}
|
||||
|
||||
async getMsgsBySeqAndCount(peer: Peer, seq: string, count: number, desc: boolean, z: boolean) {
|
||||
async getMsgsBySeqAndCount(peer: Peer, msgSeq: string, count: number, desc: boolean, z: boolean) {
|
||||
const session = getSession()
|
||||
if (session) {
|
||||
return await session.getMsgService().getMsgsBySeqAndCount(peer, seq, count, desc, z)
|
||||
return await session.getMsgService().getMsgsBySeqAndCount(peer, msgSeq, count, desc, z)
|
||||
} else {
|
||||
return await invoke<GeneralCallResult & {
|
||||
msgList: RawMessage[]
|
||||
}>({
|
||||
methodName: 'nodeIKernelMsgService/getMsgsBySeqAndCount',
|
||||
args: [
|
||||
{
|
||||
peer,
|
||||
cnt: count,
|
||||
msgSeq: seq,
|
||||
queryOrder: desc
|
||||
},
|
||||
null,
|
||||
],
|
||||
})
|
||||
return await invoke('nodeIKernelMsgService/getMsgsBySeqAndCount', [{
|
||||
peer,
|
||||
cnt: count,
|
||||
msgSeq,
|
||||
queryOrder: desc
|
||||
}, null])
|
||||
}
|
||||
}
|
||||
|
||||
@@ -361,23 +281,12 @@ export class NTQQMsgApi extends Service {
|
||||
return ret
|
||||
}
|
||||
|
||||
async getSingleMsg(peer: Peer, seq: string) {
|
||||
async getSingleMsg(peer: Peer, msgSeq: string) {
|
||||
const session = getSession()
|
||||
if (session) {
|
||||
return await session.getMsgService().getSingleMsg(peer, seq)
|
||||
return await session.getMsgService().getSingleMsg(peer, msgSeq)
|
||||
} else {
|
||||
return await invoke<GeneralCallResult & {
|
||||
msgList: RawMessage[]
|
||||
}>({
|
||||
methodName: 'nodeIKernelMsgService/getSingleMsg',
|
||||
args: [
|
||||
{
|
||||
peer,
|
||||
msgSeq: seq,
|
||||
},
|
||||
null,
|
||||
],
|
||||
})
|
||||
return await invoke('nodeIKernelMsgService/getSingleMsg', [{ peer, msgSeq }, null])
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@@ -1,5 +1,4 @@
|
||||
import { invoke, NTMethod } from '../ntcall'
|
||||
import { GeneralCallResult } from '../services'
|
||||
import { User, UserDetailInfoByUin, UserDetailInfoByUinV2, UserDetailInfoListenerArg } from '../types'
|
||||
import { getBuildVersion } from '@/common/utils'
|
||||
import { getSession } from '@/ntqqapi/wrapper'
|
||||
@@ -18,21 +17,23 @@ declare module 'cordis' {
|
||||
}
|
||||
|
||||
export class NTQQUserApi extends Service {
|
||||
static inject = ['ntFriendApi']
|
||||
|
||||
constructor(protected ctx: Context) {
|
||||
super(ctx, 'ntUserApi', true)
|
||||
}
|
||||
|
||||
async setQQAvatar(filePath: string) {
|
||||
return await invoke<GeneralCallResult>({
|
||||
methodName: NTMethod.SET_QQ_AVATAR,
|
||||
args: [
|
||||
{
|
||||
path: filePath,
|
||||
},
|
||||
async setQQAvatar(path: string) {
|
||||
return await invoke(
|
||||
NTMethod.SET_QQ_AVATAR,
|
||||
[
|
||||
{ path },
|
||||
null,
|
||||
],
|
||||
timeout: 10 * Time.second, // 10秒不一定够
|
||||
})
|
||||
{
|
||||
timeout: 10 * Time.second, // 10秒不一定够
|
||||
}
|
||||
)
|
||||
}
|
||||
|
||||
async fetchUserDetailInfo(uid: string) {
|
||||
@@ -55,12 +56,9 @@ export class NTQQUserApi extends Service {
|
||||
)
|
||||
info = profile
|
||||
} else {
|
||||
const result = await invoke<{ info: UserDetailInfoListenerArg }>({
|
||||
methodName: 'nodeIKernelProfileService/fetchUserDetailInfo',
|
||||
cbCmd: 'nodeIKernelProfileListener/onUserDetailInfoChanged',
|
||||
afterFirstCmd: false,
|
||||
cmdCB: payload => payload.info.uid === uid,
|
||||
args: [
|
||||
const result = await invoke<{ info: UserDetailInfoListenerArg }>(
|
||||
'nodeIKernelProfileService/fetchUserDetailInfo',
|
||||
[
|
||||
{
|
||||
callFrom: 'BuddyProfileStore',
|
||||
uid: [uid],
|
||||
@@ -69,7 +67,12 @@ export class NTQQUserApi extends Service {
|
||||
},
|
||||
null
|
||||
],
|
||||
})
|
||||
{
|
||||
cbCmd: 'nodeIKernelProfileListener/onUserDetailInfoChanged',
|
||||
afterFirstCmd: false,
|
||||
cmdCB: payload => payload.info.uid === uid,
|
||||
}
|
||||
)
|
||||
info = result.info
|
||||
}
|
||||
const ret: User = {
|
||||
@@ -104,19 +107,21 @@ export class NTQQUserApi extends Service {
|
||||
)
|
||||
return profile
|
||||
} else {
|
||||
const result = await invoke<{ info: User }>({
|
||||
methodName: 'nodeIKernelProfileService/getUserDetailInfoWithBizInfo',
|
||||
cbCmd: 'nodeIKernelProfileListener/onProfileDetailInfoChanged',
|
||||
afterFirstCmd: false,
|
||||
cmdCB: (payload) => payload.info.uid === uid,
|
||||
args: [
|
||||
const result = await invoke<{ info: User }>(
|
||||
'nodeIKernelProfileService/getUserDetailInfoWithBizInfo',
|
||||
[
|
||||
{
|
||||
uid,
|
||||
bizList: [0]
|
||||
},
|
||||
null,
|
||||
],
|
||||
})
|
||||
{
|
||||
cbCmd: 'nodeIKernelProfileListener/onProfileDetailInfoChanged',
|
||||
afterFirstCmd: false,
|
||||
cmdCB: (payload) => payload.info.uid === uid,
|
||||
}
|
||||
)
|
||||
return result.info
|
||||
}
|
||||
}
|
||||
@@ -165,9 +170,9 @@ export class NTQQUserApi extends Service {
|
||||
doLikeTollCount: 0
|
||||
})
|
||||
} else {
|
||||
return await invoke<GeneralCallResult & { succCounts: number }>({
|
||||
methodName: 'nodeIKernelProfileLikeService/setBuddyProfileLike',
|
||||
args: [
|
||||
return await invoke(
|
||||
'nodeIKernelProfileLikeService/setBuddyProfileLike',
|
||||
[
|
||||
{
|
||||
doLikeUserInfo: {
|
||||
friendUid: uid,
|
||||
@@ -178,7 +183,7 @@ export class NTQQUserApi extends Service {
|
||||
},
|
||||
null,
|
||||
],
|
||||
})
|
||||
)
|
||||
}
|
||||
}
|
||||
|
||||
@@ -205,32 +210,11 @@ export class NTQQUserApi extends Service {
|
||||
uid = (await session.getUixConvertService().getUid([uin])).uidInfo.get(uin)
|
||||
if (uid) return uid
|
||||
} else {
|
||||
let uid = (await invoke<{ uids: Map<string, string> }>({
|
||||
methodName: 'nodeIKernelGroupService/getUidByUins',
|
||||
args: [
|
||||
{ uin: [uin] },
|
||||
null,
|
||||
],
|
||||
})).uids.get(uin)
|
||||
let uid = (await invoke('nodeIKernelGroupService/getUidByUins', [{ uin: [uin] }, null])).uids.get(uin)
|
||||
if (uid) return uid
|
||||
uid = (await invoke<Map<string, string>>({
|
||||
methodName: 'nodeIKernelProfileService/getUidByUin',
|
||||
args: [
|
||||
{
|
||||
callFrom: 'FriendsServiceImpl',
|
||||
uin: [uin],
|
||||
},
|
||||
null,
|
||||
],
|
||||
})).get(uin)
|
||||
uid = (await invoke('nodeIKernelProfileService/getUidByUin', [{ callFrom: 'FriendsServiceImpl', uin: [uin] }, null])).get(uin)
|
||||
if (uid) return uid
|
||||
uid = (await invoke<{ uidInfo: Map<string, string> }>({
|
||||
methodName: 'nodeIKernelUixConvertService/getUid',
|
||||
args: [
|
||||
{ uin: [uin] },
|
||||
null,
|
||||
],
|
||||
})).uidInfo.get(uin)
|
||||
uid = (await invoke('nodeIKernelUixConvertService/getUid', [{ uin: [uin] }, null])).uidInfo.get(uin)
|
||||
if (uid) return uid
|
||||
}
|
||||
const unveifyUid = (await this.getUserDetailInfoByUinV2(uin)).detail.uid //从QQ Native 特殊转换
|
||||
@@ -253,13 +237,13 @@ export class NTQQUserApi extends Service {
|
||||
uin
|
||||
)
|
||||
} else {
|
||||
return await invoke<UserDetailInfoByUinV2>({
|
||||
methodName: 'nodeIKernelProfileService/getUserDetailInfoByUin',
|
||||
args: [
|
||||
return await invoke<UserDetailInfoByUinV2>(
|
||||
'nodeIKernelProfileService/getUserDetailInfoByUin',
|
||||
[
|
||||
{ uin },
|
||||
null,
|
||||
],
|
||||
})
|
||||
)
|
||||
}
|
||||
}
|
||||
|
||||
@@ -295,39 +279,18 @@ export class NTQQUserApi extends Service {
|
||||
if (uin) return uin
|
||||
uin = (await session.getUixConvertService().getUin([uid])).uinInfo.get(uid)
|
||||
if (uin) return uin
|
||||
return uin
|
||||
} else {
|
||||
let uin = (await invoke<{ uins: Map<string, string> }>({
|
||||
methodName: 'nodeIKernelGroupService/getUinByUids',
|
||||
args: [
|
||||
{ uid: [uid] },
|
||||
null,
|
||||
],
|
||||
})).uins.get(uid)
|
||||
let uin = (await invoke('nodeIKernelGroupService/getUinByUids', [{ uid: [uid] }, null])).uins.get(uid)
|
||||
if (uin) return uin
|
||||
uin = (await invoke<Map<string, string>>({
|
||||
methodName: 'nodeIKernelProfileService/getUinByUid',
|
||||
args: [
|
||||
{
|
||||
callFrom: 'FriendsServiceImpl',
|
||||
uid: [uid],
|
||||
},
|
||||
null,
|
||||
],
|
||||
})).get(uid)
|
||||
uin = (await invoke('nodeIKernelProfileService/getUinByUid', [{ callFrom: 'FriendsServiceImpl', uid: [uid] }, null])).get(uid)
|
||||
if (uin) return uin
|
||||
uin = (await invoke<{ uinInfo: Map<string, string> }>({
|
||||
methodName: 'nodeIKernelUixConvertService/getUin',
|
||||
args: [
|
||||
{ uid: [uid] },
|
||||
null,
|
||||
],
|
||||
})).uinInfo.get(uid)
|
||||
uin = (await invoke('nodeIKernelUixConvertService/getUin', [{ uid: [uid] }, null])).uinInfo.get(uid)
|
||||
if (uin) return uin
|
||||
}
|
||||
let uin = (await this.ctx.ntFriendApi.getBuddyIdMap(true)).getKey(uid)
|
||||
if (uin) return uin
|
||||
uin = (await this.getUserDetailInfo(uid)).uin //从QQ Native 转换
|
||||
return uin
|
||||
}
|
||||
|
||||
async getUinByUid(Uid: string) {
|
||||
@@ -342,12 +305,7 @@ export class NTQQUserApi extends Service {
|
||||
if (session) {
|
||||
return await session.getTicketService().forceFetchClientKey('')
|
||||
} else {
|
||||
return await invoke<forceFetchClientKeyRetType>({
|
||||
methodName: 'nodeIKernelTicketService/forceFetchClientKey',
|
||||
args: [{
|
||||
domain: ''
|
||||
}, null],
|
||||
})
|
||||
return await invoke('nodeIKernelTicketService/forceFetchClientKey', [{ domain: '' }, null])
|
||||
}
|
||||
}
|
||||
|
||||
|
@@ -125,6 +125,8 @@ export interface GroupEssenceMsgRet {
|
||||
}
|
||||
|
||||
export class NTQQWebApi extends Service {
|
||||
static inject = ['ntUserApi']
|
||||
|
||||
constructor(protected ctx: Context) {
|
||||
super(ctx, 'ntWebApi', true)
|
||||
}
|
||||
|
@@ -42,13 +42,15 @@ export class NTQQWindowApi extends Service {
|
||||
cbCmd: ReceiveCmd | undefined,
|
||||
autoCloseSeconds: number = 2,
|
||||
) {
|
||||
const result = await invoke<R>({
|
||||
className: NTClass.WINDOW_API,
|
||||
methodName: NTMethod.OPEN_EXTRA_WINDOW,
|
||||
cbCmd,
|
||||
afterFirstCmd: false,
|
||||
args: [ntQQWindow.windowName, ...args],
|
||||
})
|
||||
const result = await invoke<R>(
|
||||
NTMethod.OPEN_EXTRA_WINDOW,
|
||||
[ntQQWindow.windowName, ...args],
|
||||
{
|
||||
className: NTClass.WINDOW_API,
|
||||
cbCmd,
|
||||
afterFirstCmd: false,
|
||||
}
|
||||
)
|
||||
setTimeout(() => {
|
||||
for (const w of BrowserWindow.getAllWindows()) {
|
||||
// log("close window", w.webContents.getURL())
|
||||
|
@@ -2,7 +2,20 @@ import { ipcMain } from 'electron'
|
||||
import { hookApiCallbacks, registerReceiveHook, removeReceiveHook } from './hook'
|
||||
import { log } from '../common/utils/legacyLog'
|
||||
import { randomUUID } from 'node:crypto'
|
||||
import { GeneralCallResult } from './services'
|
||||
import {
|
||||
GeneralCallResult,
|
||||
NodeIKernelBuddyService,
|
||||
NodeIKernelProfileService,
|
||||
NodeIKernelGroupService,
|
||||
NodeIKernelProfileLikeService,
|
||||
NodeIKernelMsgService,
|
||||
NodeIKernelMSFService,
|
||||
NodeIKernelUixConvertService,
|
||||
NodeIKernelRichMediaService,
|
||||
NodeIKernelTicketService,
|
||||
NodeIKernelTipOffService,
|
||||
NodeIKernelSearchService,
|
||||
} from './services'
|
||||
|
||||
export enum NTClass {
|
||||
NT_API = 'ns-ntApi',
|
||||
@@ -95,35 +108,52 @@ export enum NTChannel {
|
||||
IPC_UP_4 = 'IPC_UP_4'
|
||||
}
|
||||
|
||||
interface InvokeParams<ReturnType> {
|
||||
methodName: string
|
||||
interface NTService {
|
||||
nodeIKernelBuddyService: NodeIKernelBuddyService
|
||||
nodeIKernelProfileService: NodeIKernelProfileService
|
||||
nodeIKernelGroupService: NodeIKernelGroupService
|
||||
nodeIKernelProfileLikeService: NodeIKernelProfileLikeService
|
||||
nodeIKernelMsgService: NodeIKernelMsgService
|
||||
nodeIKernelMSFService: NodeIKernelMSFService
|
||||
nodeIKernelUixConvertService: NodeIKernelUixConvertService
|
||||
nodeIKernelRichMediaService: NodeIKernelRichMediaService
|
||||
nodeIKernelTicketService: NodeIKernelTicketService
|
||||
nodeIKernelTipOffService: NodeIKernelTipOffService
|
||||
nodeIKernelSearchService: NodeIKernelSearchService
|
||||
}
|
||||
|
||||
interface InvokeOptions<ReturnType> {
|
||||
className?: NTClass
|
||||
channel?: NTChannel
|
||||
classNameIsRegister?: boolean
|
||||
args?: unknown[]
|
||||
cbCmd?: string | string[]
|
||||
cmdCB?: (payload: ReturnType) => boolean
|
||||
afterFirstCmd?: boolean // 是否在methodName调用完之后再去hook cbCmd
|
||||
timeout?: number
|
||||
}
|
||||
|
||||
export function invoke<ReturnType>(params: InvokeParams<ReturnType>) {
|
||||
const className = params.className ?? NTClass.NT_API
|
||||
const channel = params.channel ?? NTChannel.IPC_UP_2
|
||||
const timeout = params.timeout ?? 5000
|
||||
const afterFirstCmd = params.afterFirstCmd ?? true
|
||||
export function invoke<
|
||||
R extends Awaited<ReturnType<NTService[S][M] extends (...args: any) => any ? NTService[S][M] : any>>,
|
||||
S extends keyof NTService = any,
|
||||
M extends keyof NTService[S] & string = any,
|
||||
O = string
|
||||
>(method: `${O extends `${S}/${M}` ? `${S}/${M}` : string}`, args?: unknown[], options?: InvokeOptions<R>) {
|
||||
const className = options?.className ?? NTClass.NT_API
|
||||
const channel = options?.channel ?? NTChannel.IPC_UP_2
|
||||
const timeout = options?.timeout ?? 5000
|
||||
const afterFirstCmd = options?.afterFirstCmd ?? true
|
||||
const uuid = randomUUID()
|
||||
let eventName = className + '-' + channel[channel.length - 1]
|
||||
if (params.classNameIsRegister) {
|
||||
if (options?.classNameIsRegister) {
|
||||
eventName += '-register'
|
||||
}
|
||||
const apiArgs = [params.methodName, ...(params.args ?? [])]
|
||||
const apiArgs = [method, ...(args ?? [])]
|
||||
//log('callNTQQApi', channel, eventName, apiArgs, uuid)
|
||||
return new Promise((resolve: (data: ReturnType) => void, reject) => {
|
||||
return new Promise((resolve: (data: R) => void, reject) => {
|
||||
let success = false
|
||||
if (!params.cbCmd) {
|
||||
if (!options?.cbCmd) {
|
||||
// QQ后端会返回结果,并且可以根据uuid识别
|
||||
hookApiCallbacks[uuid] = (r: ReturnType) => {
|
||||
hookApiCallbacks[uuid] = (r: R) => {
|
||||
success = true
|
||||
resolve(r)
|
||||
}
|
||||
@@ -131,10 +161,10 @@ export function invoke<ReturnType>(params: InvokeParams<ReturnType>) {
|
||||
else {
|
||||
// 这里的callback比较特殊,QQ后端先返回是否调用成功,再返回一条结果数据
|
||||
const secondCallback = () => {
|
||||
const hookId = registerReceiveHook<ReturnType>(params.cbCmd!, (payload) => {
|
||||
const hookId = registerReceiveHook<R>(options.cbCmd!, (payload) => {
|
||||
// log(methodName, "second callback", cbCmd, payload, cmdCB);
|
||||
if (!!params.cmdCB) {
|
||||
if (params.cmdCB(payload)) {
|
||||
if (!!options.cmdCB) {
|
||||
if (options.cmdCB(payload)) {
|
||||
removeReceiveHook(hookId)
|
||||
success = true
|
||||
resolve(payload)
|
||||
@@ -154,15 +184,15 @@ export function invoke<ReturnType>(params: InvokeParams<ReturnType>) {
|
||||
afterFirstCmd && secondCallback()
|
||||
}
|
||||
else {
|
||||
log('ntqq api call failed,', params.methodName, result)
|
||||
reject(`ntqq api call failed, ${params.methodName}, ${result.errMsg}`)
|
||||
log('ntqq api call failed,', method, result)
|
||||
reject(`ntqq api call failed, ${method}, ${result.errMsg}`)
|
||||
}
|
||||
}
|
||||
}
|
||||
setTimeout(() => {
|
||||
if (!success) {
|
||||
log(`ntqq api timeout ${channel}, ${eventName}, ${params.methodName}`, apiArgs)
|
||||
reject(`ntqq api timeout ${channel}, ${eventName}, ${params.methodName}, ${apiArgs}`)
|
||||
log(`ntqq api timeout ${channel}, ${eventName}, ${method}`, apiArgs)
|
||||
reject(`ntqq api timeout ${channel}, ${eventName}, ${method}, ${apiArgs}`)
|
||||
}
|
||||
}, timeout)
|
||||
|
||||
|
@@ -110,8 +110,6 @@ export interface NodeIKernelMsgService {
|
||||
|
||||
resendMsg(...args: unknown[]): unknown
|
||||
|
||||
recallMsg(...args: unknown[]): unknown
|
||||
|
||||
reeditRecallMsg(...args: unknown[]): unknown
|
||||
//调用请检查除开commentElements其余参数不能为null
|
||||
forwardMsg(msgIds: string[], srcContact: Peer, dstContacts: Peer[], commentElements: MessageElement[]): Promise<GeneralCallResult>
|
||||
|
@@ -74,7 +74,7 @@ export interface NodeIKernelProfileService {
|
||||
|
||||
setGander(...args: unknown[]): Promise<unknown>
|
||||
|
||||
setHeader(arg: string): Promise<unknown>
|
||||
setHeader(arg: string): Promise<GeneralCallResult>
|
||||
|
||||
setRecommendImgFlag(...args: unknown[]): Promise<unknown>
|
||||
|
||||
|
@@ -173,8 +173,6 @@ export interface NodeIKernelRichMediaService {
|
||||
|
||||
downloadFile(commonFile: CommonFileInfo, arg2: unknown, arg3: unknown, savePath: string): unknown
|
||||
|
||||
createGroupFolder(arg1: unknown, arg2: unknown): unknown
|
||||
|
||||
downloadGroupFolder(arg1: unknown, arg2: unknown, arg3: unknown): unknown
|
||||
|
||||
renameGroupFolder(arg1: unknown, arg2: unknown, arg3: unknown): unknown
|
||||
|
Reference in New Issue
Block a user