mirror of
https://github.com/LLOneBot/LLOneBot.git
synced 2024-11-22 01:56:33 +00:00
feat
This commit is contained in:
parent
f68b707e1c
commit
5217638b46
@ -236,7 +236,7 @@ export class NTQQFileCacheApi extends Service {
|
||||
}
|
||||
|
||||
scanCache() {
|
||||
invoke<GeneralCallResult>(ReceiveCmdS.CACHE_SCAN_FINISH, [], { classNameIsRegister: true })
|
||||
invoke<GeneralCallResult>(ReceiveCmdS.CACHE_SCAN_FINISH, [], { registerEvent: true })
|
||||
return invoke<CacheScanResult>(NTMethod.CACHE_SCAN, [null, null], { timeout: 300 * Time.second })
|
||||
}
|
||||
|
||||
|
@ -7,7 +7,8 @@ import {
|
||||
GroupRequestOperateTypes,
|
||||
GetFileListParam,
|
||||
OnGroupFileInfoUpdateParams,
|
||||
PublishGroupBulletinReq
|
||||
PublishGroupBulletinReq,
|
||||
GroupAllInfo
|
||||
} from '../types'
|
||||
import { invoke, NTClass, NTMethod } from '../ntcall'
|
||||
import { GeneralCallResult } from '../services'
|
||||
@ -104,7 +105,7 @@ export class NTQQGroupApi extends Service {
|
||||
}
|
||||
|
||||
async getSingleScreenNotifies(num: number) {
|
||||
invoke(ReceiveCmdS.GROUP_NOTIFY, [], { classNameIsRegister: true })
|
||||
invoke(ReceiveCmdS.GROUP_NOTIFY, [], { registerEvent: true })
|
||||
return (await invoke<GroupNotifies>(
|
||||
'nodeIKernelGroupService/getSingleScreenNotifies',
|
||||
[{ doubt: false, startSeq: '', number: num }, null],
|
||||
@ -272,7 +273,7 @@ export class NTQQGroupApi extends Service {
|
||||
}
|
||||
|
||||
async getGroupFileList(groupId: string, fileListForm: GetFileListParam) {
|
||||
invoke('nodeIKernelMsgListener/onGroupFileInfoUpdate', [], { classNameIsRegister: true })
|
||||
invoke('nodeIKernelMsgListener/onGroupFileInfoUpdate', [], { registerEvent: true })
|
||||
const data = await invoke<{ fileInfo: OnGroupFileInfoUpdateParams }>(
|
||||
'nodeIKernelRichMediaService/getGroupFileList',
|
||||
[
|
||||
@ -326,4 +327,24 @@ export class NTQQGroupApi extends Service {
|
||||
}
|
||||
}, null])
|
||||
}
|
||||
|
||||
async getGroupAllInfo(groupCode: string, timeout = 1000) {
|
||||
invoke('nodeIKernelGroupListener/onGroupAllInfoChange', [], { registerEvent: true })
|
||||
return await invoke<{ groupAll: GroupAllInfo }>(
|
||||
'nodeIKernelGroupService/getGroupAllInfo',
|
||||
[
|
||||
{
|
||||
groupCode,
|
||||
source: 4
|
||||
},
|
||||
null
|
||||
],
|
||||
{
|
||||
cbCmd: 'nodeIKernelGroupListener/onGroupAllInfoChange',
|
||||
afterFirstCmd: false,
|
||||
cmdCB: payload => payload.groupAll.groupCode === groupCode,
|
||||
timeout
|
||||
}
|
||||
)
|
||||
}
|
||||
}
|
||||
|
@ -215,7 +215,7 @@ class Core extends Service {
|
||||
this.ctx.parallel('nt/friend-request', payload.data.buddyReqs)
|
||||
})
|
||||
|
||||
invoke('nodeIKernelMsgListener/onRecvSysMsg', [], { classNameIsRegister: true })
|
||||
invoke('nodeIKernelMsgListener/onRecvSysMsg', [], { registerEvent: true })
|
||||
|
||||
registerReceiveHook<{
|
||||
msgBuf: number[]
|
||||
|
@ -98,7 +98,7 @@ interface NTService {
|
||||
interface InvokeOptions<ReturnType> {
|
||||
className?: NTClass
|
||||
channel?: NTChannel
|
||||
classNameIsRegister?: boolean
|
||||
registerEvent?: boolean
|
||||
cbCmd?: string | string[]
|
||||
cmdCB?: (payload: ReturnType, result: unknown) => boolean
|
||||
afterFirstCmd?: boolean // 是否在methodName调用完之后再去hook cbCmd
|
||||
@ -115,7 +115,7 @@ export function invoke<
|
||||
const timeout = options.timeout ?? 5000
|
||||
const afterFirstCmd = options.afterFirstCmd ?? true
|
||||
let eventName = className + '-' + channel[channel.length - 1]
|
||||
if (options.classNameIsRegister) {
|
||||
if (options.registerEvent) {
|
||||
eventName += '-register'
|
||||
}
|
||||
return new Promise<R>((resolve, reject) => {
|
||||
|
@ -78,3 +78,45 @@ export interface PublishGroupBulletinReq {
|
||||
pinned: number
|
||||
confirmRequired: number
|
||||
}
|
||||
|
||||
export interface GroupAllInfo {
|
||||
groupCode: string
|
||||
ownerUid: string
|
||||
groupFlag: number
|
||||
groupFlagExt: number
|
||||
maxMemberNum: number
|
||||
memberNum: number
|
||||
groupOption: number
|
||||
classExt: number
|
||||
groupName: string
|
||||
fingerMemo: string
|
||||
groupQuestion: string
|
||||
certType: number
|
||||
shutUpAllTimestamp: number
|
||||
shutUpMeTimestamp: number //解除禁言时间
|
||||
groupTypeFlag: number
|
||||
privilegeFlag: number
|
||||
groupSecLevel: number
|
||||
groupFlagExt3: number
|
||||
isConfGroup: number
|
||||
isModifyConfGroupFace: number
|
||||
isModifyConfGroupName: number
|
||||
noFigerOpenFlag: number
|
||||
noCodeFingerOpenFlag: number
|
||||
groupFlagExt4: number
|
||||
groupMemo: string
|
||||
cmdUinMsgSeq: number
|
||||
cmdUinJoinTime: number
|
||||
cmdUinUinFlag: number
|
||||
cmdUinMsgMask: number
|
||||
groupSecLevelInfo: number
|
||||
cmdUinPrivilege: number
|
||||
cmdUinFlagEx2: number
|
||||
appealDeadline: number
|
||||
remarkName: number
|
||||
isTop: boolean
|
||||
richFingerMemo: string
|
||||
groupAnswer: string
|
||||
joinGroupAuth: string
|
||||
isAllowModifyConfGroupName: number
|
||||
}
|
||||
|
@ -436,7 +436,7 @@ export namespace OB11Entities {
|
||||
}
|
||||
}
|
||||
else if (groupElement.type === TipGroupElementType.Ban) {
|
||||
ctx.logger.info('收到群群员禁言提示', groupElement)
|
||||
ctx.logger.info('收到群成员禁言提示', groupElement)
|
||||
const memberUid = groupElement.shutUp?.member.uid
|
||||
const adminUid = groupElement.shutUp?.admin.uid
|
||||
let memberUin: string = ''
|
||||
|
@ -248,8 +248,16 @@ export async function sendMsg(
|
||||
sendElements: SendMessageElement[],
|
||||
deleteAfterSentFiles: string[]
|
||||
) {
|
||||
if (peer.chatType === ChatType.Group) {
|
||||
const info = await ctx.ntGroupApi.getGroupAllInfo(peer.peerUid)
|
||||
.catch(() => undefined)
|
||||
const shutUpMeTimestamp = info?.groupAll.shutUpMeTimestamp
|
||||
if (shutUpMeTimestamp && shutUpMeTimestamp * 1000 > Date.now()) {
|
||||
throw new Error('当前处于被禁言状态')
|
||||
}
|
||||
}
|
||||
if (!sendElements.length) {
|
||||
throw '消息体无法解析,请检查是否发送了不支持的消息类型'
|
||||
throw new Error('消息体无法解析,请检查是否发送了不支持的消息类型')
|
||||
}
|
||||
// 计算发送的文件大小
|
||||
let totalSize = 0
|
||||
|
Loading…
x
Reference in New Issue
Block a user