新增功能: - 新增 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 回调签名被错误替换的问题
416 lines
17 KiB
Go
416 lines
17 KiB
Go
// Code generated by ent, DO NOT EDIT.
|
|
|
|
package tlsfingerprintprofile
|
|
|
|
import (
|
|
"time"
|
|
|
|
"entgo.io/ent/dialect/sql"
|
|
"github.com/Wei-Shaw/sub2api/ent/predicate"
|
|
)
|
|
|
|
// ID filters vertices based on their ID field.
|
|
func ID(id int64) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldEQ(FieldID, id))
|
|
}
|
|
|
|
// IDEQ applies the EQ predicate on the ID field.
|
|
func IDEQ(id int64) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldEQ(FieldID, id))
|
|
}
|
|
|
|
// IDNEQ applies the NEQ predicate on the ID field.
|
|
func IDNEQ(id int64) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldNEQ(FieldID, id))
|
|
}
|
|
|
|
// IDIn applies the In predicate on the ID field.
|
|
func IDIn(ids ...int64) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldIn(FieldID, ids...))
|
|
}
|
|
|
|
// IDNotIn applies the NotIn predicate on the ID field.
|
|
func IDNotIn(ids ...int64) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldNotIn(FieldID, ids...))
|
|
}
|
|
|
|
// IDGT applies the GT predicate on the ID field.
|
|
func IDGT(id int64) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldGT(FieldID, id))
|
|
}
|
|
|
|
// IDGTE applies the GTE predicate on the ID field.
|
|
func IDGTE(id int64) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldGTE(FieldID, id))
|
|
}
|
|
|
|
// IDLT applies the LT predicate on the ID field.
|
|
func IDLT(id int64) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldLT(FieldID, id))
|
|
}
|
|
|
|
// IDLTE applies the LTE predicate on the ID field.
|
|
func IDLTE(id int64) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldLTE(FieldID, id))
|
|
}
|
|
|
|
// CreatedAt applies equality check predicate on the "created_at" field. It's identical to CreatedAtEQ.
|
|
func CreatedAt(v time.Time) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldEQ(FieldCreatedAt, v))
|
|
}
|
|
|
|
// UpdatedAt applies equality check predicate on the "updated_at" field. It's identical to UpdatedAtEQ.
|
|
func UpdatedAt(v time.Time) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldEQ(FieldUpdatedAt, v))
|
|
}
|
|
|
|
// Name applies equality check predicate on the "name" field. It's identical to NameEQ.
|
|
func Name(v string) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldEQ(FieldName, v))
|
|
}
|
|
|
|
// Description applies equality check predicate on the "description" field. It's identical to DescriptionEQ.
|
|
func Description(v string) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldEQ(FieldDescription, v))
|
|
}
|
|
|
|
// EnableGrease applies equality check predicate on the "enable_grease" field. It's identical to EnableGreaseEQ.
|
|
func EnableGrease(v bool) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldEQ(FieldEnableGrease, v))
|
|
}
|
|
|
|
// CreatedAtEQ applies the EQ predicate on the "created_at" field.
|
|
func CreatedAtEQ(v time.Time) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldEQ(FieldCreatedAt, v))
|
|
}
|
|
|
|
// CreatedAtNEQ applies the NEQ predicate on the "created_at" field.
|
|
func CreatedAtNEQ(v time.Time) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldNEQ(FieldCreatedAt, v))
|
|
}
|
|
|
|
// CreatedAtIn applies the In predicate on the "created_at" field.
|
|
func CreatedAtIn(vs ...time.Time) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldIn(FieldCreatedAt, vs...))
|
|
}
|
|
|
|
// CreatedAtNotIn applies the NotIn predicate on the "created_at" field.
|
|
func CreatedAtNotIn(vs ...time.Time) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldNotIn(FieldCreatedAt, vs...))
|
|
}
|
|
|
|
// CreatedAtGT applies the GT predicate on the "created_at" field.
|
|
func CreatedAtGT(v time.Time) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldGT(FieldCreatedAt, v))
|
|
}
|
|
|
|
// CreatedAtGTE applies the GTE predicate on the "created_at" field.
|
|
func CreatedAtGTE(v time.Time) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldGTE(FieldCreatedAt, v))
|
|
}
|
|
|
|
// CreatedAtLT applies the LT predicate on the "created_at" field.
|
|
func CreatedAtLT(v time.Time) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldLT(FieldCreatedAt, v))
|
|
}
|
|
|
|
// CreatedAtLTE applies the LTE predicate on the "created_at" field.
|
|
func CreatedAtLTE(v time.Time) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldLTE(FieldCreatedAt, v))
|
|
}
|
|
|
|
// UpdatedAtEQ applies the EQ predicate on the "updated_at" field.
|
|
func UpdatedAtEQ(v time.Time) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldEQ(FieldUpdatedAt, v))
|
|
}
|
|
|
|
// UpdatedAtNEQ applies the NEQ predicate on the "updated_at" field.
|
|
func UpdatedAtNEQ(v time.Time) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldNEQ(FieldUpdatedAt, v))
|
|
}
|
|
|
|
// UpdatedAtIn applies the In predicate on the "updated_at" field.
|
|
func UpdatedAtIn(vs ...time.Time) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldIn(FieldUpdatedAt, vs...))
|
|
}
|
|
|
|
// UpdatedAtNotIn applies the NotIn predicate on the "updated_at" field.
|
|
func UpdatedAtNotIn(vs ...time.Time) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldNotIn(FieldUpdatedAt, vs...))
|
|
}
|
|
|
|
// UpdatedAtGT applies the GT predicate on the "updated_at" field.
|
|
func UpdatedAtGT(v time.Time) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldGT(FieldUpdatedAt, v))
|
|
}
|
|
|
|
// UpdatedAtGTE applies the GTE predicate on the "updated_at" field.
|
|
func UpdatedAtGTE(v time.Time) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldGTE(FieldUpdatedAt, v))
|
|
}
|
|
|
|
// UpdatedAtLT applies the LT predicate on the "updated_at" field.
|
|
func UpdatedAtLT(v time.Time) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldLT(FieldUpdatedAt, v))
|
|
}
|
|
|
|
// UpdatedAtLTE applies the LTE predicate on the "updated_at" field.
|
|
func UpdatedAtLTE(v time.Time) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldLTE(FieldUpdatedAt, v))
|
|
}
|
|
|
|
// NameEQ applies the EQ predicate on the "name" field.
|
|
func NameEQ(v string) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldEQ(FieldName, v))
|
|
}
|
|
|
|
// NameNEQ applies the NEQ predicate on the "name" field.
|
|
func NameNEQ(v string) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldNEQ(FieldName, v))
|
|
}
|
|
|
|
// NameIn applies the In predicate on the "name" field.
|
|
func NameIn(vs ...string) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldIn(FieldName, vs...))
|
|
}
|
|
|
|
// NameNotIn applies the NotIn predicate on the "name" field.
|
|
func NameNotIn(vs ...string) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldNotIn(FieldName, vs...))
|
|
}
|
|
|
|
// NameGT applies the GT predicate on the "name" field.
|
|
func NameGT(v string) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldGT(FieldName, v))
|
|
}
|
|
|
|
// NameGTE applies the GTE predicate on the "name" field.
|
|
func NameGTE(v string) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldGTE(FieldName, v))
|
|
}
|
|
|
|
// NameLT applies the LT predicate on the "name" field.
|
|
func NameLT(v string) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldLT(FieldName, v))
|
|
}
|
|
|
|
// NameLTE applies the LTE predicate on the "name" field.
|
|
func NameLTE(v string) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldLTE(FieldName, v))
|
|
}
|
|
|
|
// NameContains applies the Contains predicate on the "name" field.
|
|
func NameContains(v string) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldContains(FieldName, v))
|
|
}
|
|
|
|
// NameHasPrefix applies the HasPrefix predicate on the "name" field.
|
|
func NameHasPrefix(v string) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldHasPrefix(FieldName, v))
|
|
}
|
|
|
|
// NameHasSuffix applies the HasSuffix predicate on the "name" field.
|
|
func NameHasSuffix(v string) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldHasSuffix(FieldName, v))
|
|
}
|
|
|
|
// NameEqualFold applies the EqualFold predicate on the "name" field.
|
|
func NameEqualFold(v string) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldEqualFold(FieldName, v))
|
|
}
|
|
|
|
// NameContainsFold applies the ContainsFold predicate on the "name" field.
|
|
func NameContainsFold(v string) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldContainsFold(FieldName, v))
|
|
}
|
|
|
|
// DescriptionEQ applies the EQ predicate on the "description" field.
|
|
func DescriptionEQ(v string) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldEQ(FieldDescription, v))
|
|
}
|
|
|
|
// DescriptionNEQ applies the NEQ predicate on the "description" field.
|
|
func DescriptionNEQ(v string) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldNEQ(FieldDescription, v))
|
|
}
|
|
|
|
// DescriptionIn applies the In predicate on the "description" field.
|
|
func DescriptionIn(vs ...string) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldIn(FieldDescription, vs...))
|
|
}
|
|
|
|
// DescriptionNotIn applies the NotIn predicate on the "description" field.
|
|
func DescriptionNotIn(vs ...string) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldNotIn(FieldDescription, vs...))
|
|
}
|
|
|
|
// DescriptionGT applies the GT predicate on the "description" field.
|
|
func DescriptionGT(v string) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldGT(FieldDescription, v))
|
|
}
|
|
|
|
// DescriptionGTE applies the GTE predicate on the "description" field.
|
|
func DescriptionGTE(v string) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldGTE(FieldDescription, v))
|
|
}
|
|
|
|
// DescriptionLT applies the LT predicate on the "description" field.
|
|
func DescriptionLT(v string) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldLT(FieldDescription, v))
|
|
}
|
|
|
|
// DescriptionLTE applies the LTE predicate on the "description" field.
|
|
func DescriptionLTE(v string) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldLTE(FieldDescription, v))
|
|
}
|
|
|
|
// DescriptionContains applies the Contains predicate on the "description" field.
|
|
func DescriptionContains(v string) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldContains(FieldDescription, v))
|
|
}
|
|
|
|
// DescriptionHasPrefix applies the HasPrefix predicate on the "description" field.
|
|
func DescriptionHasPrefix(v string) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldHasPrefix(FieldDescription, v))
|
|
}
|
|
|
|
// DescriptionHasSuffix applies the HasSuffix predicate on the "description" field.
|
|
func DescriptionHasSuffix(v string) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldHasSuffix(FieldDescription, v))
|
|
}
|
|
|
|
// DescriptionIsNil applies the IsNil predicate on the "description" field.
|
|
func DescriptionIsNil() predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldIsNull(FieldDescription))
|
|
}
|
|
|
|
// DescriptionNotNil applies the NotNil predicate on the "description" field.
|
|
func DescriptionNotNil() predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldNotNull(FieldDescription))
|
|
}
|
|
|
|
// DescriptionEqualFold applies the EqualFold predicate on the "description" field.
|
|
func DescriptionEqualFold(v string) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldEqualFold(FieldDescription, v))
|
|
}
|
|
|
|
// DescriptionContainsFold applies the ContainsFold predicate on the "description" field.
|
|
func DescriptionContainsFold(v string) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldContainsFold(FieldDescription, v))
|
|
}
|
|
|
|
// EnableGreaseEQ applies the EQ predicate on the "enable_grease" field.
|
|
func EnableGreaseEQ(v bool) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldEQ(FieldEnableGrease, v))
|
|
}
|
|
|
|
// EnableGreaseNEQ applies the NEQ predicate on the "enable_grease" field.
|
|
func EnableGreaseNEQ(v bool) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldNEQ(FieldEnableGrease, v))
|
|
}
|
|
|
|
// CipherSuitesIsNil applies the IsNil predicate on the "cipher_suites" field.
|
|
func CipherSuitesIsNil() predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldIsNull(FieldCipherSuites))
|
|
}
|
|
|
|
// CipherSuitesNotNil applies the NotNil predicate on the "cipher_suites" field.
|
|
func CipherSuitesNotNil() predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldNotNull(FieldCipherSuites))
|
|
}
|
|
|
|
// CurvesIsNil applies the IsNil predicate on the "curves" field.
|
|
func CurvesIsNil() predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldIsNull(FieldCurves))
|
|
}
|
|
|
|
// CurvesNotNil applies the NotNil predicate on the "curves" field.
|
|
func CurvesNotNil() predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldNotNull(FieldCurves))
|
|
}
|
|
|
|
// PointFormatsIsNil applies the IsNil predicate on the "point_formats" field.
|
|
func PointFormatsIsNil() predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldIsNull(FieldPointFormats))
|
|
}
|
|
|
|
// PointFormatsNotNil applies the NotNil predicate on the "point_formats" field.
|
|
func PointFormatsNotNil() predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldNotNull(FieldPointFormats))
|
|
}
|
|
|
|
// SignatureAlgorithmsIsNil applies the IsNil predicate on the "signature_algorithms" field.
|
|
func SignatureAlgorithmsIsNil() predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldIsNull(FieldSignatureAlgorithms))
|
|
}
|
|
|
|
// SignatureAlgorithmsNotNil applies the NotNil predicate on the "signature_algorithms" field.
|
|
func SignatureAlgorithmsNotNil() predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldNotNull(FieldSignatureAlgorithms))
|
|
}
|
|
|
|
// AlpnProtocolsIsNil applies the IsNil predicate on the "alpn_protocols" field.
|
|
func AlpnProtocolsIsNil() predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldIsNull(FieldAlpnProtocols))
|
|
}
|
|
|
|
// AlpnProtocolsNotNil applies the NotNil predicate on the "alpn_protocols" field.
|
|
func AlpnProtocolsNotNil() predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldNotNull(FieldAlpnProtocols))
|
|
}
|
|
|
|
// SupportedVersionsIsNil applies the IsNil predicate on the "supported_versions" field.
|
|
func SupportedVersionsIsNil() predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldIsNull(FieldSupportedVersions))
|
|
}
|
|
|
|
// SupportedVersionsNotNil applies the NotNil predicate on the "supported_versions" field.
|
|
func SupportedVersionsNotNil() predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldNotNull(FieldSupportedVersions))
|
|
}
|
|
|
|
// KeyShareGroupsIsNil applies the IsNil predicate on the "key_share_groups" field.
|
|
func KeyShareGroupsIsNil() predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldIsNull(FieldKeyShareGroups))
|
|
}
|
|
|
|
// KeyShareGroupsNotNil applies the NotNil predicate on the "key_share_groups" field.
|
|
func KeyShareGroupsNotNil() predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldNotNull(FieldKeyShareGroups))
|
|
}
|
|
|
|
// PskModesIsNil applies the IsNil predicate on the "psk_modes" field.
|
|
func PskModesIsNil() predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldIsNull(FieldPskModes))
|
|
}
|
|
|
|
// PskModesNotNil applies the NotNil predicate on the "psk_modes" field.
|
|
func PskModesNotNil() predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldNotNull(FieldPskModes))
|
|
}
|
|
|
|
// ExtensionsIsNil applies the IsNil predicate on the "extensions" field.
|
|
func ExtensionsIsNil() predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldIsNull(FieldExtensions))
|
|
}
|
|
|
|
// ExtensionsNotNil applies the NotNil predicate on the "extensions" field.
|
|
func ExtensionsNotNil() predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.FieldNotNull(FieldExtensions))
|
|
}
|
|
|
|
// And groups predicates with the AND operator between them.
|
|
func And(predicates ...predicate.TLSFingerprintProfile) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.AndPredicates(predicates...))
|
|
}
|
|
|
|
// Or groups predicates with the OR operator between them.
|
|
func Or(predicates ...predicate.TLSFingerprintProfile) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.OrPredicates(predicates...))
|
|
}
|
|
|
|
// Not applies the not operator on the given predicate.
|
|
func Not(p predicate.TLSFingerprintProfile) predicate.TLSFingerprintProfile {
|
|
return predicate.TLSFingerprintProfile(sql.NotPredicates(p))
|
|
}
|