mirror of
https://gitee.com/mirrors/AllinSSL.git
synced 2026-03-10 00:31:10 +08:00
173 lines
4.6 KiB
TypeScript
173 lines
4.6 KiB
TypeScript
import { getAccessList, addAccess, updateAccess, deleteAccess } from '@api/access'
|
||
import { useError } from '@baota/hooks/error'
|
||
import { useMessage } from '@baota/naive-ui/hooks'
|
||
import { $t } from '@locales/index'
|
||
|
||
import type { AccessItem, AccessListParams, AddAccessParams, UpdateAccessParams } from '@/types/access'
|
||
import type { TableResponse } from '@baota/naive-ui/types/table'
|
||
import type { Ref } from 'vue'
|
||
|
||
/**
|
||
* 授权API管理状态Store接口定义
|
||
*/
|
||
interface AuthApiManageStoreExposes {
|
||
// 状态
|
||
apiFormProps: Ref<{
|
||
name: string
|
||
type: string
|
||
config: Record<string, any>
|
||
}>
|
||
accessTypeMap: Record<string, string>
|
||
|
||
// 方法
|
||
fetchAccessList: <T = AccessItem>(params: AccessListParams) => Promise<TableResponse<T>>
|
||
addNewAccess: (params: AddAccessParams<string>) => Promise<void>
|
||
updateExistingAccess: (params: UpdateAccessParams<string>) => Promise<void>
|
||
deleteExistingAccess: (id: string) => Promise<void>
|
||
resetApiForm: () => void
|
||
}
|
||
|
||
|
||
const message = useMessage() // 导入消息钩子
|
||
|
||
/**
|
||
* 授权API管理状态 Store
|
||
* @description 用于管理授权API相关的状态和操作,包括API列表、类型、分页等
|
||
*/
|
||
export const useAuthApiManageStore = defineStore('auth-api-manage-store', (): AuthApiManageStoreExposes => {
|
||
const { handleError } = useError() // 导入错误处理钩子
|
||
|
||
// -------------------- 状态定义 --------------------
|
||
/** 添加/编辑API表单 */
|
||
const apiFormProps = ref({
|
||
name: '',
|
||
type: 'btpanel',
|
||
config: {
|
||
url: '',
|
||
api_key: '',
|
||
ignore_ssl: '0',
|
||
},
|
||
})
|
||
|
||
// 表格列配置
|
||
const accessTypeMap = {
|
||
dns: $t('t_3_1745735765112'),
|
||
host: $t('t_0_1746754500246'),
|
||
plugin: '插件',
|
||
}
|
||
|
||
// -------------------- 请求方法 --------------------
|
||
/**
|
||
* 获取授权API列表
|
||
* @description 根据分页和关键词获取授权API列表数据
|
||
* @param {AccessListParams} params - 查询参数
|
||
* @returns {Promise<TableResponse<T>>} 返回列表数据和总数
|
||
*/
|
||
const fetchAccessList = async <T = AccessItem,>(params: AccessListParams): Promise<TableResponse<T>> => {
|
||
try {
|
||
const res = await getAccessList(params).fetch()
|
||
return {
|
||
list: (res.data || []) as T[],
|
||
total: res.count,
|
||
}
|
||
} catch (error) {
|
||
handleError(error)
|
||
return { list: [] as T[], total: 0 }
|
||
}
|
||
}
|
||
|
||
/**
|
||
* 新增授权API
|
||
* @description 创建新的授权API配置
|
||
* @param {AddAccessParams<string>} params - 授权API参数
|
||
* @returns {Promise<void>} 操作结果
|
||
*/
|
||
const addNewAccess = async (params: AddAccessParams<string>): Promise<void> => {
|
||
try {
|
||
const { fetch, message: apiMessage } = addAccess(params)
|
||
apiMessage.value = true
|
||
await fetch()
|
||
resetApiForm()
|
||
} catch (error) {
|
||
if (handleError(error)) message.error($t('t_8_1745289354902'))
|
||
throw error
|
||
}
|
||
}
|
||
|
||
/**
|
||
* 更新授权API
|
||
* @description 更新指定的授权API配置信息
|
||
* @param {UpdateAccessParams<string>} params - 授权API更新参数
|
||
* @returns {Promise<void>} 操作结果
|
||
*/
|
||
const updateExistingAccess = async (params: UpdateAccessParams<string>): Promise<void> => {
|
||
try {
|
||
const { fetch, message: apiMessage } = updateAccess(params)
|
||
apiMessage.value = true
|
||
await fetch()
|
||
resetApiForm()
|
||
} catch (error) {
|
||
if (handleError(error)) message.error($t('t_40_1745227838872'))
|
||
throw error
|
||
}
|
||
}
|
||
|
||
/**
|
||
* 删除授权API
|
||
* @description 删除指定的授权API配置
|
||
* @param {string} id - 授权API ID
|
||
* @returns {Promise<void>} 操作结果
|
||
*/
|
||
const deleteExistingAccess = async (id: string): Promise<void> => {
|
||
try {
|
||
const { fetch, message: apiMessage } = deleteAccess({ id })
|
||
apiMessage.value = true
|
||
await fetch()
|
||
resetApiForm()
|
||
} catch (error) {
|
||
if (handleError(error)) message.error($t('t_40_1745227838872'))
|
||
throw error
|
||
}
|
||
}
|
||
|
||
/**
|
||
* 重置API表单
|
||
* @description 重置表单数据为初始状态
|
||
*/
|
||
const resetApiForm = (): void => {
|
||
apiFormProps.value = {
|
||
name: '',
|
||
type: 'btpanel',
|
||
config: {
|
||
url: '',
|
||
api_key: '',
|
||
ignore_ssl: '0',
|
||
},
|
||
}
|
||
}
|
||
|
||
// 返回Store暴露的状态和方法
|
||
return {
|
||
// 状态
|
||
apiFormProps,
|
||
accessTypeMap,
|
||
|
||
// 方法
|
||
fetchAccessList,
|
||
addNewAccess,
|
||
updateExistingAccess,
|
||
deleteExistingAccess,
|
||
resetApiForm,
|
||
}
|
||
})
|
||
|
||
/**
|
||
* 组合式 API 使用 Store
|
||
* @description 提供对授权API管理 Store 的访问,并返回响应式引用
|
||
* @returns {Object} 包含所有 store 状态和方法的对象
|
||
*/
|
||
export const useStore = () => {
|
||
const store = useAuthApiManageStore()
|
||
return { ...store, ...storeToRefs(store) }
|
||
}
|