argon2 support #308

Merged
toast merged 5 commits from argon2 into main 2022-12-29 20:13:48 +00:00
Owner

Passwords will be automatically re-hashed on sign-in.
All new password hashes will be argon2 by default.

This uses argon2id and is not configurable (mostly since it's the default and I couldn't be bothered).
In the very unlikely case someone has more specific needs (e.g wants the additional resistance to side-channel attacks from using pure argon2i, or is worried about gpu attacks and wants to use argon2d), a fork is recommended (since there are many other parts of the codebase that would need significant modification).

Due to the change in attitude towards configurability, it's recommended this be squash-merged.

ChangeLog: Added

Passwords will be automatically re-hashed on sign-in. All new password hashes will be argon2 by default. This uses argon2id and is not configurable (mostly since it's the default and I couldn't be bothered). In the very unlikely case someone has more specific needs (e.g wants the additional resistance to side-channel attacks from using pure argon2i, or is worried about gpu attacks and wants to use argon2d), a fork is recommended (since there are many other parts of the codebase that would need significant modification). Due to the change in attitude towards configurability, it's recommended this be squash-merged. ChangeLog: Added
toast added 5 commits 2022-12-28 17:06:37 +00:00
backend: add support for argon2id hashes
All checks were successful
ci/woodpecker/push/lint-client Pipeline was successful
ci/woodpecker/push/lint-backend Pipeline was successful
ci/woodpecker/push/build Pipeline was successful
ci/woodpecker/push/lint-foundkey-js Pipeline was successful
ci/woodpecker/push/lint-sw Pipeline was successful
ci/woodpecker/push/test Pipeline was successful
71c6eaa66e
Still TODO: automatically rehash passwords on login, somehow.

ChangeLog: Added
fixup! backend: add support for argon2id hashes
All checks were successful
ci/woodpecker/push/lint-backend Pipeline was successful
ci/woodpecker/push/build Pipeline was successful
ci/woodpecker/push/lint-client Pipeline was successful
ci/woodpecker/push/lint-foundkey-js Pipeline was successful
ci/woodpecker/push/lint-sw Pipeline was successful
ci/woodpecker/push/test Pipeline was successful
80042d9b77
backend: automatically rehash old algorithm passwords on signin
Some checks failed
ci/woodpecker/push/lint-client Pipeline was successful
ci/woodpecker/push/lint-foundkey-js Pipeline was successful
ci/woodpecker/push/build Pipeline was successful
ci/woodpecker/push/lint-backend Pipeline was successful
ci/woodpecker/push/lint-sw Pipeline was successful
ci/woodpecker/push/test Pipeline was successful
ci/woodpecker/pr/lint-foundkey-js Pipeline was successful
ci/woodpecker/pr/lint-client Pipeline failed
ci/woodpecker/pr/lint-backend Pipeline failed
ci/woodpecker/pr/build Pipeline was successful
ci/woodpecker/pr/lint-sw Pipeline failed
ci/woodpecker/pr/test Pipeline failed
520ae2fc61
Johann150 reviewed 2022-12-28 20:28:09 +00:00
@ -69,6 +69,11 @@ export default async (ctx: Koa.Context) => {
// Compare password
const same = await comparePassword(password, profile.password!);
if (same && isOldAlgorithm(profile.password!)) {
Owner

I'm not sure if putting this here before potential other checks doesn't make it susceptible to timing attacks?

I'm not sure if putting this here before potential other checks doesn't make it susceptible to timing attacks?
Author
Owner

same is a static check and short circuits.
If same is true, the login would already be successful.
The only difference in timing would be in case of successful validation, in which case it's also static except for ONE time when the hash is updated (and it's already updated by the time you can figure that out).

`same` is a static check and short circuits. If `same` is true, the login would already be successful. The only difference in timing would be in case of successful validation, in which case it's also static except for ONE time when the hash is updated (and it's already updated by the time you can figure that out).
Author
Owner

same is a static check and short circuits.
If same is true, the login would already be successful.
The only difference in timing would be in case of successful validation, in which case it's also static except for ONE time when the hash is updated (and it's already updated by the time you can figure that out).

`same` is a static check and short circuits. If `same` is true, the login would already be successful. The only difference in timing would be in case of successful validation, in which case it's also static except for ONE time when the hash is updated (and it's already updated by the time you can figure that out).
toast marked this conversation as resolved
Owner

Other than the comment above seems fine to me.

Other than the comment above seems fine to me.
Johann150 added a new dependency 2022-12-28 20:41:38 +00:00
toast merged commit ed9d4023d4 into main 2022-12-29 20:13:48 +00:00
toast referenced this pull request from a commit 2022-12-29 20:13:48 +00:00
Sign in to join this conversation.
No reviewers
No labels
feature
fix
upkeep
No milestone
No project
No assignees
2 participants
Notifications
Due date
The due date is invalid or out of range. Please use the format "yyyy-mm-dd".

No due date set.

Reference: FoundKeyGang/FoundKey#308
No description provided.