Module: Mongoid::Interceptable
- Extended by:
- ActiveSupport::Concern
- Included in:
- Composable
- Defined in:
- lib/mongoid/interceptable.rb
Overview
This module contains all the callback hooks for Mongoid.
Constant Summary collapse
- CALLBACKS =
[ :after_build, :after_create, :after_destroy, :after_find, :after_initialize, :after_save, :after_touch, :after_update, :after_upsert, :after_validation, :around_create, :around_destroy, :around_save, :around_update, :around_upsert, :before_create, :before_destroy, :before_save, :before_update, :before_upsert, :before_validation ].freeze
Instance Method Summary collapse
-
#callback_executable?(kind) ⇒ true, false
Is the provided type of callback executable by this document?.
-
#in_callback_state?(kind) ⇒ true, false
Is the document currently in a state that could potentially require callbacks to be executed?.
-
#run_after_callbacks(*kinds) ⇒ Object
Run only the after callbacks for the specific event.
-
#run_before_callbacks(*kinds) ⇒ Object
Run only the before callbacks for the specific event.
-
#run_callbacks(kind, *args, &block) ⇒ Document
Run the callbacks for the document.
Instance Method Details
#callback_executable?(kind) ⇒ true, false
Is the provided type of callback executable by this document?
54 55 56 |
# File 'lib/mongoid/interceptable.rb', line 54 def callback_executable?(kind) respond_to?("_#{kind}_callbacks") end |
#in_callback_state?(kind) ⇒ true, false
Is the document currently in a state that could potentially require callbacks to be executed?
69 70 71 |
# File 'lib/mongoid/interceptable.rb', line 69 def in_callback_state?(kind) [ :create, :destroy ].include?(kind) || new_record? || flagged_for_destroy? || changed? end |
#run_after_callbacks(*kinds) ⇒ Object
ActiveSupport does not allow this type of behaviour by default, so Mongoid has to get around it and implement itself.
Run only the after callbacks for the specific event.
86 87 88 89 90 |
# File 'lib/mongoid/interceptable.rb', line 86 def run_after_callbacks(*kinds) kinds.each do |kind| run_targeted_callbacks(:after, kind) end end |
#run_before_callbacks(*kinds) ⇒ Object
ActiveSupport does not allow this type of behaviour by default, so Mongoid has to get around it and implement itself.
Run only the before callbacks for the specific event.
105 106 107 108 109 |
# File 'lib/mongoid/interceptable.rb', line 105 def run_before_callbacks(*kinds) kinds.each do |kind| run_targeted_callbacks(:before, kind) end end |
#run_callbacks(kind, *args, &block) ⇒ Document
Run the callbacks for the document. This overrides active support’s functionality to cascade callbacks to embedded documents that have been flagged as such.
126 127 128 129 130 131 132 133 134 135 136 137 138 139 |
# File 'lib/mongoid/interceptable.rb', line 126 def run_callbacks(kind, *args, &block) cascadable_children(kind).each do |child| # This is returning false for some destroy tests on 4.1.0.beta1, # causing them to fail since 4.1.0 expects a block to be passed if the # callbacks for the type are empty. If no block is passed then the nil # return value gets interpreted as false and halts the chain. # # @see https://github.com/rails/rails/blob/master/activesupport/lib/active_support/callbacks.rb#L79 if child.run_callbacks(child_callback_type(kind, child), *args) == false return false end end callback_executable?(kind) ? super(kind, *args, &block) : true end |