| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296 |
- import { Hono } from "hono";
- import debug from "debug";
- import type {
- SystemSetting,
- SystemSettingGroupData,
- } from "../client/share/types.ts";
- import type { Variables, WithAuth } from "./app.tsx";
- const log = {
- api: debug("api:sys"),
- };
- // 创建系统设置路由
- export function createSystemSettingsRoutes(withAuth: WithAuth) {
- const settingsRoutes = new Hono<{ Variables: Variables }>();
- // 获取所有系统设置(按分组)
- settingsRoutes.get('/', withAuth, async (c) => {
- try {
- const apiClient = c.get('apiClient');
- const settings = await apiClient.database
- .table('system_settings')
- .select('*');
- // 按分组整理数据
- const groupedSettings = settings.reduce((acc: SystemSettingGroupData[], setting) => {
- const groupIndex = acc.findIndex((g: SystemSettingGroupData) => g.name === setting.group);
- if (groupIndex === -1) {
- acc.push({
- name: setting.group,
- description: `${setting.group}组设置`,
- settings: [{
- id: setting.id,
- key: setting.key,
- value: setting.value,
- description: setting.description,
- group: setting.group
- }]
- });
- } else {
- acc[groupIndex].settings.push({
- id: setting.id,
- key: setting.key,
- value: setting.value,
- description: setting.description,
- group: setting.group
- });
- }
- return acc;
- }, []);
- return c.json({
- message: '获取系统设置成功',
- data: groupedSettings
- });
- } catch (error) {
- log.api('获取系统设置失败:', error);
- return c.json({ error: '获取系统设置失败' }, 500);
- }
- });
- // 获取指定分组的系统设置
- settingsRoutes.get('/group/:group', withAuth, async (c) => {
- try {
- const apiClient = c.get('apiClient');
- const group = c.req.param('group');
-
- const settings = await apiClient.database
- .table('system_settings')
- .where('group', group)
- .select('*');
- return c.json({
- message: '获取分组设置成功',
- data: settings
- });
- } catch (error) {
- log.api('获取分组设置失败:', error);
- return c.json({ error: '获取分组设置失败' }, 500);
- }
- });
- // 更新系统设置
- settingsRoutes.put('/:key', withAuth, async (c) => {
- try {
- const apiClient = c.get('apiClient');
- const key = c.req.param('key');
- const settingData = await c.req.json();
- // 验证设置是否存在
- const existingSetting = await apiClient.database
- .table('system_settings')
- .where('key', key)
- .first();
- if (!existingSetting) {
- return c.json({ error: '设置项不存在' }, 404);
- }
- // 更新设置
- await apiClient.database
- .table('system_settings')
- .where('key', key)
- .update({
- value: settingData.value,
- updated_at: apiClient.database.fn.now()
- });
- // 获取更新后的设置
- const updatedSetting = await apiClient.database
- .table('system_settings')
- .where('key', key)
- .first();
- return c.json({
- message: '系统设置已更新',
- data: updatedSetting
- });
- } catch (error) {
- log.api('更新系统设置失败:', error);
- return c.json({ error: '更新系统设置失败' }, 500);
- }
- });
- // 批量更新系统设置
- settingsRoutes.put('/', withAuth, async (c) => {
- try {
- const apiClient = c.get('apiClient');
- const settingsData = await c.req.json();
- // 验证数据格式
- if (!Array.isArray(settingsData)) {
- return c.json({ error: '无效的请求数据格式,应为数组' }, 400);
- }
- const trxProvider = apiClient.database.transactionProvider();
- const trx = await trxProvider();
- for (const setting of settingsData) {
- if (!setting.key) continue;
- // 验证设置是否存在
- const existingSetting = await trx.table('system_settings')
- .where('key', setting.key)
- .first();
- if (!existingSetting) {
- throw new Error(`设置项 ${setting.key} 不存在`);
- }
- // 更新设置
- await trx.table('system_settings')
- .where('key', setting.key)
- .update({
- value: setting.value,
- updated_at: trx.fn.now()
- });
- }
- await trx.commit();
- // 获取所有更新后的设置
- const updatedSettings = await apiClient.database
- .table('system_settings')
- .whereIn('key', settingsData.map(s => s.key))
- .select('*');
- return c.json({
- message: '系统设置已批量更新',
- data: updatedSettings
- });
- } catch (error) {
- log.api('批量更新系统设置失败:', error);
- return c.json({ error: '批量更新系统设置失败' }, 500);
- }
- });
- // 重置系统设置
- settingsRoutes.post('/reset', withAuth, async (c) => {
- try {
- const apiClient = c.get('apiClient');
- // 重置为迁移文件中定义的初始值
- const trxProvider = apiClient.database.transactionProvider();
- const trx = await trxProvider();
- // 清空现有设置
- await trx.table('system_settings').delete();
-
- // 插入默认设置
- await trx.table('system_settings').insert([
- // 基础设置组
- {
- key: 'SITE_NAME',
- value: '应用管理系统',
- description: '站点名称',
- group: 'basic',
- created_at: apiClient.database.fn.now(),
- updated_at: apiClient.database.fn.now()
- },
- {
- key: 'SITE_DESCRIPTION',
- value: '一个强大的应用管理系统',
- description: '站点描述',
- group: 'basic',
- created_at: apiClient.database.fn.now(),
- updated_at: apiClient.database.fn.now()
- },
- {
- key: 'SITE_KEYWORDS',
- value: '应用管理,系统管理,后台管理',
- description: '站点关键词',
- group: 'basic',
- created_at: apiClient.database.fn.now(),
- updated_at: apiClient.database.fn.now()
- },
- // 功能设置组
- {
- key: 'ENABLE_REGISTER',
- value: 'true',
- description: '是否开启注册',
- group: 'feature',
- created_at: apiClient.database.fn.now(),
- updated_at: apiClient.database.fn.now()
- },
- {
- key: 'ENABLE_CAPTCHA',
- value: 'true',
- description: '是否开启验证码',
- group: 'feature',
- created_at: apiClient.database.fn.now(),
- updated_at: apiClient.database.fn.now()
- },
- {
- key: 'LOGIN_ATTEMPTS',
- value: '5',
- description: '登录尝试次数',
- group: 'feature',
- created_at: apiClient.database.fn.now(),
- updated_at: apiClient.database.fn.now()
- },
- // 上传设置组
- {
- key: 'UPLOAD_MAX_SIZE',
- value: '10',
- description: '最大上传大小(MB)',
- group: 'upload',
- created_at: apiClient.database.fn.now(),
- updated_at: apiClient.database.fn.now()
- },
- {
- key: 'ALLOWED_FILE_TYPES',
- value: 'jpg,jpeg,png,gif,doc,docx,xls,xlsx,pdf',
- description: '允许的文件类型',
- group: 'upload',
- created_at: apiClient.database.fn.now(),
- updated_at: apiClient.database.fn.now()
- },
- // 通知设置组
- {
- key: 'NOTIFY_ON_LOGIN',
- value: 'true',
- description: '登录通知',
- group: 'notify',
- created_at: apiClient.database.fn.now(),
- updated_at: apiClient.database.fn.now()
- },
- {
- key: 'NOTIFY_ON_ERROR',
- value: 'true',
- description: '错误通知',
- group: 'notify',
- created_at: apiClient.database.fn.now(),
- updated_at: apiClient.database.fn.now()
- }
- ]);
- await trx.commit();
- const resetSettings = await apiClient.database
- .table('system_settings')
- .select('*');
- return c.json({
- message: '系统设置已重置',
- data: resetSettings
- });
- } catch (error) {
- log.api('重置系统设置失败:', error);
- return c.json({ error: '重置系统设置失败' }, 500);
- }
- });
- return settingsRoutes;
- }
|