Files
NapCatQQ/packages/napcat-satori/action/user/FriendApprove.ts
手瓜一十雪 b0d88d3705 Refactor Satori actions with schema validation and router
Refactored all Satori action classes to use TypeBox schemas for payload validation and unified action naming via a new router. Added schema-based parameter checking to the SatoriAction base class. Introduced new actions for guild and member approval, and login retrieval. Centralized action name constants and types in a new router module. Enhanced event and message APIs with more structured event types and parsing logic. Added helper utilities for XML parsing. Updated exports and registration logic to support the new structure.
2026-01-14 17:52:38 +08:00

32 lines
1.0 KiB
TypeScript

import { Static, Type } from '@sinclair/typebox';
import { SatoriAction } from '../SatoriAction';
import { SatoriActionName } from '../router';
const SchemaData = Type.Object({
message_id: Type.String(),
approve: Type.Boolean(),
comment: Type.Optional(Type.String()),
});
type Payload = Static<typeof SchemaData>;
export class FriendApproveAction extends SatoriAction<Payload, void> {
actionName = SatoriActionName.FriendApprove;
override payloadSchema = SchemaData;
protected async _handle (payload: Payload): Promise<void> {
const { message_id, approve } = payload;
// message_id 格式: reqTime (好友请求的时间戳)
// 需要从好友请求列表中找到对应的请求
const buddyReqData = await this.core.apis.FriendApi.getBuddyReq();
const notify = buddyReqData.buddyReqs.find((e) => e.reqTime === message_id);
if (!notify) {
throw new Error(`未找到好友请求: ${message_id}`);
}
await this.core.apis.FriendApi.handleFriendRequest(notify, approve);
}
}