1. 02 Jan, 2026 1 commit
    • yangjianbo's avatar
      feat(安全): 强化安全策略与配置校验 · bd4bf008
      yangjianbo authored
      - 增加 CORS/CSP/安全响应头与代理信任配置
      
      - 引入 URL 白名单与私网开关,校验上游与价格源
      
      - 改善 API Key 处理与网关错误返回
      
      - 管理端设置隐藏敏感字段并优化前端提示
      
      - 增加计费熔断与相关配置示例
      
      测试: go test ./...
      bd4bf008
  2. 31 Dec, 2025 14 commits
    • yangjianbo's avatar
      fix(数据层): 修复软删除与唯一约束冲突问题 · 59269dc1
      yangjianbo authored
      问题:软删除的记录仍占用唯一约束位置,导致删后无法重建同名/同邮箱/同订阅
      
      修复方案:使用 PostgreSQL 部分唯一索引(WHERE deleted_at IS NULL)
      - User.email: 移除字段级 Unique(),改用部分唯一索引
      - Group.name: 移除字段级 Unique(),改用部分唯一索引
      - UserSubscription.(user_id, group_id): 移除组合唯一索引,改用部分唯一索引
      - ApiKey.key: 保留普通唯一约束(安全考虑,已删除的 Key 不应重用)
      
      安全性:
      - 应用层已有 ExistsByXxx 检查,自动过滤软删除记录
      - 数据库层部分唯一索引提供最后一道防线
      
      🤖 Generated with [Claude Code](https://claude.com/claude-code
      
      )
      Co-Authored-By: default avatarClaude Opus 4.5 <noreply@anthropic.com>
      59269dc1
    • shaw's avatar
      refactor(service): 统一时间戳解析,支持多种格式 · 81213f23
      shaw authored
      新增 Account.GetCredentialAsTime 方法,统一处理凭证中的时间戳字段,
      兼容 RFC3339 字符串、Unix 时间戳字符串和数字类型。
      
      - 重构 Claude/Gemini/Antigravity TokenRefresher.NeedsRefresh
      - 移除重复的 parseExpiresAt/parseAntigravityExpiresAt 函数
      - 简化 GetOpenAITokenExpiresAt 实现
      - 新增 RFC3339 格式单元测试用例
      81213f23
    • yangjianbo's avatar
      fix(网关): 添加 model 参数必填验证 · 1ef4f09d
      yangjianbo authored
      在以下端点添加 model 参数的必填验证,缺失时直接返回 400 错误:
      - /v1/messages
      - /v1/messages/count_tokens
      - /openai/v1/responses
      
      修复前:空 model 会进入账号选择流程,最终由上游 API 返回错误
      修复后:入口处直接拒绝,避免浪费资源和不明确的错误信息
      
      🤖 Generated with [Claude Code](https://claude.com/claude-code
      
      )
      Co-Authored-By: default avatarClaude Opus 4.5 <noreply@anthropic.com>
      1ef4f09d
    • shaw's avatar
      style: fix gofmt formatting in test file · aac7dd6b
      shaw authored
      Remove redundant alignment whitespace before comments.
      aac7dd6b
    • yangjianbo's avatar
      fix(设置): 修复站点设置保存失败的问题 · 6f6dc303
      yangjianbo authored
      问题:
      1. Setting.value 字段设置了 NotEmpty() 约束,导致保存空字符串值时验证失败
      2. 数据库 settings 表缺少 key 字段的唯一约束,导致 ON CONFLICT 语句执行失败
      
      修复:
      - 移除 ent/schema/setting.go 中 value 字段的 NotEmpty() 约束
      - 新增迁移 015_fix_settings_unique_constraint.sql 添加缺失的唯一约束
      - 添加3个回归测试确保空值保存功能正常
      
      🤖 Generated with [Claude Code](https://claude.com/claude-code
      
      )
      Co-Authored-By: default avatarClaude Opus 4.5 <noreply@anthropic.com>
      6f6dc303
    • yangjianbo's avatar
      fix(仓储): 修复并发缓存前缀与软删除更新 · d77d0544
      yangjianbo authored
      补齐 Redis ZSET 前缀处理,确保并发释放计数正确
      
      删除时改用 Client().Mutate 走更新逻辑,保留软删除记录
      
      测试: make test-integration
      d77d0544
    • yangjianbo's avatar
      fix(lint): 修复 golangci-lint 报告的代码问题 · 682f546c
      yangjianbo authored
      - errcheck: 修复类型断言未检查返回值的问题
        - pool.go: 添加 sync.Map 类型断言安全检查
        - req_client_pool.go: 添加 sync.Map 类型断言安全检查
        - concurrency_cache_benchmark_test.go: 显式忽略断言返回值
        - gateway_service.go: 显式忽略 WriteString 返回值
      
      - gofmt: 修复代码格式问题
        - redis.go: 注释对齐
        - api_key_repo.go: 结构体字段对齐
        - concurrency_cache.go: 字段对齐
        - http_upstream.go: 注释对齐
      
      - unused: 删除未使用的代码
        - user_repo.go: 删除未使用的 sql 字段
        - usage_service.go: 删除未使用的 calculateStats 函数
      
      🤖 Generated with [Claude Code](https://claude.com/claude-code
      
      )
      Co-Authored-By: default avatarClaude Opus 4.5 <noreply@anthropic.com>
      682f546c
    • yangjianbo's avatar
      fix(数据层): 修复数据完整性与仓储一致性问题 · 5906f9ab
      yangjianbo authored
      ## 数据完整性修复 (fix-critical-data-integrity)
      - 添加 error_translate.go 统一错误转换层
      - 修复 nil 输入和 NotFound 错误处理
      - 增强仓储层错误一致性
      
      ## 仓储一致性修复 (fix-high-repository-consistency)
      - Group schema 添加 default_validity_days 字段
      - Account schema 添加 proxy edge 关联
      - 新增 UsageLog ent schema 定义
      - 修复 UpdateBalance/UpdateConcurrency 受影响行数校验
      
      ## 数据卫生修复 (fix-medium-data-hygiene)
      - UserSubscription 添加软删除支持 (SoftDeleteMixin)
      - RedeemCode/Setting 添加硬删除策略文档
      - account_groups/user_allowed_groups 的 created_at 声明 timestamptz
      - 停止写入 legacy users.allowed_groups 列
      - 新增迁移: 011-014 (索引优化、软删除、孤立数据审计、列清理)
      
      ## 测试补充
      - 添加 UserSubscription 软删除测试
      - 添加迁移回归测试
      - 添加 NotFound 错误测试
      
      🤖 Generated with [Claude Code](https://claude.com/claude-code
      
      )
      Co-Authored-By: default avatarClaude Opus 4.5 <noreply@anthropic.com>
      5906f9ab
    • yangjianbo's avatar
      fix(网关): 防止连接池缓存失控 · 820bb16c
      yangjianbo authored
      超限且无可淘汰条目时拒绝新建
      
      规范化代理地址并更新失败时的访问时间
      
      补充连接池上限与代理规范化测试
      820bb16c
    • Wei Shaw's avatar
      a1540e27
    • yangjianbo's avatar
      perf(网关): 实现上游账号连接池隔离 · d1c98896
      yangjianbo authored
      新增隔离策略与连接池缓存回收
      
      连接池大小跟随账号并发并处理代理切换
      
      同步配置默认值与示例并补充测试
      d1c98896
    • shaw's avatar
      fix: 修复Antigravity token刷新间隔问题 · b7c6d040
      shaw authored
      b7c6d040
    • yangjianbo's avatar
      fix(服务): 修复system判定、统计时区与缓存日志 · 3d7f8e4b
      yangjianbo authored
      - system 字段存在即视为显式提供,避免 null 触发默认注入
      - 日统计分组显式使用应用时区,缺失时从 TZ 回退到 UTC
      - 缓存写入队列丢弃日志节流汇总,关键任务同步回退
      
      测试: go test ./internal/service -run TestBillingCacheServiceQueueHighLoad
      3d7f8e4b
    • yangjianbo's avatar
      perf(后端): 完成性能优化与连接池配置 · 7efa8b54
      yangjianbo authored
      新增 DB/Redis 连接池配置与校验,并补充单测
      
      网关请求体大小限制与 413 处理
      
      HTTP/req 客户端池化并调整上游连接池默认值
      
      并发槽位改为 ZSET+Lua 与指数退避
      
      用量统计改 SQL 聚合并新增索引迁移
      
      计费缓存写入改工作池并补测试/基准
      
      测试: 在 backend/ 下运行 go test ./...
      7efa8b54
  3. 30 Dec, 2025 16 commits
  4. 29 Dec, 2025 9 commits