feat(group-filter): 分组账号过滤控制 — require_oauth_only + require_privacy_set
为 OpenAI/Antigravity/Anthropic/Gemini 分组新增两个布尔控制字段:
- require_oauth_only: 创建/更新账号绑定分组时拒绝 apikey 类型加入
- require_privacy_set: 调度选号时跳过 privacy 未成功设置的账号并标记 error
后端:Ent schema 新增字段 + 迁移、Group CRUD 全链路透传、
gateway_service 与 openai_account_scheduler 两套调度路径过滤
前端:创建/编辑表单 toggle 开关(OpenAI/Antigravity/Anthropic/Gemini 平台可见)
Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
This commit is contained in:
@@ -141,6 +141,21 @@ func (a *Account) IsOAuth() bool {
|
||||
return a.Type == AccountTypeOAuth || a.Type == AccountTypeSetupToken
|
||||
}
|
||||
|
||||
// IsPrivacySet 检查账号的 privacy 是否已成功设置。
|
||||
// OpenAI: privacy_mode == "training_off"
|
||||
// Antigravity: privacy_mode == "privacy_set"
|
||||
// 其他平台: 无 privacy 概念,始终返回 true
|
||||
func (a *Account) IsPrivacySet() bool {
|
||||
switch a.Platform {
|
||||
case PlatformOpenAI:
|
||||
return a.getExtraString("privacy_mode") == PrivacyModeTrainingOff
|
||||
case PlatformAntigravity:
|
||||
return a.getExtraString("privacy_mode") == AntigravityPrivacySet
|
||||
default:
|
||||
return true
|
||||
}
|
||||
}
|
||||
|
||||
func (a *Account) IsGemini() bool {
|
||||
return a.Platform == PlatformGemini
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user