fxbin/bubble-fireworks before commit 67b2ef4 did not properly verify the signature of JSON Web Tokens. This allows forging a valid JWT.
A JWT consists of three parts:
The three parts are base64 encoded and concatenated to form a string like this:
base64EncodedHeader.base64EncodedClaims.base64EncodedSignature. In a client-server context the signature is created by the server and so a (malicious) client could not change a JWT without making signature validation fail!
But it will also verify a JWT that contains no signature at all!
So it will happily accept a token like this that could have been created by a malicious attacker:
The solution is to always use the
parseClaimsJws method when parsing signed JWTs!
(This vulnerability has been found using this CodeQL query)
Arbitrary JWT forging which may lead to authentication bypasses.
- 2021-04-17: Asked to open a Github security advisory.
- 2021-04-23: Invited to Github security advisory.
- 2021-05-06: Issue is patched.
- 2021-05-10: CVE is assigned.
- 2021-05-21: Advisory is published.
This issue was discovered and reported by @intrigus-lgtm.
You can contact the ISL at
email@example.com. Please include a reference to
ISL-2021-005 in any communication regarding this issue.