module ActiveSupport::Callbacks::ClassMethods
def skip_callback(name, *filter_list, &block)
An ArgumentError will be raised if the callback has not
saved
- save
saving...
Output:
young_writer.save
young_writer.age = 17
young_writer = Writer.new
When if option returns false, callback is NOT skipped.
saved
- save
Output:
writer.save
writer.age = 20
writer = Writer.new
When if option returns true, callback is skipped.
end
skip_callback :save, :before, :saving_message, if: -> { age > 18 }
attr_accessor :age
class Writer < PersonRecord
can see defined here[rdoc-ref:ActiveSupport::Callbacks]
Note: this example uses +PersonRecord+ and +#saving_message+, which you
callback is skipped.
:unless options may be passed in order to control when the
Skip a previously set callback. Like #set_callback, :if or
def skip_callback(name, *filter_list, &block) type, filters, options = normalize_callback_params(filter_list, block) options[:raise] = true unless options.key?(:raise) __update_callbacks(name) do |target, chain| filters.each do |filter| callback = chain.find { |c| c.matches?(type, filter) } if !callback && options[:raise] raise ArgumentError, "#{type.to_s.capitalize} #{name} callback #{filter.inspect} has not been defined" end if callback && (options.key?(:if) || options.key?(:unless)) new_callback = callback.merge_conditional_options(chain, if_option: options[:if], unless_option: options[:unless]) chain.insert(chain.index(callback), new_callback) end chain.delete(callback) end target.set_callbacks name, chain end end