Ответ cwninja должен помочь, но есть кое-что еще.
Прежде всего, обработка базовых атрибутов выполняется с помощью метода write_attribute, поэтому вам следует воспользоваться этим.
Rails также имеет встроенную структуру обратного вызова, к которой было бы неплохо подключиться, хотя она не позволяет передавать аргументы, что немного раздражает.
Используя пользовательские обратные вызовы, вы можете сделать это так:
class Person < ActiveRecord::Base
def write_attribute(attr_name, value)
attribute_changed(attr_name, read_attribute(attr_name), value)
super
end
private
def attribute_changed(attr, old_val, new_val)
logger.info "Attribute Changed: #{attr} from #{old_val} to #{new_val}"
end
end
Если вы хотите попробовать использовать обратные вызовы Rails (особенно полезно, если у вас может быть несколько обратных вызовов и / или подклассов), вы можете сделать что-то вроде этого:
class Person < ActiveRecord::Base
define_callbacks :attribute_changed
attribute_changed :notify_of_attribute_change
def write_attribute(attr_name, value)
returning(super) do
@last_changed_attr = attr_name
run_callbacks(:attribute_changed)
end
end
private
def notify_of_attribute_change
attr = @last_changed_attr
old_val, new_val = send("#{attr}_change")
logger.info "Attribute Changed: #{attr} from #{old_val} to #{new_val}"
end
end