-
-
Notifications
You must be signed in to change notification settings - Fork 92
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Ability to add options to scopes #47
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
👍
I like the idea and the proposed implementation.
Left a few comments.
Feel free to continue with docs and changelog!
Btw, could you share your use-case (and, probably, include it into the docs)?
lib/action_policy/testing.rb
Outdated
policy_class == policy.class && | ||
type == actual_type && | ||
name == actual_name | ||
name == actual_name && | ||
scope_options == actual_scope_options |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Suggestion: what if we use ===
here?
That would allow us to use RSpec composed matchers (like a_hash_including(...)
).
Updated PR, @palkan |
CHANGELOG.md
Outdated
# user_policy.rb | ||
describe UserPolicy < Application do | ||
relation_scope do |relation, with_deleted: false| | ||
if with_deleted |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Let's update an example a little bit to make it less abstract:
relation_scope do |relation, with_deleted: false|
some_logic(relation).yield_self do |rel|
with_deleted ? rel.with_deleted : rel
end
end
wdyt?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
sure, it might help a bit with understanding
Thanks! |
Hi! Thank you for a great gem!
What is the purpose of this pull request?
Add the ability to add options to Scopes so it can be declared like this:
And instead of several scopes can be created only one
It can be used this way:
authorized(blabla, type: :relation, with_deleted: true)
would look better, but I don't think we need to mix policy lookup options with scope optionsWhat changes did you make? (overview)
Behaviour#authorized
Scoping#apply_scope
and made it pass to the policy only when options are present to not break existing scopes which don't expect optionsIs there anything you'd like reviewers to focus on?
If you like the idea and the syntax, I'll add specs, documentation, and changelog for it
PR checklist: