You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Of course users should not call it with empty secret but that will usually come from some configuration file, environment variable or secret store, and it is possible to have a bug somewhere along that chain and accidentally initialize it to empty value. Having the encode call fail would be safer.
This would technically be a breaking API change and there might be intentional calls with empty secret such as in tests, but I think those would be easy to swap to another non-empty test string.
The text was updated successfully, but these errors were encountered:
If you look at the RFC specification, you can see that there is a none algorithm which MUST be implemented. This is correctly done in this library. You can see that there is specific handling of the none algorithm scenario in algorithms.py.
I do agree that having no secret is very counter intuitive, but it is a valid option for a JWT.
I think it would be a good idea for
jwt.encode
to raise an exception if the secret argument is an empty string.https://vulnapi.cerberauth.com/docs/vulnerabilities/broken-authentication/jwt-blank-secret
Right now it works but produces JWT that is trivially spoofed:
Of course users should not call it with empty secret but that will usually come from some configuration file, environment variable or secret store, and it is possible to have a bug somewhere along that chain and accidentally initialize it to empty value. Having the encode call fail would be safer.
This would technically be a breaking API change and there might be intentional calls with empty secret such as in tests, but I think those would be easy to swap to another non-empty test string.
The text was updated successfully, but these errors were encountered: