fix: differentiate between missing sessions and internal server errors #3975
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Our consumer of the
whoami
call caches both authorized and unauthorized responses from Kratos. If a session is unauthorized, we should not ping Kratos again for the duration of the cache. However, if Kratos itself had a problem, such as a database error, these responses were coming back as 401s as well. And now we have this potentially false unauthorized response in our cache.Instead, a 500 is the correct response for a Kratos failure. That way our cache can choose to do nothing with this response and not end up with a poisoned cache.
With this change, an invalid session continued to produce a 401. Valid sessions continue to produce a 200. A Kratos failure, such as a database problem, produces a 500.
Checklist
introduces a new feature.
contributing code guidelines.
vulnerability. If this pull request addresses a security vulnerability, I
confirm that I got the approval (please contact
[email protected]) from the maintainers to push
the changes.
works.
Further Comments