"frontend/src/vscode:/vscode.git/clone" did not exist on "f28d4b78e746e61c1efaee71c9cff87fec5d5b41"
  1. 02 Feb, 2026 1 commit
  2. 16 Jan, 2026 2 commits
    • yangjianbo's avatar
      perf(Caddy): 添加静态资源长期缓存配置 · 74a3c745
      yangjianbo authored
      
      
      - 为 /assets/* 设置 1 年缓存 + immutable 标记
      - 包含 logo.png 和 favicon.ico
      - 移除可能干扰缓存的 Pragma/Expires 头
      
      效果:
      - 浏览器缓存命中后不再发送请求
      - Cloudflare CDN 可正确缓存静态资源
      - 重复访问页面秒开
      Co-Authored-By: default avatarClaude Opus 4.5 <noreply@anthropic.com>
      74a3c745
    • yangjianbo's avatar
      feat(安全): 实现 CSP nonce 支持解决内联脚本安全问题 · c9f79dee
      yangjianbo authored
      
      
      - 添加 GenerateNonce() 生成加密安全的随机 nonce
      - SecurityHeaders 中间件为每个请求生成唯一 nonce
      - CSP 策略支持 __CSP_NONCE__ 占位符动态替换
      - embed_on.go 注入的内联脚本添加 nonce 属性
      - 添加 Cloudflare Insights 域名到 CSP 允许列表
      - 添加完整单元测试,覆盖率达到 89.8%
      
      解决的问题:
      - 内联脚本违反 CSP script-src 指令
      - Cloudflare Insights beacon.min.js 加载被阻止
      Co-Authored-By: default avatarClaude Opus 4.5 <noreply@anthropic.com>
      c9f79dee
  3. 15 Jan, 2026 1 commit
    • yangjianbo's avatar
      fix(认证): OAuth 401 直接标记错误状态 · a458e684
      yangjianbo authored
      - OAuth 401 清理缓存并设置错误状态
      
      - 移除 oauth_401_cooldown_minutes 配置及示例
      
      - 更新 401 相关单测
      
      破坏性变更: OAuth 401 不再临时不可调度,需手动恢复
      a458e684
  4. 14 Jan, 2026 1 commit
  5. 12 Jan, 2026 2 commits
  6. 11 Jan, 2026 6 commits
  7. 10 Jan, 2026 1 commit
  8. 09 Jan, 2026 7 commits
    • Song Siyu's avatar
      feat: antigravity 配额域限流 + SSE 上限 (#222) · 7d1fe818
      Song Siyu authored
      * fix: 添加 gemini-3-flash 前缀映射支持 gemini-3-flash-preview
      
      * feat(antigravity): 增强请求参数和注入 Antigravity 身份 system prompt
      
      * feat: antigravity 配额域限流
      
      * chore: 调整 SSE 单行上限到 25MB
      
      * chore: 提升 SSE 单行上限到 40MB
      7d1fe818
    • Edric.Li's avatar
      feat(api-key): 添加 IP 白名单/黑名单限制功能 (#221) · 0a4641c2
      Edric.Li authored
      * feat(api-key): add IP whitelist/blacklist restriction and usage log IP tracking
      
      - Add IP restriction feature for API keys (whitelist/blacklist with CIDR support)
      - Add IP address logging to usage logs (admin-only visibility)
      - Remove billing_type column from usage logs UI (redundant)
      - Use generic "Access denied" error message for security
      
      Backend:
      - New ip package with IP/CIDR validation and matching utilities
      - Database migrations for ip_whitelist, ip_blacklist (api_keys) and ip_address (usage_logs)
      - Middleware IP restriction check after API key validation
      - Input validation for IP/CIDR patterns on create/update
      
      Frontend:
      - API key form with enable toggle for IP restriction
      - Shield icon indicator in table for keys with IP restriction
      - Removed billing_type filter and column from usage views
      
      * fix: update API contract tests for ip_whitelist/ip_blacklist fields
      
      Add ip_whitelist and ip_blacklist fields to expected JSON responses
      in API contract tests to match the new API key schema.
      0a4641c2
    • Edric Li's avatar
      fix: update API contract tests for ip_whitelist/ip_blacklist fields · e83f644c
      Edric Li authored
      Add ip_whitelist and ip_blacklist fields to expected JSON responses
      in API contract tests to match the new API key schema.
      e83f644c
    • song's avatar
      chore: 提升 SSE 单行上限到 40MB · c2a6ca8d
      song authored
      c2a6ca8d
    • song's avatar
      chore: 调整 SSE 单行上限到 25MB · 7b1cf2c4
      song authored
      7b1cf2c4
    • admin's avatar
      feat(auth): 添加 Linux DO Connect OAuth 登录支持 · 152d0cde
      admin authored
      - 新增 Linux DO OAuth 配置项和环境变量支持
      - 实现 OAuth 授权流程和回调处理
      - 前端添加 Linux DO 登录按钮和回调页面
      - 支持通过 Linux DO 账号注册/登录
      - 添加相关国际化文本
      
      🤖 Generated with [Claude Code](https://claude.com/claude-code
      
      )
      Co-Authored-By: default avatarClaude Opus 4.5 <noreply@anthropic.com>
      152d0cde
    • shaw's avatar
      27291f2e
  9. 07 Jan, 2026 1 commit
  10. 06 Jan, 2026 3 commits
  11. 05 Jan, 2026 12 commits
  12. 04 Jan, 2026 1 commit
    • yangjianbo's avatar
      fix(流式): 提升SSE稳定性并统一超时配置 · 73ffb585
      yangjianbo authored
      - 扩展SSE行长与间隔超时处理,补充keepalive
      
      - 写入失败与超长行时发送错误事件,修复并发释放
      
      - 同步默认配置与示例配置,更新Caddy超时/压缩规则
      
      - 新增OpenAI流式超时与超长行测试
      
      测试: go test ./...
      73ffb585
  13. 02 Jan, 2026 2 commits
    • IanShaw's avatar
      Fix/multiple issues (#24) · 7fdc2b2d
      IanShaw authored
      * fix(gemini): 修复 google_one OAuth 配置和 scopes 问题
      
      - 修复 google_one 类型在 ExchangeCode 和 RefreshToken 中使用内置客户端
      - 添加 DefaultGoogleOneScopes,包含 generative-language 和 drive.readonly 权限
      - 在 EffectiveOAuthConfig 中为 google_one 类型使用专门的 scopes
      - 将 docker-compose.override.yml 重命名为 .example 并添加到 .gitignore
      - 完善 docker-compose.override.yml.example 示例文档
      
      解决问题:
      1. google_one OAuth 授权后 API 调用返回 403 权限不足
      2. 缺少访问 Gemini API 所需的 generative-language scope
      3. 缺少获取 Drive 存储配额所需的 drive.readonly scope
      
      * fix(antigravity): 完全跳过 Claude 模型的所有 thinking 块
      
      问题分析:
      - 当前代码尝试保留有 signature 的 thinking 块
      - 但 Vertex AI 的 signature 是完整性令牌,无法在本地验证
      - 导致 400 错误:Invalid signature in thinking block
      
      根本原因:
      1. thinking 功能已对非 Gemini 模型禁用 (isThinkingEnabled=false)
      2. Vertex AI 要求原样重放 (thinking, signature) 对或完全不发送
      3. 本地无法复制 Vertex 的加密验证逻辑
      
      修复方案:
      - 对 Claude 模型完全跳过所有 thinking 块(无论是否有 signature)
      - 保持 Gemini 模型使用 dummy signature 的行为不变
      - 更新测试用例以反映新的预期行为
      
      影响:
      - 消除 thinking 相关的 400 错误
      - 与现有的 thinking 禁用策略保持一致
      - 不影响 Gemini 模型的 thinking 功能
      
      测试:
      -  TestBuildParts_ThinkingBlockWithoutSignature 全部通过
      -  TestBuildTools_CustomTypeTools 全部通过
      
      参考:Codex review 建议
      
      * fix(gateway): 修复 count_tokens 端点 400 错误
      
      问题分析:
      - count_tokens 请求包含 thinking 块时返回 400 错误
      - 原因:thinking 块未被过滤,直接转发到上游 API
      - 上游 API 拒绝无效的 thinking signature
      
      根本原因:
      1. /v1/messages 请求通过 TransformClaudeToGemini 过滤 thinking 块
      2. count_tokens 请求绕过转换,直接转发原始请求体
      3. 导致包含无效 signature 的 thinking 块被发送到上游
      
      修复方案:
      - 创建 FilterThinkingBlocks 工具函数
      - 在 buildCountTokensRequest 中应用过滤(1 行修改)
      - 与 /v1/messages 行为保持一致
      
      实现细节:
      - FilterThinkingBlocks: 解析 JSON,过滤 thinking 块,重新序列化
      - 失败安全:解析/序列化失败时返回原始请求体
      - 性能优化:仅在发现 thinking 块时重新序列化
      
      测试:
      -  6 个单元测试全部通过
      -  覆盖正常过滤、无 thinking 块、无效 JSON 等场景
      -  现有测试不受影响
      
      影响:
      - 消除 count_tokens 的 400 错误
      - 不影响 Antigravity 账号(仍返回模拟响应)
      - 适用于所有账号类型(OAuth、API Key)
      
      文件修改:
      - backend/internal/service/gateway_request.go: +62 行(新函数)
      - backend/internal/service/gateway_service.go: +2 行(应用过滤)
      - backend/internal/service/gateway_request_test.go: +62 行(测试)
      
      * fix(gateway): 增强 thinking 块过滤逻辑
      
      基于 Codex 分析和建议的改进:
      
      问题分析:
      - 新错误:signature: Field required(signature 字段缺失)
      - 旧错误:Invalid signature(signature 存在但无效)
      - 两者都说明 thinking 块在请求中是危险的
      
      Codex 建议:
      - 保持 Option A:完全跳过所有 thinking 块
      - 原因:thinking 块应该是只输出的,除非有服务端来源证明
      - 在无状态代理中,无法安全区分上游来源 vs 客户端注入
      
      改进内容:
      
      1. 增强 FilterThinkingBlocks 函数
         - 过滤显式的 thinking 块:{"type":"thinking", ...}
         - 过滤无 type 的 thinking 对象:{"thinking": {...}}
         - 保留 tool_use 等其他类型块中的 thinking 字段
         - 修复:只在实际过滤时更新 content 数组
      
      2. 扩展过滤范围
         - 将 FilterThinkingBlocks 应用到 /v1/messages 主路径
         - 之前只应用于 count_tokens,现在两个端点都过滤
         - 防止所有端点的 thinking 相关 400 错误
      
      3. 改进测试
         - 新增:过滤无 type discriminator 的 thinking 块
         - 新增:不过滤 tool_use 中的 thinking 字段
         - 使用 containsThinkingBlock 辅助函数验证
      
      测试:
      -  8 个测试用例全部通过
      -  覆盖各种 thinking 块格式
      -  确保不误伤其他类型的块
      
      影响:
      - 消除 signature required 和 invalid signature 错误
      - 统一 /v1/messages 和 count_tokens 的行为
      - 更健壮的 thinking 块检测逻辑
      
      参考:Codex review 和代码改进
      
      * refactor: 根据 Codex 审查建议进行代码优化
      
      基于 Codex 代码审查的 P1 和 P2 改进:
      
      P1 改进(重要问题):
      
      1. 优化日志输出
         - 移除 thinking 块跳过时的 log.Printf
         - 避免高频请求下的日志噪音
         - 添加注释说明可通过指标监控
      
      2. 清理遗留代码
         - 删除未使用的 isValidThoughtSignature 函数(27行)
         - 该函数在改为完全跳过 thinking 块后不再需要
      
      P2 改进(性能优化):
      
      3. 添加快速路径检查
         - 在 FilterThinkingBlocks 中添加 bytes.Contains 预检查
         - 如果请求体不包含 "thinking" 字符串,直接返回
         - 避免不必要的 JSON 解析,提升性能
      
      技术细节:
      - request_transformer.go: -27行(删除函数),+1行(优化注释)
      - gateway_request.go: +5行(快速路径 + bytes 导入)
      
      测试:
      -  TestBuildParts_ThinkingBlockWithoutSignature 全部通过
      -  TestFilterThinkingBlocks 全部通过(8个测试用例)
      
      影响:
      - 减少日志噪音
      - 提升性能(快速路径)
      - 代码更简洁(删除未使用代码)
      
      参考:Codex 代码审查建议
      
      * fix: 修复 golangci-lint 检查问题
      
      - 格式化 gateway_request_test.go
      - 使用 switch 语句替代 if-else 链(staticcheck QF1003)
      
      * fix(antigravity): 修复 thinking signature 处理并实现 Auto 模式降级
      
      问题分析:
      1. 原先代码错误地禁用了 Claude via Vertex 的 thinkingConfig
      2. 历史 thinking 块的 signature 被完全跳过,导致验证失败
      3. 跨模型混用时 dummy signature 会导致 400 错误
      
      修复内容:
      
      **request_transformer.go**:
      - 删除第 38-43 行的错误逻辑(禁用 thinkingConfig)
      - 引入 thoughtSignatureMode(Preserve/Dummy)策略
      - Claude 模式:透传真实 signature,过滤空/dummy
      - Gemini 模式:使用 dummy signature
      - 支持 signature-only thinking 块
      - tool_use 的 signature 也透传
      
      **antigravity_gateway_service.go**:
      - 新增 isSignatureRelatedError() 检测 signature 相关错误
      - 新增 stripThinkingFromClaudeRequest() 移除 thinking 块
      - 实现 Auto 模式:检测 400 + signature 关键词时自动降级重试
      - 重试时完全移除 thinking 配置和消息中的 thinking 块
      - 最多重试一次,避免循环
      
      **测试**:
      - 更新并新增测试覆盖 Claude preserve/Gemini dummy 模式
      - 新增 tool_use signature 处理测试
      - 所有测试通过(6/6)
      
      影响:
      -  Claude via Vertex 可以正常使用 thinking 功能
      -  历史 signature 正确透传,避免验证失败
      -  跨模型混用时自动过滤无效 signature
      -  错误驱动降级,自动修复 signature 问题
      -  不影响纯 Claude API 和其他渠道
      
      参考:Codex 深度分析和实现建议
      
      * fix(lint): 修复 gofmt 格式问题
      
      * fix(antigravity): 修复 stripThinkingFromClaudeRequest 遗漏 untyped thinking blocks
      
      问题:
      - Codex 审查指出 stripThinkingFromClaudeRequest 只移除了 type="thinking" 的块
      - 没有处理没有 type 字段的 thinking 对象(如 {"thinking": "...", "signature": "..."})
      - 导致重试时仍包含无效 thinking 块,上游 400 错误持续
      
      修复:
      - 添加检查:跳过没有 type 但有 thinking 字段的块
      - 现在会移除两种格式:
        1. {"type": "thinking", "thinking": "...", "signature": "..."}
        2. {"thinking": "...", "signature": "..."}(untyped)
      
      测试:所有测试通过
      
      参考:Codex P1 审查意见
      7fdc2b2d
    • yangjianbo's avatar
      feat(安全): 强化安全策略与配置校验 · bd4bf008
      yangjianbo authored
      - 增加 CORS/CSP/安全响应头与代理信任配置
      
      - 引入 URL 白名单与私网开关,校验上游与价格源
      
      - 改善 API Key 处理与网关错误返回
      
      - 管理端设置隐藏敏感字段并优化前端提示
      
      - 增加计费熔断与相关配置示例
      
      测试: go test ./...
      bd4bf008