1. 28 Jan, 2026 1 commit
  2. 26 Jan, 2026 1 commit
    • shaw's avatar
      feat(auth): 实现 TOTP 双因素认证功能 · 1245f07a
      shaw authored
      新增功能:
      - 支持 Google Authenticator 等应用进行 TOTP 二次验证
      - 用户可在个人设置中启用/禁用 2FA
      - 登录时支持 TOTP 验证流程
      - 管理后台可全局开关 TOTP 功能
      
      安全增强:
      - TOTP 密钥使用 AES-256-GCM 加密存储
      - 添加 TOTP_ENCRYPTION_KEY 配置项,必须手动配置才能启用功能
      - 防止服务重启导致加密密钥变更使用户无法登录
      - 验证失败次数限制,防止暴力破解
      
      配置说明:
      - Docker 部署:在 .env 中设置 TOTP_ENCRYPTION_KEY
      - 非 Docker 部署:在 config.yaml 中设置 totp.encryption_key
      - 生成密钥命令:openssl rand -hex 32
      1245f07a
  3. 24 Jan, 2026 2 commits
    • shaw's avatar
      feat(auth): 密码重置邮件队列化与限流优化 · 9cc83525
      shaw authored
      - 邮件发送改为异步队列处理,避免并发导致发送失败
      - 新增 Email 维度限流(30秒冷却期),防止邮件轰炸
      - Token 验证使用常量时间比较,防止时序攻击
      - 重构代码消除冗余,提取公共验证逻辑
      9cc83525
    • shaw's avatar
      feat(subscription): 订阅过期状态自动更新与服务端排序 · b0aa2354
      shaw authored
      - 新增 SubscriptionExpiryService 定时任务,每分钟更新过期订阅状态
      - 订阅列表支持服务端排序(按过期时间、状态、创建时间)
      - 实时显示正确的过期状态,无需等待定时任务
      - 允许对已过期订阅进行续期操作
      - DataTable 组件支持 serverSideSort 模式
      b0aa2354
  4. 23 Jan, 2026 2 commits
  5. 21 Jan, 2026 1 commit
  6. 20 Jan, 2026 3 commits
  7. 19 Jan, 2026 7 commits
  8. 18 Jan, 2026 7 commits
  9. 16 Jan, 2026 9 commits
    • IanShaw027's avatar
      fix(gemini): 更新 Gemini 模型列表配置 · 28e46e0e
      IanShaw027 authored
      - 移除已弃用的 1.5 系列模型
      - 调整模型优先级顺序(2.0 Flash > 2.5 Flash > 2.5 Pro > 3.0 Preview)
      - 同步前后端模型配置
      - 更新相关测试用例和默认模型选择逻辑
      28e46e0e
    • shaw's avatar
      feat: 添加5h窗口费用控制和会话数量限制 · 73794233
      shaw authored
      - 支持Anthropic OAuth/SetupToken账号的5h窗口费用阈值控制
      - 支持账号级别的并发会话数量限制
      - 使用Redis缓存窗口费用(30秒TTL)减少数据库压力
      - 费用计算基于标准费用(不含账号倍率)
      73794233
    • yangjianbo's avatar
      perf(路由预加载): 修复静态 import 导致入口文件膨胀问题 · b0569d87
      yangjianbo authored
      
      
      问题:
      - 原实现使用静态 import() 映射表
      - Rollup 静态分析时将所有 37 个视图组件引用打包进 index.js
      - 导致首次加载时需要解析大量未使用的 import 语句
      
      修复:
      - 移除静态 import() 映射,改用纯路径字符串邻接表
      - 通过 router.getRoutes() 动态获取组件的 import 函数
      - 延迟初始化 routePrefetch,首次导航时才创建实例
      - 更新测试文件使用 mock router
      
      效果:
      - index.js 中动态 import 引用从 37 个减少到 1 个
      - 首次加载不再包含未使用的视图组件引用
      - 41 个测试全部通过
      Co-Authored-By: default avatarClaude Opus 4.5 <noreply@anthropic.com>
      b0569d87
    • yangjianbo's avatar
      perf(前端): 优化页面加载性能和用户体验 · 92234857
      yangjianbo authored
      
      
      - 添加路由预加载功能,使用 requestIdleCallback 在浏览器空闲时预加载
      - 配置 Vite manualChunks 分离 vendor 库(vue/ui/chart/i18n/misc)
      - 新增 NavigationProgress 导航进度条组件,支持防闪烁和无障碍
      - 集成 Vitest 测试框架,添加 40 个单元测试和集成测试
      - 支持 prefers-reduced-motion 和暗色模式
      Co-Authored-By: default avatarClaude Opus 4.5 <noreply@anthropic.com>
      92234857
    • yangjianbo's avatar
      perf(前端): 优化页面加载性能和用户体验 · 8efa3617
      yangjianbo authored
      
      
      - 添加路由预加载功能,使用 requestIdleCallback 在浏览器空闲时预加载
      - 配置 Vite manualChunks 分离 vendor 库(vue/ui/chart/i18n/misc)
      - 新增 NavigationProgress 导航进度条组件,支持防闪烁和无障碍
      - 集成 Vitest 测试框架,添加 40 个单元测试和集成测试
      - 支持 prefers-reduced-motion 和暗色模式
      Co-Authored-By: default avatarClaude Opus 4.5 <noreply@anthropic.com>
      8efa3617
    • yangjianbo's avatar
      perf(前端): 移除 Google Fonts 改用系统字体栈 · eb432a49
      yangjianbo authored
      
      
      - 删除 Google Fonts @import,解决国内访问阻塞问题
      - 使用 system-ui 优先的系统字体栈
      - 添加中文字体支持(苹方、冬青黑、微软雅黑)
      - 移除 Inter 字体专用的 font-feature-settings
      
      此改动可显著提升国内用户的页面加载速度,避免因 Google Fonts
      被墙导致的渲染阻塞问题。
      Co-Authored-By: default avatarClaude Opus 4.5 <noreply@anthropic.com>
      eb432a49
    • longgexx's avatar
      feat(group): 添加分组级别模型路由配置功能 · 19865b86
      longgexx authored
        支持为分组配置模型路由规则,可以指定特定模型模式优先使用的账号列表。
      
        - 新增 model_routing 字段存储路由配置(JSONB格式,支持通配符匹配)
      
        - 新增 model_routing_enabled 字段控制是否启用路由
      
        - 更新后端 handler/service/repository 支持路由配置的增删改查
      
        - 更新前端 GroupsView 添加路由配置界面
      
        - 添加数据库迁移脚本 040/041
      19865b86
    • yangjianbo's avatar
      fix(前端路由): 添加 chunk 加载错误自动恢复机制 · c6597880
      yangjianbo authored
      
      
      - 检测动态导入模块加载失败错误
      - 自动刷新页面获取最新资源
      - 使用 sessionStorage 防止无限刷新循环(10秒冷却)
      - 解决前端重新部署后用户缓存导致的加载失败问题
      Co-Authored-By: default avatarClaude Opus 4.5 <noreply@anthropic.com>
      c6597880
    • yangjianbo's avatar
      style(界面): 修复 AccountsView ESLint 报错 · b4789824
      yangjianbo authored
      移除多余分号并整理 onMounted 代码块,确保 lint:check 通过。
      b4789824
  10. 15 Jan, 2026 7 commits
    • IanShaw027's avatar
      refactor(ops): 简化自动刷新定时器逻辑 · 8b95d162
      IanShaw027 authored
      - 合并双定时器为单一倒计时定时器
      - 倒计时归零时触发数据刷新
      - 添加自定义时间范围的安全回退
      8b95d162
    • IanShaw027's avatar
      refactor(ops): 优化文案显示 · a478822b
      IanShaw027 authored
      - TTFT 定义统一改为"首 Token"/"First Token"(而非"首字节"/"first byte")
      - 请求时长卡片标题去掉"(毫秒)"/"(ms)"后缀
      a478822b
    • IanShaw027's avatar
      refactor(ops): 优化任务心跳和组件刷新机制 · 23aa69f5
      IanShaw027 authored
      后端改动:
      - 添加 ops_job_heartbeats.last_result 字段记录任务执行结果
      - 优化告警评估器统计信息(规则数/事件数/邮件数)
      - 统一各定时任务的心跳记录格式
      
      前端改动:
      - 重构 OpsConcurrencyCard 使用父组件统一控制刷新节奏
      - 移除独立的 5 秒刷新定时器,改用 refreshToken 机制
      - 修复 TypeScript 类型错误
      23aa69f5
    • IanShaw027's avatar
      fix(ops): 请求时长详情显示所有请求 · e93f0864
      IanShaw027 authored
      - 移除请求时长卡片详情按钮的 min_duration_ms 参数限制
      - 现在点击详情会显示所有请求,按时长倒序排列
      - 不再只显示 P99 以上的请求
      e93f0864
    • IanShaw027's avatar
      feat(ops): 添加自定义时间范围选择功能 · 930e9ee5
      IanShaw027 authored
      功能特性:
      - 在时间段选择器中增加"自定义"选项
      - 点击后弹出对话框,支持选择任意时间范围
      - 使用 HTML5 datetime-local 输入框,体验友好
      - 自定义时显示格式化的时间范围标签(MM-DD HH:mm ~ MM-DD HH:mm)
      - 默认初始化为最近1小时
      
      技术实现:
      - 扩展 TimeRange 类型支持 'custom'
      - 添加 customStartTime 和 customEndTime 状态管理
      - 创建 buildApiParams 辅助函数统一处理 API 参数
      - 当选择自定义时,使用 start_time 和 end_time 参数替代 time_range
      - 更新所有相关 API 调用支持自定义时间范围
      
      国际化:
      - 添加"自定义"、"开始时间"、"结束时间"翻译
      930e9ee5
    • IanShaw027's avatar
      refactor(ops): 优化阈值检查系统和布局 · 38961ba1
      IanShaw027 authored
      阈值检查系统优化:
      - 引入三级阈值系统(normal/warning/critical)
      - 统一阈值判断逻辑,支持警告和严重两个级别
      - 移除硬编码的 TTFT 颜色判断,改用阈值配置
      - 新增 getThresholdColorClass 统一颜色映射
      
      布局优化:
      - 优化详细指标在卡片内的响应式布局
      - 改进宽屏下的卡片布局显示
      - 优化指标数值的对齐和间距
      38961ba1
    • yangjianbo's avatar
      fix(账号管理): 移除调度切换后的冗余列表刷新 · 1bb4c76d
      yangjianbo authored
      
      
      切换账号调度状态后,updateSchedulableInList 已完成局部更新,
      无需再调用 load() 刷新整个列表。此修改减少不必要的 API 请求,
      避免 UI 闪烁。
      Co-Authored-By: default avatarClaude Opus 4.5 <noreply@anthropic.com>
      1bb4c76d