1. 25 Dec, 2025 1 commit
    • ianshaw's avatar
      feat(account): 优化批量更新实现,使用统一 SQL 合并 JSONB 字段 · 62ed5422
      ianshaw authored
      - 新增 BulkUpdate 仓储方法,使用单条 SQL 更新所有账户
      - credentials/extra 使用 COALESCE(...) || ? 合并,只更新传入的 key
      - name/proxy_id/concurrency/priority/status 只在提供时更新
      - 分组绑定仍逐账号处理(需要独立操作)
      - 前端优化:Base URL 留空则不修改,按勾选字段更新
      - 完善 i18n 文案:说明留空不修改、批量更新行为
      62ed5422
  2. 24 Dec, 2025 4 commits
    • ianshaw's avatar
      feat(account): 添加从 CRS 同步账户功能 · 65538280
      ianshaw authored
      - 添加账户同步 API 接口 (account_handler.go)
      - 实现 CRS 同步服务 (crs_sync_service.go)
      - 添加前端同步对话框组件 (SyncFromCrsModal.vue)
      - 更新账户管理界面支持同步操作
      - 添加账户仓库批量创建方法
      - 添加中英文国际化翻译
      - 更新依赖注入配置
      65538280
    • Forest's avatar
      refactor: 重命名 go module · 836c4dda
      Forest authored
      836c4dda
    • shaw's avatar
      fix(concurrency): 重构并发管理使用独立Key+原生TTL · e65e9587
      shaw authored
      问题:旧方案使用计数器模式,每次acquire都刷新TTL,导致僵尸数据永不过期
      
      解决方案:
      - 每个槽位使用独立Redis Key: concurrency:account:{id}:{requestID}
      - 利用Redis原生TTL,每个槽位独立5分钟过期
      - 服务崩溃后僵尸数据自动清理,无需手动干预
      - 兼容多实例K8s部署
      
      技术改动:
      - 新增SCAN脚本统计活跃槽位数量
      - 移除冗余的releaseScript,直接使用DEL命令
      - Wait队列TTL只在首次创建时设置,避免刷新
      e65e9587
    • Forest's avatar
      refactor(usage): 移动 usage 查询到 services · bbf4024d
      Forest authored
      bbf4024d
  3. 23 Dec, 2025 1 commit
  4. 22 Dec, 2025 1 commit
  5. 20 Dec, 2025 1 commit
  6. 19 Dec, 2025 2 commits