1. 31 Dec, 2025 3 commits
    • IanShaw's avatar
      fix: 修复 /v1/messages 间歇性 400 错误 (#18) · 34c10204
      IanShaw authored
      * fix(upstream): 修复上游格式兼容性问题
      
      - 跳过Claude模型无signature的thinking block
      - 支持custom类型工具(MCP)格式转换
      - 添加ClaudeCustomToolSpec结构体支持MCP工具
      - 添加Custom字段验证,跳过无效custom工具
      - 在convertClaudeToolsToGeminiTools中添加schema清理
      - 完整的单元测试覆盖,包含边界情况
      
      修复: Issue 0.1 signature缺失, Issue 0.2 custom工具格式
      改进: Codex审查发现的2个重要问题
      
      测试:
      - TestBuildParts_ThinkingBlockWithoutSignature: 验证thinking block处理
      - TestBuildTools_CustomTypeTools: 验证custom工具转换和边界情况
      - TestConvertClaudeToolsToGeminiTools_CustomType: 验证service层转换
      
      * feat(gemini): 添加Gemini限额与TierID支持
      
      实现PR1:Gemini限额与TierID功能
      
      后端修改:
      - GeminiTokenInfo结构体添加TierID字段
      - fetchProjectID函数返回(projectID, tierID, error)
      - 从LoadCodeAssist响应中提取tierID(优先IsDefault,回退到第一个非空tier)
      - ExchangeCode、RefreshAccountToken、GetAccessToken函数更新以处理tierID
      - BuildAccountCredentials函数保存tier_id到credentials
      
      前端修改:
      - AccountStatusIndicator组件添加tier显示
      - 支持LEGACY/PRO/ULTRA等tier类型的友好显示
      - 使用蓝色badge展示tier信息
      
      技术细节:
      - tierID提取逻辑:优先选择IsDefault的tier,否则选择第一个非空tier
      - 所有fetchProjectID调用点已更新以处理新的返回签名
      - 前端gracefully处理missing/unknown tier_id
      
      * refactor(gemini): 优化TierID实现并添加安全验证
      
      根据并发代码审查(code-reviewer, security-auditor, gemini, codex)的反馈进行改进:
      
      安全改进:
      - 添加validateTierID函数验证tier_id格式和长度(最大64字符)
      - 限制tier_id字符集为字母数字、下划线、连字符和斜杠
      - 在BuildAccountCredentials中验证tier_id后再存储
      - 静默跳过无效tier_id,不阻塞账户创建
      
      代码质量改进:
      - 提取extractTierIDFromAllowedTiers辅助函数消除重复代码
      - 重构fetchProjectID函数,tierID提取逻辑只执行一次
      - 改进代码可读性和可维护性
      
      审查工具:
      - code-reviewer agent (a09848e)
      - security-auditor agent (a9a149c)
      - gemini CLI (bcc7c81)
      - codex (b5d8919)
      
      修复问题:
      - HIGH: 未验证的tier_id输入
      - MEDIUM: 代码重复(tierID提取逻辑重复2次)
      
      * fix(format): 修复 gofmt 格式问题
      
      - 修复 claude_types.go 中的字段对齐问题
      - 修复 gemini_messages_compat_service.go 中的缩进问题
      
      * fix(upstream): 修复上游格式兼容性问题 (#14)
      
      * fix(upstream): 修复上游格式兼容性问题
      
      - 跳过Claude模型无signature的thinking block
      - 支持custom类型工具(MCP)格式转换
      - 添加ClaudeCustomToolSpec结构体支持MCP工具
      - 添加Custom字段验证,跳过无效custom工具
      - 在convertClaudeToolsToGeminiTools中添加schema清理
      - 完整的单元测试覆盖,包含边界情况
      
      修复: Issue 0.1 signature缺失, Issue 0.2 custom工具格式
      改进: Codex审查发现的2个重要问题
      
      测试:
      - TestBuildParts_ThinkingBlockWithoutSignature: 验证thinking block处理
      - TestBuildTools_CustomTypeTools: 验证custom工具转换和边界情况
      - TestConvertClaudeToolsToGeminiTools_CustomType: 验证service层转换
      
      * fix(format): 修复 gofmt 格式问题
      
      - 修复 claude_types.go 中的字段对齐问题
      - 修复 gemini_messages_compat_service.go 中的缩进问题
      
      * fix(format): 修复 claude_types.go 的 gofmt 格式问题
      
      * feat(antigravity): 优化 thinking block 和 schema 处理
      
      - 为 dummy thinking block 添加 ThoughtSignature
      - 重构 thinking block 处理逻辑,在每个条件分支内创建 part
      - 优化 excludedSchemaKeys,移除 Gemini 实际支持的字段
        (minItems, maxItems, minimum, maximum, additionalProperties, format)
      - 添加详细注释说明 Gemini API 支持的 schema 字段
      
      * fix(antigravity): 增强 schema 清理的安全性
      
      基于 Codex review 建议:
      - 添加 format 字段白名单过滤,只保留 Gemini 支持的 date-time/date/time
      - 补充更多不支持的 schema 关键字到黑名单:
        * 组合 schema: oneOf, anyOf, allOf, not, if/then/else
        * 对象验证: minProperties, maxProperties, patternProperties 等
        * 定义引用: $defs, definitions
      - 避免不支持的 schema 字段导致 Gemini API 校验失败
      
      * fix(lint): 修复 gemini_messages_compat_service 空分支警告
      
      - 在 cleanToolSchema 的 if 语句中添加 continue
      - 移除重复的注释
      
      * fix(antigravity): 移除 minItems/maxItems 以兼容 Claude API
      
      - 将 minItems 和 maxItems 添加到 schema 黑名单
      - Claude API (Vertex AI) 不支持这些数组验证字段
      - 添加调试日志记录工具 schema 转换过程
      - 修复 tools.14.custom.input_schema 验证错误
      
      * fix(antigravity): 修复 additionalProperties schema 对象问题
      
      - 将 additionalProperties 的 schema 对象转换为布尔值 true
      - Claude API 只支持 additionalProperties: false,不支持 schema 对象
      - 修复 tools.14.custom.input_schema 验证错误
      - 参考 Claude 官方文档的 JSON Schema 限制
      
      * fix(antigravity): 修复 Claude 模型 thinking 块兼容性问题
      
      - 完全跳过 Claude 模型的 thinking 块以避免 signature 验证失败
      - 只在 Gemini 模型中使用 dummy thought signature
      - 修改 additionalProperties 默认值为 false(更安全)
      - 添加调试日志以便排查问题
      
      * fix(upstream): 修复跨模型切换时的 dummy signature 问题
      
      基于 Codex review 和用户场景分析的修复:
      
      1. 问题场景
         - Gemini (thinking) → Claude (thinking) 切换时
         - Gemini 返回的 thinking 块使用 dummy signature
         - Claude API 会拒绝 dummy signature,导致 400 错误
      
      2. 修复内容
         - request_transformer.go:262: 跳过 dummy signature
         - 只保留真实的 Claude signature
         - 支持频繁的跨模型切换
      
      3. 其他修复(基于 Codex review)
         - gateway_service.go:691: 修复 io.ReadAll 错误处理
         - gateway_service.go:687: 条件日志(尊重 LogUpstreamErrorBody 配置)
         - gateway_service.go:915: 收紧 400 failover 启发式
         - request_transformer.go:188: 移除签名成功日志
      
      4. 新增功能(默认关闭)
         - 阶段 1: 上游错误日志(GATEWAY_LOG_UPSTREAM_ERROR_BODY)
         - 阶段 2: Antigravity thinking 修复
         - 阶段 3: API-key beta 注入(GATEWAY_INJECT_BETA_FOR_APIKEY)
         - 阶段 3: 智能 400 failover(GATEWAY_FAILOVER_ON_400)
      
      测试:所有测试通过
      
      * fix(lint): 修复 golangci-lint 问题
      
      - 应用 De Morgan 定律简化条件判断
      - 修复 gofmt 格式问题
      - 移除未使用的 min 函数
      34c10204
    • yangjianbo's avatar
      perf(网关): 实现上游账号连接池隔离 · d1c98896
      yangjianbo authored
      新增隔离策略与连接池缓存回收
      
      连接池大小跟随账号并发并处理代理切换
      
      同步配置默认值与示例并补充测试
      d1c98896
    • yangjianbo's avatar
      perf(后端): 完成性能优化与连接池配置 · 7efa8b54
      yangjianbo authored
      新增 DB/Redis 连接池配置与校验,并补充单测
      
      网关请求体大小限制与 413 处理
      
      HTTP/req 客户端池化并调整上游连接池默认值
      
      并发槽位改为 ZSET+Lua 与指数退避
      
      用量统计改 SQL 聚合并新增索引迁移
      
      计费缓存写入改工作池并补测试/基准
      
      测试: 在 backend/ 下运行 go test ./...
      7efa8b54
  2. 30 Dec, 2025 3 commits
  3. 29 Dec, 2025 1 commit
    • yangjianbo's avatar
      refactor(数据库): 迁移持久层到 Ent 并清理 GORM · 3d617de5
      yangjianbo authored
      将仓储层/基础设施改为 Ent + 原生 SQL 执行路径,并移除 AutoMigrate 与 GORM 依赖。
      重构内容包括:
      - 仓储层改用 Ent/SQL(含 usage_log/account 等复杂查询),统一错误映射
      - 基础设施与 setup 初始化切换为 Ent + SQL migrations
      - 集成测试与 fixtures 迁移到 Ent 事务模型
      - 清理遗留 GORM 模型/依赖,补充迁移与文档说明
      - 增加根目录 Makefile 便于前后端编译
      
      测试:
      - go test -tags unit ./...
      - go test -tags integration ./...
      3d617de5
  4. 28 Dec, 2025 2 commits
    • IanShaw027's avatar
      feat(全栈): 实现简易模式核心功能 · ecfad788
      IanShaw027 authored
      **功能概述**:
      实现简易模式(Simple Mode),为个人用户和小团队提供简化的使用体验,隐藏复杂的分组、订阅、配额等概念。
      
      **后端改动**:
      1. 配置系统
         - 新增 run_mode 配置项(standard/simple)
         - 支持环境变量 RUN_MODE
         - 默认值为 standard
      
      2. 数据库初始化
         - 自动创建3个默认分组:anthropic-default、openai-default、gemini-default
         - 默认分组配置:无并发限制、active状态、非独占
         - 幂等性保证:重复启动不会重复创建
      
      3. 账号管理
         - 创建账号时自动绑定对应平台的默认分组
         - 如果未指定分组,自动查找并绑定默认分组
      
      **前端改动**:
      1. 状态管理
         - authStore 新增 isSimpleMode 计算属性
         - 从后端API获取并同步运行模式
      
      2. UI隐藏
         - 侧边栏:隐藏分组管理、订阅管理、兑换码菜单
         - 账号管理页面:隐藏分组列
         - 创建/编辑账号对话框:隐藏分组选择器
      
      3. 路由守卫
         - 限制访问分组、订阅、兑换码相关页面
         - 访问受限页面时自动重定向到仪表板
      
      **配置示例**:
      ```yaml
      run_mode: simple
      
      run_mode: standard
      ```
      
      **影响范围**:
      - 后端:配置、数据库迁移、账号服务
      - 前端:认证状态、路由、UI组件
      - 部署:配置文件示例
      
      **兼容性**:
      - 简易模式和标准模式可无缝切换
      - 不需要数据迁移
      - 现有数据不受影响
      ecfad788
    • shaw's avatar
      fix: 修复安装脚本通过 pipe 执行时 root 权限检查失效的问题 · 9bbe468c
      shaw authored
      使用 `id -u` 替代 `$EUID` 进行 root 权限检查。
      `$EUID` 是 bash 内置变量,在通过 pipe 执行脚本时可能不可靠。
      9bbe468c
  5. 27 Dec, 2025 3 commits
  6. 26 Dec, 2025 6 commits
  7. 25 Dec, 2025 2 commits
  8. 24 Dec, 2025 1 commit
    • shaw's avatar
      feat(install): 添加安装指定版本和回退功能 · 870b2191
      shaw authored
      - 新增 rollback 命令支持回退到指定版本
      - 新增 list-versions 命令列出可用版本
      - 新增 -v/--version 参数指定安装版本
      - upgrade 命令支持升级到指定版本
      - 添加安装状态检查,未安装时给出明确提示
      - 版本切换仅替换二进制文件,保留配置和数据
      - 自动备份当前版本(带版本号或时间戳后缀)
      - 改进网络错误处理,添加超时和友好提示
      - 修复 grep -oP 兼容性问题,改用 grep -oE
      870b2191
  9. 19 Dec, 2025 1 commit
  10. 18 Dec, 2025 9 commits
    • shaw's avatar
      feat: 改进安装脚本的交互体验和自动化流程 · caae7e46
      shaw authored
      - 修复 curl | bash 管道模式下无法交互式输入的问题
        - 使用 /dev/tty 检测终端可用性替代 stdin 检测
        - 所有 read 命令从 /dev/tty 读取用户输入
      - 安装完成后自动启动服务和启用开机自启
      - 使用 ipinfo.io API 获取公网 IP 用于显示访问地址
      - 简化安装完成后的输出信息
      caae7e46
    • shaw's avatar
      refactor: 使用行业标准方案重构服务重启逻辑 · 8e81e395
      shaw authored
      重构内容:
      - 移除复杂的 sudo systemctl restart 方案
      - 改用 os.Exit(0) + systemd Restart=always 的标准做法
      - 删除 sudoers 配置及相关代码
      - 删除 sub2api-sudoers 文件
      
      优势:
      - 代码从 85+ 行简化到 47 行
      - 无需 sudo 权限配置
      - 无需特殊用户 shell 配置
      - 更简单、更可靠
      - 符合行业最佳实践(Docker/K8s 等均采用此方案)
      
      工作原理:
      - 服务调用 os.Exit(0) 优雅退出
      - systemd 检测到退出后自动重启(Restart=always)
      8e81e395
    • shaw's avatar
      fix: 修复 install.sh 优先使用旧 sudoers 文件的问题 · b66f97c1
      shaw authored
      问题原因:
      - install.sh 优先从 tar.gz 复制 sudoers 文件
      - 旧版 Release 中的 sudoers 文件没有 /usr/bin/systemctl 路径
      - 即使脚本更新了,仍然会使用旧的配置
      
      修复内容:
      - 移除对 tar.gz 中 sudoers 文件的依赖
      - 总是使用脚本中内嵌的最新配置
      - 确保新版脚本立即生效,无需等待新 Release
      b66f97c1
    • shaw's avatar
      fix: 修复 sudoers 中 systemctl 路径不兼容的问题 · b51ad0d8
      shaw authored
      问题原因:
      - sudoers 只配置了 /bin/systemctl 路径
      - 部分系统(如 Ubuntu 22.04+)的 systemctl 位于 /usr/bin/systemctl
      - 路径不匹配导致 sudo 仍然需要密码
      
      修复内容:
      - 同时支持 /bin/systemctl 和 /usr/bin/systemctl 两个路径
      - 兼容 Debian/Ubuntu 和 RHEL/CentOS 等不同发行版
      b51ad0d8
    • shaw's avatar
      fix: 修复服务用户 shell 导致无法执行 sudo 重启的问题 · 4eb22d8e
      shaw authored
      问题原因:
      - 服务用户 sub2api 的 shell 被设置为 /bin/false
      - 导致无法执行 sudo systemctl restart 命令
      - 安装/升级后服务无法自动重启
      
      修复内容:
      - 新安装时使用 /bin/sh 替代 /bin/false
      - 升级时自动检测并修复旧版本用户的 shell 配置
      - 修复失败时给出警告和手动修复命令,不中断安装流程
      4eb22d8e
    • shaw's avatar
      fix: 修复脚本的一些参数问题 · ef3199f0
      shaw authored
      ef3199f0
    • shaw's avatar
      20aee89d
    • shaw's avatar
      fix: add missing deploy/DOCKER.md for Docker workflow · 268f4d28
      shaw authored
      The release workflow references ./deploy/DOCKER.md to update DockerHub
      description, but the file was missing causing ENOENT error.
      268f4d28
    • shaw's avatar
      First commit · 642842c2
      shaw authored
      642842c2