Rails 5.1+
class Page < ActiveRecord::Base
before_save :do_something, if: :will_save_change_to_status_id?
private
def do_something
# ...
end
end
O commit que alterou ActiveRecord :: Dirty está aqui: https://github.com/rails/rails/commit/16ae3db5a5c6a08383b974ae6c96faac5b4a3c81
Aqui está uma postagem do blog sobre essas mudanças: https://www.ombulabs.com/blog/rails/upgrades/active-record-5-1-api-changes.html
Aqui está o resumo que fiz para mim mesmo nas mudanças em ActiveRecord :: Dirty in Rails 5.1+:
ActiveRecord :: Dirty
https://api.rubyonrails.org/classes/ActiveRecord/AttributeMethods/Dirty.html
Antes de salvar (ALTERAÇÃO OPCIONAL)
Depois de modificar um objeto e antes de salvá-lo no banco de dados ou dentro do before_save
filtro:
changes
agora deveria ser changes_to_save
changed?
agora deveria ser has_changes_to_save?
changed
agora deveria ser changed_attribute_names_to_save
<attribute>_change
agora deveria ser <attribute>_change_to_be_saved
<attribute>_changed?
agora deveria ser will_save_change_to_<attribute>?
<attribute>_was
agora deveria ser <attribute>_in_database
Depois de salvar (BREAKING CHANGE)
Depois de modificar um objeto e depois de salvá-lo no banco de dados ou dentro do after_save
filtro:
saved_changes
(substitui previous_changes
)
saved_changes?
saved_change_to_<attribute>
saved_change_to_<attribute>?
<attribute>_before_last_save
Rails <= 5,0
class Page < ActiveRecord::Base
before_save :do_something, if: :status_id_changed?
private
def do_something
# ...
end
end
Isso utiliza o fato de que o before_save
retorno de chamada pode ser executado condicionalmente com base no valor de retorno de uma chamada de método. O status_id_changed?
método vem de ActiveModel :: Dirty , que nos permite verificar se um atributo específico foi alterado simplesmente anexando_changed?
ao nome do atributo.
Quando o do_something
método deve ser chamado, depende de suas necessidades. Pode ser before_save
ou after_save
qualquer um dos ActiveRecord :: Callbacks definidos .