Merge pull request #472 from pohgxz/main

完善<set_input_status>接口
This commit is contained in:
手瓜一十雪 2024-10-29 10:53:29 +08:00 committed by GitHub
commit 88de57f984
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
3 changed files with 27 additions and 32 deletions

View File

@ -18,7 +18,7 @@ export class NTQQUserApi {
async getStatusByUid(uid: string) { async getStatusByUid(uid: string) {
return this.context.session.getProfileService().getStatus(uid); return this.context.session.getProfileService().getStatus(uid);
} }
async getProfileLike(uid: string) { async getProfileLike(uid: string, start: number, count: number) {
return this.context.session.getProfileLikeService().getBuddyProfileLike({ return this.context.session.getProfileLikeService().getBuddyProfileLike({
friendUids: [uid], friendUids: [uid],
basic: 1, basic: 1,
@ -26,8 +26,8 @@ export class NTQQUserApi {
favorite: 0, favorite: 0,
userProfile: 1, userProfile: 1,
type: 2, type: 2,
start: 0, start: start,
limit: 20, limit: count,
}); });
} }
async fetchOtherProfileLike(uid: string) { async fetchOtherProfileLike(uid: string) {

View File

@ -1,15 +1,22 @@
import BaseAction from '../BaseAction'; import BaseAction from '../BaseAction';
import { ActionName } from '../types'; import { ActionName, BaseCheckResult } from '../types';
export class GetProfileLike extends BaseAction<void, any> { interface Payload {
start: number,
count: number
}
export class GetProfileLike extends BaseAction<Payload, any> {
actionName = ActionName.GetProfileLike; actionName = ActionName.GetProfileLike;
async _handle(payload: void) { async _handle(payload: Payload) {
const ret = await this.core.apis.UserApi.getProfileLike(this.core.selfInfo.uid); const start = payload.start ? Number(payload.start) : 0;
const listdata: any[] = ret.info.userLikeInfos[0].favoriteInfo.userInfos; const count = payload.count ? Number(payload.count) : 10;
const ret = await this.core.apis.UserApi.getProfileLike(this.core.selfInfo.uid, start, count);
const listdata: any[] = ret.info.userLikeInfos[0].voteInfo.userInfos;
for (let i = 0; i < listdata.length; i++) { for (let i = 0; i < listdata.length; i++) {
listdata[i].uin = parseInt((await this.core.apis.UserApi.getUinByUidV2(listdata[i].uid)) || ''); listdata[i].uin = parseInt((await this.core.apis.UserApi.getUinByUidV2(listdata[i].uid)) || '');
} }
return listdata; return ret.info.userLikeInfos[0].voteInfo;
} }
} }

View File

@ -1,16 +1,15 @@
import { FromSchema, JSONSchema } from 'json-schema-to-ts'; import { FromSchema, JSONSchema } from 'json-schema-to-ts';
import BaseAction from '../BaseAction'; import BaseAction from '../BaseAction';
import { ActionName } from '../types'; import { ActionName, BaseCheckResult } from '../types';
import { ChatType, Peer } from '@/core'; import { ChatType, Peer } from '@/core';
const SchemaData = { const SchemaData = {
type: 'object', type: 'object',
properties: { properties: {
eventType: { type: 'string' }, event_type: { type: 'number' },
group_id: { type: 'string' }, user_id: { type: ['number', 'string'] },
user_id: { type: 'string' },
}, },
required: ['eventType'], required: ['event_type','user_id'],
} as const satisfies JSONSchema; } as const satisfies JSONSchema;
type Payload = FromSchema<typeof SchemaData>; type Payload = FromSchema<typeof SchemaData>;
@ -19,23 +18,12 @@ export class SetInputStatus extends BaseAction<Payload, any> {
actionName = ActionName.SetInputStatus; actionName = ActionName.SetInputStatus;
async _handle(payload: Payload) { async _handle(payload: Payload) {
let peer: Peer; const uid = await this.core.apis.UserApi.getUidByUinV2(payload.user_id.toString());
if (payload.group_id) {
peer = {
chatType: ChatType.KCHATTYPEGROUP,
peerUid: payload.group_id,
};
} else if (payload.user_id) {
const uid = await this.core.apis.UserApi.getUidByUinV2(payload.user_id);
if (!uid) throw new Error('uid is empty'); if (!uid) throw new Error('uid is empty');
peer = { const peer = {
chatType: ChatType.KCHATTYPEC2C, chatType: ChatType.KCHATTYPEC2C,
peerUid: uid, peerUid: uid,
}; };
} else { return await this.core.apis.MsgApi.sendShowInputStatusReq(peer, payload.event_type);
throw new Error('请指定 group_id 或 user_id');
}
return await this.core.apis.MsgApi.sendShowInputStatusReq(peer, parseInt(payload.eventType));
} }
} }