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
This storage backend uses bcrypt to hash the tokens, but it shouldn't be necessary. The purpose of bcrypt is to take a low-entropy string and turn it into a high-entropy key, but we don't have that problem since the tokens are randomly generated and by default already have 2^128 bits of entropy.
Note that the number-based tokens would not be secure, but I'm not convinced they're secure even with bcrypt, since they only have 4-bytes of entropy.
The other reason for hashing is to protect people's other accounts if their password is leaked, but since this is a random token, we don't have that problem either.
Hashing the token does one thing for security, which is preventing an attacker with read access to the database from logging in, but you could get just as much protection with one round of SHA-1.
In case you're thinking this doesn't matter:
Installing the bcrypt library adds a significant amount of complexity as shown by the -bcrypt-node versions of each backend
Running bcrypt with difficulty=10 slows auth down to the point where it can only handle around 2-4 requests per second, which is a massive slowdown for something that's completely unnecessary.
The text was updated successfully, but these errors were encountered:
Removing this entirely might be complicated if you want to maintain backwards compatibility, but two easy fixes for the performance issue would be to replace the hard-coded difficulty of 10 with either the lowest-allowed value (probably 1 or 4), or add an option so people can set it themselves.
This storage backend uses
bcrypt
to hash the tokens, but it shouldn't be necessary. The purpose of bcrypt is to take a low-entropy string and turn it into a high-entropy key, but we don't have that problem since the tokens are randomly generated and by default already have 2^128 bits of entropy.Note that the number-based tokens would not be secure, but I'm not convinced they're secure even with
bcrypt
, since they only have 4-bytes of entropy.The other reason for hashing is to protect people's other accounts if their password is leaked, but since this is a random token, we don't have that problem either.
Hashing the token does one thing for security, which is preventing an attacker with read access to the database from logging in, but you could get just as much protection with one round of SHA-1.
In case you're thinking this doesn't matter:
bcrypt
library adds a significant amount of complexity as shown by the-bcrypt-node
versions of each backendThe text was updated successfully, but these errors were encountered: