mirror of
https://github.com/QuantumNous/new-api.git
synced 2026-03-30 11:51:20 +00:00
117 lines
3.5 KiB
JavaScript
117 lines
3.5 KiB
JavaScript
/*
|
|
Copyright (C) 2025 QuantumNous
|
|
|
|
This program is free software: you can redistribute it and/or modify
|
|
it under the terms of the GNU Affero General Public License as
|
|
published by the Free Software Foundation, either version 3 of the
|
|
License, or (at your option) any later version.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU Affero General Public License for more details.
|
|
|
|
You should have received a copy of the GNU Affero General Public License
|
|
along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
For commercial licensing, please contact support@quantumnous.com
|
|
*/
|
|
|
|
import React, { useState } from 'react';
|
|
import { useTranslation } from 'react-i18next';
|
|
import { Button, Modal } from '@douyinfe/semi-ui';
|
|
import { useSecureVerification } from '../../../hooks/common/useSecureVerification';
|
|
import { createApiCalls } from '../../../services/secureVerification';
|
|
import SecureVerificationModal from '../modals/SecureVerificationModal';
|
|
import ChannelKeyDisplay from '../ui/ChannelKeyDisplay';
|
|
|
|
/**
|
|
* 渠道密钥查看组件使用示例
|
|
* 展示如何使用通用安全验证系统
|
|
*/
|
|
const ChannelKeyViewExample = ({ channelId }) => {
|
|
const { t } = useTranslation();
|
|
const [keyData, setKeyData] = useState('');
|
|
const [showKeyModal, setShowKeyModal] = useState(false);
|
|
|
|
// 使用通用安全验证 Hook
|
|
const {
|
|
isModalVisible,
|
|
verificationMethods,
|
|
verificationState,
|
|
startVerification,
|
|
executeVerification,
|
|
cancelVerification,
|
|
setVerificationCode,
|
|
switchVerificationMethod,
|
|
} = useSecureVerification({
|
|
onSuccess: (result) => {
|
|
// 验证成功后处理结果
|
|
if (result.success && result.data?.key) {
|
|
setKeyData(result.data.key);
|
|
setShowKeyModal(true);
|
|
}
|
|
},
|
|
successMessage: t('密钥获取成功'),
|
|
});
|
|
|
|
// 开始查看密钥流程
|
|
const handleViewKey = async () => {
|
|
const apiCall = createApiCalls.viewChannelKey(channelId);
|
|
|
|
await startVerification(apiCall, {
|
|
title: t('查看渠道密钥'),
|
|
description: t('为了保护账户安全,请验证您的身份。'),
|
|
preferredMethod: 'passkey', // 可以指定首选验证方式
|
|
});
|
|
};
|
|
|
|
return (
|
|
<>
|
|
{/* 查看密钥按钮 */}
|
|
<Button
|
|
type='primary'
|
|
theme='outline'
|
|
onClick={handleViewKey}
|
|
>
|
|
{t('查看密钥')}
|
|
</Button>
|
|
|
|
{/* 安全验证模态框 */}
|
|
<SecureVerificationModal
|
|
visible={isModalVisible}
|
|
verificationMethods={verificationMethods}
|
|
verificationState={verificationState}
|
|
onVerify={executeVerification}
|
|
onCancel={cancelVerification}
|
|
onCodeChange={setVerificationCode}
|
|
onMethodSwitch={switchVerificationMethod}
|
|
title={verificationState.title}
|
|
description={verificationState.description}
|
|
/>
|
|
|
|
{/* 密钥显示模态框 */}
|
|
<Modal
|
|
title={t('渠道密钥信息')}
|
|
visible={showKeyModal}
|
|
onCancel={() => setShowKeyModal(false)}
|
|
footer={
|
|
<Button type='primary' onClick={() => setShowKeyModal(false)}>
|
|
{t('完成')}
|
|
</Button>
|
|
}
|
|
width={700}
|
|
style={{ maxWidth: '90vw' }}
|
|
>
|
|
<ChannelKeyDisplay
|
|
keyData={keyData}
|
|
showSuccessIcon={true}
|
|
successText={t('密钥获取成功')}
|
|
showWarning={true}
|
|
/>
|
|
</Modal>
|
|
</>
|
|
);
|
|
};
|
|
|
|
export default ChannelKeyViewExample; |