Fix: Where clauses with named arguments may cause generation of unintended queries #4937
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.
What did this pull request do?
During the building of Where clauses, the NamedExpr type is omitted while determining whether the expression should be wrapped in parentheses. Therefore, although it is required, Where clauses containing both named arguments and OR conditions are not wrapped, and this causes the generation of different queries than desired. This pull request tries to fix this issue.
User Case Description
eg:
For the gorm statement below,
the following query is generated.
Due to the precedence of
AND
overOR
, the query will be interpreted like`WHERE role = 'admin' or (role = 'super_admin' AND users.deleted_at IS NULL)`
instead of
`WHERE (role = 'admin' or role = 'super_admin') AND users.deleted_at IS NULL`
which is actually intended, and it leads to getting softly deleted admin users without being aware, which may also be dangerous.