Actionmailer SMTP Server Response

北战南征 提交于 2019-12-09 03:09:34

问题


When sending mail through actionmailer, the actionmailer gets a response from the SMTP server, when its ok, or when its wrong. Is there a way to retrieve this response after sending a mail? Also when no errors are thrown by the SMTP server?

Our qmail mail server throws a handler id which we want to use for tracing e-mails.

As an example, the server response is this :

250 ok 1308235825 qp 17832


回答1:


Set return_response: true in the smtp settings and call message.deliver! instead of deliver. This returns the SMTP server response, a Net::SMTP::Response, which contains the server response you're looking for.

If you need a log of all responses from the connection with the server, not just the final result, you'll need to dig into Net::SMTP.




回答2:


Looking at the the source you can define an observer:

in base.rb

  # Register an Observer which will be notified when mail is delivered.
  # Either a class or a string can be passed in as the Observer. If a string is passed in
  # it will be <tt>constantize</tt>d.
  def register_observer(observer)
    delivery_observer = (observer.is_a?(String) ? observer.constantize : observer)
    Mail.register_observer(delivery_observer)
  end

So you could use some code like this in an initialization file:

class MailObserver
  def self.delivered_email(message)
    logger_info "Sent Message: #{message}"
  end
end

ActionMailer::Base.register_observer(MailObserver)

That will log sent mail and you can see if you can get the headers or response from the sent mail object.



来源:https://stackoverflow.com/questions/6374648/actionmailer-smtp-server-response

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!