2025-04-17 00:06:49 +08:00
|
|
|
import { ALL, Body, Controller, Inject, Post, Provide } from "@midwayjs/core";
|
|
|
|
|
import { BaseController, Constants } from "@certd/lib-server";
|
|
|
|
|
import { UserSettingsService } from "../../../modules/mine/service/user-settings-service.js";
|
|
|
|
|
import { UserTwoFactorSetting } from "../../../modules/mine/service/models.js";
|
|
|
|
|
import { merge } from "lodash-es";
|
|
|
|
|
import { TwoFactorService } from "../../../modules/mine/service/two-factor-service.js";
|
2025-04-17 13:41:08 +08:00
|
|
|
import {isPlus} from "@certd/plus-core";
|
2025-04-17 00:06:49 +08:00
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
*/
|
|
|
|
|
@Provide()
|
|
|
|
|
@Controller("/api/user/settings/twoFactor")
|
|
|
|
|
export class UserTwoFactorSettingController extends BaseController {
|
|
|
|
|
@Inject()
|
|
|
|
|
service: UserSettingsService;
|
|
|
|
|
|
|
|
|
|
@Inject()
|
|
|
|
|
twoFactorService: TwoFactorService;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@Post("/get", { summary: Constants.per.authOnly })
|
|
|
|
|
async get() {
|
|
|
|
|
const userId = this.getUserId();
|
|
|
|
|
const setting = await this.service.getSetting<UserTwoFactorSetting>(userId, UserTwoFactorSetting);
|
|
|
|
|
return this.ok(setting);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Post("/save", { summary: Constants.per.authOnly })
|
|
|
|
|
async save(@Body(ALL) bean: any) {
|
2025-04-17 13:41:08 +08:00
|
|
|
if (!isPlus()) {
|
|
|
|
|
throw new Error('本功能需要开通专业版')
|
|
|
|
|
}
|
2025-04-17 00:06:49 +08:00
|
|
|
const userId = this.getUserId();
|
|
|
|
|
const setting = new UserTwoFactorSetting();
|
|
|
|
|
merge(setting, bean);
|
|
|
|
|
|
|
|
|
|
// 禁用时清除
|
|
|
|
|
if(!setting.authenticator.enabled){
|
|
|
|
|
setting.authenticator.secret = null;
|
|
|
|
|
setting.authenticator.verified = false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
await this.service.saveSetting(userId, setting);
|
|
|
|
|
return this.ok({});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Post("/authenticator/qrcode", { summary: Constants.per.authOnly })
|
|
|
|
|
async authenticatorQrcode() {
|
|
|
|
|
const userId = this.getUserId();
|
2026-02-06 23:26:57 +08:00
|
|
|
const {qrcode,link,secret} = await this.twoFactorService.getAuthenticatorQrCode(userId);
|
|
|
|
|
return this.ok({qrcode,link,secret});
|
2025-04-17 00:06:49 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Post("/authenticator/save", { summary: Constants.per.authOnly })
|
|
|
|
|
async authenticatorSave(@Body(ALL) bean: any) {
|
2025-04-17 13:41:08 +08:00
|
|
|
if (!isPlus()) {
|
|
|
|
|
throw new Error('本功能需要开通专业版')
|
|
|
|
|
}
|
2025-04-17 00:06:49 +08:00
|
|
|
const userId = this.getUserId();
|
|
|
|
|
await this.twoFactorService.saveAuthenticator({
|
|
|
|
|
userId,
|
|
|
|
|
verifyCode: bean.verifyCode,
|
|
|
|
|
});
|
|
|
|
|
return this.ok();
|
|
|
|
|
}
|
|
|
|
|
|
2025-04-17 01:15:55 +08:00
|
|
|
@Post("/authenticator/off", { summary: Constants.per.authOnly })
|
|
|
|
|
async authenticatorOff() {
|
|
|
|
|
const userId = this.getUserId();
|
|
|
|
|
await this.twoFactorService.offAuthenticator(userId);
|
|
|
|
|
return this.ok();
|
|
|
|
|
}
|
|
|
|
|
|
2025-04-17 00:06:49 +08:00
|
|
|
}
|