新增功能: - 新增 TLS 指纹 Profile CRUD 管理(Ent schema + 迁移 + Admin API + 前端管理界面) - 支持账号绑定数据库中的自定义 TLS Profile,或随机选择(profile_id=-1) - HTTPUpstream.DoWithTLS 接口从 bool 改为 *tlsfingerprint.Profile,支持按账号指定 Profile - AccountUsageService 注入 TLSFingerprintProfileService,统一 usage 场景与网关的 Profile 解析逻辑 代码优化: - 删除已被 TLSFingerprintProfileService 完全取代的 registry.go 死代码(418 行) - 提取 3 个 dialer 的重复 TLS 握手逻辑为 performTLSHandshake() 共用函数 - 修复 GetTLSFingerprintProfileID 缺少 json.Number 处理的 bug - gateway_service.Forward 中 ResolveTLSProfile 从重试循环内重复调用改为预解析局部变量 - 删除冗余的 buildClientHelloSpec() 单行 wrapper 和 int64(e.ID) 无效转换 - tls_fingerprint_profile_cache.go 日志从 log.Printf 改为 slog 结构化日志 - dialer_capture_test.go 添加 //go:build integration 标签,防止 CI 失败 - 去重 TestProfileExpectation 类型至共享 test_types_test.go - 修复 9 个测试文件缺少 tlsfingerprint import 的编译错误 - 修复 error_policy_integration_test.go 中 handleError 回调签名被错误替换的问题
25 lines
909 B
Go
25 lines
909 B
Go
package service
|
||
|
||
import (
|
||
"net/http"
|
||
|
||
"github.com/Wei-Shaw/sub2api/internal/pkg/tlsfingerprint"
|
||
)
|
||
|
||
// HTTPUpstream 上游 HTTP 请求接口
|
||
// 用于向上游 API(Claude、OpenAI、Gemini 等)发送请求
|
||
type HTTPUpstream interface {
|
||
// Do 执行 HTTP 请求(不启用 TLS 指纹)
|
||
Do(req *http.Request, proxyURL string, accountID int64, accountConcurrency int) (*http.Response, error)
|
||
|
||
// DoWithTLS 执行带 TLS 指纹伪装的 HTTP 请求
|
||
//
|
||
// profile 参数:
|
||
// - nil: 不启用 TLS 指纹,行为与 Do 方法相同
|
||
// - non-nil: 使用指定的 Profile 进行 TLS 指纹伪装
|
||
//
|
||
// Profile 由调用方通过 TLSFingerprintProfileService 解析后传入,
|
||
// 支持按账号绑定的数据库 profile 或内置默认 profile。
|
||
DoWithTLS(req *http.Request, proxyURL string, accountID int64, accountConcurrency int, profile *tlsfingerprint.Profile) (*http.Response, error)
|
||
}
|