Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Update dependency jsonwebtoken to v9 [SECURITY] #588

Open
wants to merge 1 commit into
base: master
Choose a base branch
from

Conversation

renovate[bot]
Copy link
Contributor

@renovate renovate bot commented Dec 22, 2022

Mend Renovate

This PR contains the following updates:

Package Change Age Adoption Passing Confidence
jsonwebtoken 8.5.1 -> 9.0.0 age adoption passing confidence

Warning

Some dependencies could not be looked up. Check the warning logs for more information.

GitHub Vulnerability Alerts

CVE-2022-23539

Overview

Versions <=8.5.1 of jsonwebtoken library could be misconfigured so that legacy, insecure key types are used for signature verification. For example, DSA keys could be used with the RS256 algorithm.

Am I affected?

You are affected if you are using an algorithm and a key type other than the combinations mentioned below

Key type algorithm
ec ES256, ES384, ES512
rsa RS256, RS384, RS512, PS256, PS384, PS512
rsa-pss PS256, PS384, PS512

And for Elliptic Curve algorithms:

alg Curve
ES256 prime256v1
ES384 secp384r1
ES512 secp521r1

How do I fix it?

Update to version 9.0.0. This version validates for asymmetric key type and algorithm combinations. Please refer to the above mentioned algorithm / key type combinations for the valid secure configuration. After updating to version 9.0.0, If you still intend to continue with signing or verifying tokens using invalid key type/algorithm value combinations, you’ll need to set the allowInvalidAsymmetricKeyTypes option to true in the sign() and/or verify() functions.

Will the fix impact my users?

There will be no impact, if you update to version 9.0.0 and you already use a valid secure combination of key type and algorithm. Otherwise, use the allowInvalidAsymmetricKeyTypes option to true in the sign() and verify() functions to continue usage of invalid key type/algorithm combination in 9.0.0 for legacy compatibility.

CVE-2022-23541

Overview

Versions <=8.5.1 of jsonwebtoken library can be misconfigured so that passing a poorly implemented key retrieval function (referring to the secretOrPublicKey argument from the readme link) will result in incorrect verification of tokens. There is a possibility of using a different algorithm and key combination in verification than the one that was used to sign the tokens. Specifically, tokens signed with an asymmetric public key could be verified with a symmetric HS256 algorithm. This can lead to successful validation of forged tokens.

Am I affected?

You will be affected if your application is supporting usage of both symmetric key and asymmetric key in jwt.verify() implementation with the same key retrieval function.

How do I fix it?

Update to version 9.0.0.

Will the fix impact my users?

There is no impact for end users

CVE-2022-23540

Overview

In versions <=8.5.1 of jsonwebtoken library, lack of algorithm definition and a falsy secret or key in the jwt.verify() function can lead to signature validation bypass due to defaulting to the none algorithm for signature verification.

Am I affected?

You will be affected if all the following are true in the jwt.verify() function:

  • a token with no signature is received
  • no algorithms are specified
  • a falsy (e.g. null, false, undefined) secret or key is passed

How do I fix it?

Update to version 9.0.0 which removes the default support for the none algorithm in the jwt.verify() method.

Will the fix impact my users?

There will be no impact, if you update to version 9.0.0 and you don’t need to allow for the none algorithm. If you need 'none' algorithm, you have to explicitly specify that in jwt.verify() options.


Release Notes

auth0/node-jsonwebtoken (jsonwebtoken)

v9.0.0

Compare Source

Breaking changes: See Migration from v8 to v9

Breaking changes
Security fixes
  • security: fixes Arbitrary File Write via verify function - CVE-2022-23529
  • security: fixes Insecure default algorithm in jwt.verify() could lead to signature validation bypass - CVE-2022-23540
  • security: fixes Insecure implementation of key retrieval function could lead to Forgeable Public/Private Tokens from RSA to HMAC - CVE-2022-23541
  • security: fixes Unrestricted key type could lead to legacy keys usage - CVE-2022-23539

Configuration

📅 Schedule: Branch creation - "" (UTC), Automerge - At any time (no schedule defined).

🚦 Automerge: Disabled by config. Please merge this manually once you are satisfied.

Rebasing: Whenever PR is behind base branch, or you tick the rebase/retry checkbox.

🔕 Ignore: Close this PR and you won't be reminded about this update again.


  • If you want to rebase/retry this PR, check this box

This PR has been generated by Mend Renovate. View repository job log here.

