Module: Mongoid::Threaded
- Extended by:
- Threaded
- Included in:
- Threaded
- Defined in:
- lib/mongoid/threaded.rb,
lib/mongoid/threaded/lifecycle.rb
Overview
This module contains logic for easy access to objects that have a lifecycle on the current thread.
Defined Under Namespace
Modules: Lifecycle
Instance Method Summary collapse
-
#autosaved?(document) ⇒ true, false
Is the document autosaved on the current thread?.
-
#autosaves ⇒ Hash
Get all autosaves on the current thread.
-
#autosaves_for(klass) ⇒ Array
Get all autosaves on the current thread for the class.
-
#begin_autosave(document) ⇒ Object
Begin autosaving a document on the current thread.
-
#begin_execution(name) ⇒ true
Begin entry into a named thread local stack.
-
#begin_validate(document) ⇒ Object
Begin validating a document on the current thread.
-
#database_override ⇒ String, Symbol
Get the global database override.
-
#database_override=(name) ⇒ String, Symbol
Set the global database override.
-
#executing?(name) ⇒ true
Are in the middle of executing the named stack.
-
#exit_autosave(document) ⇒ Object
Exit autosaving a document on the current thread.
-
#exit_execution(name) ⇒ true
Exit from a named thread local stack.
-
#exit_validate(document) ⇒ Object
Exit validating a document on the current thread.
-
#scope_stack ⇒ Hash
Get the mongoid scope stack for chained criteria.
-
#session_override ⇒ String, Symbol
Get the global session override.
-
#session_override=(name) ⇒ String, Symbol
Set the global session override.
-
#sessions ⇒ Hash
Get the database sessions from the current thread.
-
#stack(name) ⇒ Array
Get the named stack.
-
#validated?(document) ⇒ true, false
Is the document validated on the current thread?.
-
#validations ⇒ Hash
Get all validations on the current thread.
-
#validations_for(klass) ⇒ Array
Get all validations on the current thread for the class.
Instance Method Details
#autosaved?(document) ⇒ true, false
Is the document autosaved on the current thread?
201 202 203 |
# File 'lib/mongoid/threaded.rb', line 201 def autosaved?(document) autosaves_for(document.class).include?(document.id) end |
#autosaves ⇒ Hash
Get all autosaves on the current thread.
227 228 229 |
# File 'lib/mongoid/threaded.rb', line 227 def autosaves Thread.current["[mongoid]:autosaves"] ||= {} end |
#autosaves_for(klass) ⇒ Array
Get all autosaves on the current thread for the class.
253 254 255 |
# File 'lib/mongoid/threaded.rb', line 253 def autosaves_for(klass) autosaves[klass] ||= [] end |
#begin_autosave(document) ⇒ Object
Begin autosaving a document on the current thread.
113 114 115 |
# File 'lib/mongoid/threaded.rb', line 113 def begin_autosave(document) autosaves_for(document.class).push(document.id) end |
#begin_execution(name) ⇒ true
Begin entry into a named thread local stack.
21 22 23 |
# File 'lib/mongoid/threaded.rb', line 21 def begin_execution(name) stack(name).push(true) end |
#begin_validate(document) ⇒ Object
Begin validating a document on the current thread.
125 126 127 |
# File 'lib/mongoid/threaded.rb', line 125 def begin_validate(document) validations_for(document.class).push(document.id) end |
#database_override ⇒ String, Symbol
Get the global database override.
33 34 35 |
# File 'lib/mongoid/threaded.rb', line 33 def database_override Thread.current["[mongoid]:db-override"] end |
#database_override=(name) ⇒ String, Symbol
Set the global database override.
47 48 49 |
# File 'lib/mongoid/threaded.rb', line 47 def database_override=(name) Thread.current["[mongoid]:db-override"] = name end |
#executing?(name) ⇒ true
Are in the middle of executing the named stack
73 74 75 |
# File 'lib/mongoid/threaded.rb', line 73 def executing?(name) !stack(name).empty? end |
#exit_autosave(document) ⇒ Object
Exit autosaving a document on the current thread.
137 138 139 |
# File 'lib/mongoid/threaded.rb', line 137 def exit_autosave(document) autosaves_for(document.class).delete_one(document.id) end |
#exit_execution(name) ⇒ true
Exit from a named thread local stack.
87 88 89 |
# File 'lib/mongoid/threaded.rb', line 87 def exit_execution(name) stack(name).pop end |
#exit_validate(document) ⇒ Object
Exit validating a document on the current thread.
149 150 151 |
# File 'lib/mongoid/threaded.rb', line 149 def exit_validate(document) validations_for(document.class).delete_one(document.id) end |
#scope_stack ⇒ Hash
Get the mongoid scope stack for chained criteria.
187 188 189 |
# File 'lib/mongoid/threaded.rb', line 187 def scope_stack Thread.current["[mongoid]:scope-stack"] ||= {} end |
#session_override ⇒ String, Symbol
Get the global session override.
161 162 163 |
# File 'lib/mongoid/threaded.rb', line 161 def session_override Thread.current["[mongoid]:session-override"] end |
#session_override=(name) ⇒ String, Symbol
Set the global session override.
175 176 177 |
# File 'lib/mongoid/threaded.rb', line 175 def session_override=(name) Thread.current["[mongoid]:session-override"] = name end |
#sessions ⇒ Hash
Get the database sessions from the current thread.
59 60 61 |
# File 'lib/mongoid/threaded.rb', line 59 def sessions Thread.current["[mongoid]:sessions"] ||= {} end |
#stack(name) ⇒ Array
Get the named stack.
101 102 103 |
# File 'lib/mongoid/threaded.rb', line 101 def stack(name) Thread.current["[mongoid]:#{name}-stack"] ||= [] end |
#validated?(document) ⇒ true, false
Is the document validated on the current thread?
215 216 217 |
# File 'lib/mongoid/threaded.rb', line 215 def validated?(document) validations_for(document.class).include?(document.id) end |
#validations ⇒ Hash
Get all validations on the current thread.
239 240 241 |
# File 'lib/mongoid/threaded.rb', line 239 def validations Thread.current["[mongoid]:validations"] ||= {} end |
#validations_for(klass) ⇒ Array
Get all validations on the current thread for the class.
266 267 268 |
# File 'lib/mongoid/threaded.rb', line 266 def validations_for(klass) validations[klass] ||= [] end |