Vulnerability Details : CVE-2021-32701
ORY Oathkeeper is an Identity & Access Proxy (IAP) and Access Control Decision API that authorizes HTTP requests based on sets of Access Rules. When you make a request to an endpoint that requires the scope `foo` using an access token granted with that `foo` scope, introspection will be valid and that token will be cached. The problem comes when a second requests to an endpoint that requires the scope `bar` is made before the cache has expired. Whether the token is granted or not to the `bar` scope, introspection will be valid. A patch will be released with `v0.38.12-beta.1`. Per default, caching is disabled for the `oauth2_introspection` authenticator. When caching is disabled, this vulnerability does not exist. The cache is checked in [`func (a *AuthenticatorOAuth2Introspection) Authenticate(...)`](https://github.com/ory/oathkeeper/blob/6a31df1c3779425e05db1c2a381166b087cb29a4/pipeline/authn/authenticator_oauth2_introspection.go#L152). From [`tokenFromCache()`](https://github.com/ory/oathkeeper/blob/6a31df1c3779425e05db1c2a381166b087cb29a4/pipeline/authn/authenticator_oauth2_introspection.go#L97) it seems that it only validates the token expiration date, but ignores whether the token has or not the proper scopes. The vulnerability was introduced in PR #424. During review, we failed to require appropriate test coverage by the submitter which is the primary reason that the vulnerability passed the review process.
Products affected by CVE-2021-32701
- cpe:2.3:a:ory:oathkeeper:0.38.0:beta2:*:*:*:*:*:*
- cpe:2.3:a:ory:oathkeeper:0.38.1:beta2:*:*:*:*:*:*
- cpe:2.3:a:ory:oathkeeper:0.38.2:beta1:*:*:*:*:*:*
- cpe:2.3:a:ory:oathkeeper:0.38.3:beta1:*:*:*:*:*:*
- cpe:2.3:a:ory:oathkeeper:0.38.4:beta1:*:*:*:*:*:*
- cpe:2.3:a:ory:oathkeeper:0.38.5:beta1:*:*:*:*:*:*
- cpe:2.3:a:ory:oathkeeper:0.38.6:beta1:*:*:*:*:*:*
- cpe:2.3:a:ory:oathkeeper:0.38.7:beta1:*:*:*:*:*:*
- cpe:2.3:a:ory:oathkeeper:0.38.8:beta1:*:*:*:*:*:*
- cpe:2.3:a:ory:oathkeeper:0.38.9:beta1:*:*:*:*:*:*
- cpe:2.3:a:ory:oathkeeper:0.38.10:beta2:*:*:*:*:*:*
- cpe:2.3:a:ory:oathkeeper:0.38.11:beta1:*:*:*:*:*:*
Exploit prediction scoring system (EPSS) score for CVE-2021-32701
0.31%
Probability of exploitation activity in the next 30 days
EPSS Score History
~ 51 %
Percentile, the proportion of vulnerabilities that are scored at or less
CVSS scores for CVE-2021-32701
Base Score | Base Severity | CVSS Vector | Exploitability Score | Impact Score | Score Source | First Seen |
---|---|---|---|---|---|---|
4.3
|
MEDIUM | AV:N/AC:M/Au:N/C:P/I:N/A:N |
8.6
|
2.9
|
NIST | |
7.5
|
HIGH | CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:N/A:N |
3.9
|
3.6
|
NIST | |
7.5
|
HIGH | CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:N/A:N |
3.9
|
3.6
|
GitHub, Inc. |
CWE ids for CVE-2021-32701
-
The product performs an authorization check when an actor attempts to access a resource or perform an action, but it does not correctly perform the check.Assigned by: security-advisories@github.com (Primary)
References for CVE-2021-32701
-
https://github.com/ory/oathkeeper/security/advisories/GHSA-qvp4-rpmr-xwrr
Possible bypass of token claim validation when OAuth2 Introspection caching is enabled · Advisory · ory/oathkeeper · GitHubThird Party Advisory
-
https://github.com/ory/oathkeeper/commit/1f9f625c1a49e134ae2299ee95b8cf158feec932
Merge pull request from GHSA-qvp4-rpmr-xwrr · ory/oathkeeper@1f9f625 · GitHubPatch;Third Party Advisory
-
https://github.com/ory/oathkeeper/pull/424
feat: cache incoming oauth introspect tokens by pike1212 · Pull Request #424 · ory/oathkeeper · GitHubPatch;Third Party Advisory
Jump to