mirror of
https://github.com/NapNeko/NapCatQQ.git
synced 2025-12-31 06:29:02 +08:00
62 lines
2.2 KiB
TypeScript
62 lines
2.2 KiB
TypeScript
import BaseAction from '../BaseAction';
|
||
import { ActionName, BaseCheckResult } from '../types';
|
||
import * as fs from 'node:fs';
|
||
import { checkFileReceived, uri2local } from '@/common/utils/file';
|
||
|
||
// import { log } from "../../../common/utils";
|
||
|
||
interface Payload {
|
||
file: string,
|
||
groupCode: string
|
||
}
|
||
|
||
export default class SetGroupHeader extends BaseAction<Payload, any> {
|
||
actionName = ActionName.SetGroupHeader;
|
||
|
||
// 用不着复杂检测
|
||
protected async check(payload: Payload): Promise<BaseCheckResult> {
|
||
if (!payload.file || typeof payload.file != 'string' || !payload.groupCode || typeof payload.groupCode != 'string') {
|
||
return {
|
||
valid: false,
|
||
message: 'file和groupCode字段不能为空或者类型错误',
|
||
};
|
||
}
|
||
return {
|
||
valid: true,
|
||
};
|
||
}
|
||
|
||
async _handle(payload: Payload): Promise<any> {
|
||
const NTQQGroupApi = this.CoreContext.apis.GroupApi;
|
||
const { path, isLocal, errMsg, success } = (await uri2local(this.CoreContext.NapCatTempPath, payload.file));
|
||
if (!success) {
|
||
throw `头像${payload.file}设置失败,file字段可能格式不正确`;
|
||
}
|
||
if (path) {
|
||
await checkFileReceived(path, 5000); // 文件不存在QQ会崩溃,需要提前判断
|
||
const ret = await NTQQGroupApi.setGroupAvatar(payload.groupCode, path);
|
||
if (!isLocal) {
|
||
fs.unlink(path, () => {
|
||
});
|
||
}
|
||
if (!ret) {
|
||
throw `头像${payload.file}设置失败,api无返回`;
|
||
}
|
||
// log(`头像设置返回:${JSON.stringify(ret)}`)
|
||
// if (ret['result'] == 1004022) {
|
||
// throw `头像${payload.file}设置失败,文件可能不是图片格式`;
|
||
// } else if (ret['result'] != 0) {
|
||
// throw `头像${payload.file}设置失败,未知的错误,${ret['result']}:${ret['errMsg']}`;
|
||
// }
|
||
return ret;
|
||
} else {
|
||
if (!isLocal) {
|
||
fs.unlink(path, () => {
|
||
});
|
||
}
|
||
throw `头像${payload.file}设置失败,无法获取头像,文件可能不存在`;
|
||
}
|
||
return null;
|
||
}
|
||
}
|