1

我定义了一个 ActionMailer Observer 并且它没有被调用。我该如何解决这个问题?导轨 3.1.3,红宝石 1.9.2。或者,我想要一个在从某个 ActionMailer 子类发送电子邮件时调用的方法。这是我能找到的唯一干净的实现方式(我可以从 ActionMailer 子类中的每个邮件方法调用一个方法,但这不是很干)。欢迎任何其他关于如何实现这一点的建议。

config/initializers/mail_observer.rb:
  class MailObserver
    def self.delivered_email(message)
      require 'ruby-debug' ; debugger
      user = User.find_by_email(message.to[0])
      if user
        email_type = caller[1]
        UserMailerLogging.create!(user_id: @user.id, email_type: email_type, contents: self.body)
      end
    end
  end

  ActionMailer::Base.register_observer(MailObserver)

app/mailers/user_mailer:
  class UserMailer < ActionMailer::Base
    default from: "no-reply@testing.com"
    ...
    def unfinished_setup(user)
      @user = user
      mail to: user_email(user), subject: "Testing..."
    end
    ...
  end

而且,在 Rails 控制台中:

irb(main):001:0> UserMailer.unfinished_setup(User.find(1))    
=> #<Mail::Message:70192154395900, Multipart: false, Headers: <From: no-reply@testing.com>, <To: Test User<user@testing.com>>, <Subject: Testing...>, <Mime-Version: 1.0>, <Content-Type: text/plain>>
4

1 回答 1

3

我相信在你真正传递信息之前,观察者不会开火。您在 rails 控制台中的代码只是创建电子邮件,而不是发送它。添加.deliver到最后应该传递消息并执行观察者代码。

于 2013-02-14T22:56:08.673 回答