@renovate renovate bot force-pushed the renovate/npm-jsonwebtoken-vulnerability branch from 352d77e to ba98a46 Compare December 23, 2022 18:22
@renovate renovate bot force-pushed the renovate/npm-jsonwebtoken-vulnerability branch 2 times, most recently from 6f81154 to 90400be Compare January 6, 2023 23:43
@renovate renovate bot changed the title Update dependency jsonwebtoken to v9 [SECURITY] Update dependency jsonwebtoken to v9 [SECURITY] - autoclosed Jan 7, 2023
@renovate renovate bot closed this Jan 7, 2023
@renovate renovate bot deleted the renovate/npm-jsonwebtoken-vulnerability branch January 7, 2023 02:45
@renovate renovate bot changed the title Update dependency jsonwebtoken to v9 [SECURITY] - autoclosed Update dependency jsonwebtoken to v9 [SECURITY] Jan 7, 2023
@renovate renovate bot reopened this Jan 7, 2023
@renovate renovate bot restored the renovate/npm-jsonwebtoken-vulnerability branch January 7, 2023 05:16
@renovate renovate bot changed the title Update dependency jsonwebtoken to v9 [SECURITY] Update dependency jsonwebtoken to v9 [SECURITY] - autoclosed Feb 3, 2023
@renovate renovate bot closed this Feb 3, 2023
@renovate renovate bot deleted the renovate/npm-jsonwebtoken-vulnerability branch February 3, 2023 00:52
@renovate renovate bot changed the title Update dependency jsonwebtoken to v9 [SECURITY] - autoclosed Update dependency jsonwebtoken to v9 [SECURITY] Feb 3, 2023
@renovate renovate bot reopened this Feb 3, 2023
@renovate renovate bot restored the renovate/npm-jsonwebtoken-vulnerability branch February 3, 2023 04:44
@renovate renovate bot force-pushed the renovate/npm-jsonwebtoken-vulnerability branch 4 times, most recently from f77d97d to 05878e1 Compare June 2, 2023 19:37
@renovate renovate bot force-pushed the renovate/npm-jsonwebtoken-vulnerability branch 10 times, most recently from 5bf4c91 to d771a4a Compare June 28, 2023 19:51
@renovate renovate bot force-pushed the renovate/npm-jsonwebtoken-vulnerability branch from d771a4a to c6ef085 Compare June 29, 2023 19:26
@renovate renovate bot force-pushed the renovate/npm-jsonwebtoken-vulnerability branch from 5a219e3 to b115e30 Compare August 28, 2023 23:27
@renovate renovate bot force-pushed the renovate/npm-jsonwebtoken-vulnerability branch 2 times, most recently from a4e4d21 to f6570ed Compare September 15, 2023 16:17
@renovate renovate bot force-pushed the renovate/npm-jsonwebtoken-vulnerability branch 2 times, most recently from bd8e060 to fcd83d7 Compare September 24, 2023 08:54
@renovate renovate bot force-pushed the renovate/npm-jsonwebtoken-vulnerability branch from fcd83d7 to 51137cb Compare October 13, 2023 16:07
@renovate renovate bot force-pushed the renovate/npm-jsonwebtoken-vulnerability branch 3 times, most recently from 441f58a to 077b087 Compare October 23, 2023 22:35
@renovate renovate bot force-pushed the renovate/npm-jsonwebtoken-vulnerability branch from 077b087 to 8b66e53 Compare October 27, 2023 21:58
@renovate renovate bot force-pushed the renovate/npm-jsonwebtoken-vulnerability branch from 8b66e53 to 6ddcbdc Compare November 28, 2023 22:02
@renovate renovate bot force-pushed the renovate/npm-jsonwebtoken-vulnerability branch 4 times, most recently from 88a8246 to 35b79a9 Compare December 21, 2023 21:47
@renovate renovate bot force-pushed the renovate/npm-jsonwebtoken-vulnerability branch 2 times, most recently from a0fa281 to f45a7ca Compare January 4, 2024 23:25
@renovate renovate bot force-pushed the renovate/npm-jsonwebtoken-vulnerability branch 2 times, most recently from 4a333ee to 3c37ff8 Compare January 21, 2024 15:00
@renovate renovate bot force-pushed the renovate/npm-jsonwebtoken-vulnerability branch from 3c37ff8 to ae5cd7f Compare January 31, 2024 11:43
@renovate renovate bot force-pushed the renovate/npm-jsonwebtoken-vulnerability branch 2 times, most recently from 41ffbef to 392ceb2 Compare February 23, 2024 21:39
@renovate renovate bot force-pushed the renovate/npm-jsonwebtoken-vulnerability branch 2 times, most recently from 9a8cf0b to c1c1756 Compare March 1, 2024 21:56
@renovate renovate bot force-pushed the renovate/npm-jsonwebtoken-vulnerability branch from c1c1756 to f45ab1a Compare March 17, 2024 14:47
@renovate renovate bot force-pushed the renovate/npm-jsonwebtoken-vulnerability branch from f45ab1a to 5ae0147 Compare April 19, 2024 20:41
@renovate renovate bot force-pushed the renovate/npm-jsonwebtoken-vulnerability branch from 5ae0147 to fcb7d32 Compare April 28, 2024 20:54
@renovate renovate bot force-pushed the renovate/npm-jsonwebtoken-vulnerability branch from fcb7d32 to 8b05964 Compare May 2, 2024 23:56
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

0 participants