| name | go-vuln-auth-bypass |
| description | Use when auditing Go code involving authentication flows, RBAC policies, Kubernetes admission webhooks, JWT/OAuth token validation, or privilege escalation in cloud-native infrastructure. Covers CWE-287/863/269/284/285/862. Keywords: authentication bypass, authorization bypass, RBAC, admission webhook, JWT, OAuth, privilege escalation, Rancher, Kyverno, impersonation, namespace isolation, middleware auth |
Go Auth Bypass Vulnerability Patterns (CWE-287/863/269/284/285/862)
当审计 Go 代码中涉及认证流程、RBAC 权限检查、K8s admission webhook、JWT/OAuth 验证时加载此 Skill。
Detection Strategy
通用检测模型,适用于 Go 云原生生态中认证/授权绕过的所有变体。
Sources(攻击入口):
- HTTP 请求头部(
Authorization, Impersonate-User, Impersonate-Group)
- Kubernetes API 请求(ServiceAccount token, RBAC RoleBinding)
- gRPC metadata(
authorization, custom auth headers)
- JWT/OAuth token(
id_token, access_token, state parameter)
- Webhook 回调请求(admission webhook, mutating webhook)
- Rancher API proxy 请求(
/v3/clusters/:id/proxy)
Sinks(受保护资源/操作):
- Kubernetes API 调用(
client-go Create/Update/Delete)
- Rancher 管理 API(集群凭证、cloud credential)
- Secret 读取/修改操作(
v1.Secret 对象)
- 特权提升操作(
ClusterRoleBinding 创建, RoleRef 修改)
- Admission webhook 的
allow/deny 决策
- gRPC service method 实现
Sanitization(认证/授权屏障):
- Go HTTP 中间件(chi
Use(), gin Use(), echo middleware chain)
- Kubernetes RBAC(
SubjectAccessReview, SelfSubjectAccessReview)
- OPA/Gatekeeper 策略评估
- JWT 验证库(
golang-jwt/jwt/v5 的 Parse + WithValidMethods)
- gRPC interceptor(
UnaryInterceptor, StreamInterceptor)
- Rancher webhook 验证(
cattle.io webhook admission)
检测路径:
搜索认证/授权模式的 Grep 模式:
grep -rn "admission.Response\|admission.Allowed\|admission.Denied" --include="*.go"
grep -rn "SubjectAccessReview\|SelfSubjectAccessReview\|authz" --include="*.go"
grep -rn "jwt.Parse\|jwt.ParseWithClaims\|token.Valid" --include="*.go"
grep -rn "oauth\|OAuth\|state.*param\|csrf.*token" --include="*.go"
grep -rn "\.Use(\|\.Group(\|middleware\.\|interceptor" --include="*.go"
grep -rn "proxy.*handler\|proxyRequest\|cloud.*credential" --include="*.go"
grep -rn "Impersonate\|impersonate\|as-user\|as-group" --include="*.go"
- 搜索受保护的资源端点(HTTP handler、gRPC method、admission webhook handler)
- 检查是否有认证/授权中间件保护(middleware chain、interceptor、RBAC check)
- 验证屏障是否可被绕过:
- Admission webhook 在升级过程中是否被临时禁用?
- RBAC 策略是否存在跨 namespace 权限泄漏?
- JWT 验证是否检查了
alg 字段和 audience?
- OAuth state 参数是否正确验证?
- 中间件顺序是否正确(auth middleware 在路由之前)?
- Impersonation header 是否在 API proxy 中被正确过滤?
- ServiceAccount token 的权限范围是否过宽?
- 若无屏障或屏障可被绕过 -> 标记为候选漏洞
Detection Checklist
False Positive Exclusion Guide
以下模式不是此类漏洞:
- 测试代码中的权限豁免 --
_test.go 文件中使用 fake.NewSimpleClientset() 跳过认证
- 健康检查端点无认证 --
/healthz、/readyz、/livez 不需要认证是正常行为
- 公开的 metrics 端点 --
/metrics 在 Prometheus 架构中通常不需要认证(需确认网络隔离)
- 内部 gRPC 通信使用 mTLS -- 如果 gRPC 服务仅在 mesh 内通信且使用 mTLS,缺少 application-level 认证可接受
以下模式需要深入检查:
admission.Allowed("") -- 空 reason 的 allow 决策可能是 webhook 的默认放行逻辑
if err != nil { return true } -- 认证错误时默认允许是高危模式
- 中间件链中
Next() 在认证检查之前被调用 -- 可能导致后续 handler 在未认证情况下执行
ClusterRole 使用 * 通配符 -- resources: ["*"] + verbs: ["*"] 是过宽权限
Real-World Cases
详见 references/cases.md(7 个真实案例,需要时加载)。