Module: Mongoid::Scopable::ClassMethods
- Defined in:
- lib/mongoid/scopable.rb
Instance Method Summary collapse
-
#default_scopable? ⇒ true | false
Is the class able to have the default scope applied?.
-
#default_scope(value = nil) ⇒ Proc
Add a default scope to the model.
-
#queryable ⇒ Criteria
private
Get a queryable, either the last one on the scope stack or a fresh one.
-
#scope(name, value, &block) ⇒ Object
Create a scope that can be accessed from the class level or chained to criteria by the provided name.
-
#scoped(options = nil) ⇒ Criteria
Get a criteria for the document with normal scoping.
-
#scopes ⇒ Hash
Returns a hash of all the scopes defined for this class, including scopes defined on ancestor classes.
-
#unscoped ⇒ Criteria | Object
Get the criteria without the default scoping applied.
-
#with_default_scope ⇒ Criteria
(also: #criteria)
Get a criteria with the default scope applied, if possible.
-
#with_scope(criteria) ⇒ Criteria
Pushes the provided criteria onto the scope stack, and removes it after the provided block is yielded.
-
#without_default_scope ⇒ Object
Execute the block without applying the default scope.
Instance Method Details
#default_scopable? ⇒ true | false
Is the class able to have the default scope applied?
94 95 96 |
# File 'lib/mongoid/scopable.rb', line 94 def default_scopable? default_scoping? && !Threaded.without_default_scope?(self) end |
#default_scope(value = nil) ⇒ Proc
Add a default scope to the model. This scope will be applied to all criteria unless #unscoped is specified.
82 83 84 85 86 |
# File 'lib/mongoid/scopable.rb', line 82 def default_scope(value = nil) value = Proc.new { yield } if block_given? check_scope_validity(value) self.default_scoping = process_default_scope(value) end |
#queryable ⇒ Criteria
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
Get a queryable, either the last one on the scope stack or a fresh one.
106 107 108 109 110 |
# File 'lib/mongoid/scopable.rb', line 106 def queryable crit = Threaded.current_scope(self) || Criteria.new(self) crit. = true if (crit.klass. && !crit.klass.cyclic?) crit end |
#scope(name, value, &block) ⇒ Object
Create a scope that can be accessed from the class level or chained to criteria by the provided name.
131 132 133 134 135 136 137 138 139 140 |
# File 'lib/mongoid/scopable.rb', line 131 def scope(name, value, &block) normalized = name.to_sym check_scope_validity(value) check_scope_name(normalized) _declared_scopes[normalized] = { scope: value, extension: Module.new(&block) } define_scope_method(normalized) end |
#scoped(options = nil) ⇒ Criteria
This will force the default scope to be applied.
Get a criteria for the document with normal scoping.
157 158 159 |
# File 'lib/mongoid/scopable.rb', line 157 def scoped( = nil) queryable.scoped() end |
#scopes ⇒ Hash
Returns a hash of all the scopes defined for this class, including scopes defined on ancestor classes.
50 51 52 53 54 55 56 57 58 |
# File 'lib/mongoid/scopable.rb', line 50 def scopes defined_scopes = {} ancestors.reverse.each do |klass| if klass.respond_to?(:_declared_scopes) defined_scopes.merge!(klass._declared_scopes) end end defined_scopes.freeze end |
#unscoped ⇒ Criteria | Object
This will force the default scope to be removed, but will not remove scopes declared with “.with_scope“. This will be changed in Mongoid 9.
Get the criteria without the default scoping applied.
177 178 179 180 181 182 183 184 185 |
# File 'lib/mongoid/scopable.rb', line 177 def unscoped if block_given? without_default_scope do yield(self) end else queryable.unscoped end end |
#with_default_scope ⇒ Criteria Also known as: criteria
Get a criteria with the default scope applied, if possible.
193 194 195 |
# File 'lib/mongoid/scopable.rb', line 193 def with_default_scope queryable.with_default_scope end |
#with_scope(criteria) ⇒ Criteria
Pushes the provided criteria onto the scope stack, and removes it after the provided block is yielded.
207 208 209 210 211 212 213 214 215 216 217 218 219 |
# File 'lib/mongoid/scopable.rb', line 207 def with_scope(criteria) previous = Threaded.current_scope(self) Threaded.set_current_scope(criteria, self) begin yield criteria ensure if Mongoid.broken_scoping Threaded.set_current_scope(nil, self) else Threaded.set_current_scope(previous, self) end end end |
#without_default_scope ⇒ Object
Execute the block without applying the default scope.
229 230 231 232 233 234 |
# File 'lib/mongoid/scopable.rb', line 229 def without_default_scope Threaded.begin_without_default_scope(self) yield ensure Threaded.exit_without_default_scope(self) end |