你可以使用ActiveRecord::脏 http://api.rubyonrails.org/classes/ActiveRecord/Dirty.html模块,它允许您跟踪未保存的更改。
E.g.
t1 = Ticket.first
t1.some_attribute = some_new_value
t1.changed? => true
t1.some_attribute_changed? => true
t1.some_attribute_was => old_value
因此,在 before_create 的 before_update 中,您应该执行这些操作(您只能在保存之前进行检查!)。
收集所有这些方法的一个非常好的地方是观察者级 http://api.rubyonrails.org/classes/ActiveRecord/Observer.htmlTicket Observer,这样您就可以将“观察者”代码与实际模型分开。
E.g.
class TicketObserver < ActiveRecord::Observer
def before_update
.. do some checking here ..
end
end
要启用观察者类,您需要将其添加到您的environment.rb
:
config.active_record.observers = :ticket_observer
这应该可以帮助你开始:)
链接的评论涉及什么。如果你这样做:
new_comment = ticket.ticket_comments.build
new_comment.new_record? => true
ticket.comments.changed => true
所以这正是您所需要的。这对你不起作用吗?
再次注意:当然,您需要在保存之前检查这一点:)
我想您必须收集在 before_create 或 before_update 中更改的数据,并在 after_update/create 中实际发送邮件(因为这样您就确定它成功了)。
显然目前还不清楚。我会让它更明确一点。我建议使用 TicketObserver 类。但如果你想使用回调,那就像这样:
class Ticked
before_save :check_state
after_save :send_mail_if_needed
def check_state
@logmsg=""
if ticket_comments.changed
# find the comment
ticket_comments.each do |c|
@logmsg << "comment changed" if c.changed?
@logmsg << "comment added" if c.new_record?
end
end
end
end
def send_mail_if_needed
if @logmsg.size > 0
..send mail..
end
end