Issue with whitespace in JWT roles in OpenSearch
Moderate severity
GitHub Reviewed
Published
Jan 24, 2023
in
opensearch-project/security
•
Updated Mar 7, 2023
Package
Affected versions
< 1.3.8
>= 2.0.0, < 2.5.0
Patched versions
1.3.8
2.5.0
Description
Published to the GitHub Advisory Database
Jan 24, 2023
Reviewed
Jan 24, 2023
Published by the National Vulnerability Database
Jan 26, 2023
Last updated
Mar 7, 2023
Advisory title: Issue with whitespace in JWT roles
Affected versions:
OpenSearch 1.0.0-1.3.7 and 2.0.0-2.4.1
Patched versions:
OpenSearch 1.3.8 and 2.5.0
Impact:
OpenSearch uses JWTs to store role claims obtained from the Identity Provider (IdP) when the authentication backend is SAML or OpenID Connect. There is an issue in how those claims are processed from the JWTs where the leading and trailing whitespace is trimmed, allowing users to potentially claim roles they are not assigned to if any role matches the whitespace-stripped version of the roles they are a member of.
This issue is only present for authenticated users, and it requires either the existence of roles that match, not considering leading/trailing whitespace, or the ability for users to create said matching roles. In addition, the Identity Provider must allow leading and trailing spaces in role names.
Patches:
OpenSearch versions 1.3.8 and 2.5.0 contain a fix for this issue.
For more information:
If you have any questions or comments about this advisory, please contact AWS/Amazon Security via our issue reporting page (https://aws.amazon.com/security/vulnerability-reporting/) or directly via email to [email protected]. Please do not create a public GitHub issue.
References