Module: ActionMailerWithRequest::MailerDefaultUrlOptions

Defined in:
lib/actionmailer_with_request.rb

Class Method Summary collapse

Instance Method Summary collapse

Class Method Details

.included(base) ⇒ Object



19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
# File 'lib/actionmailer_with_request.rb', line 19

def self.included(base)
  base.class_eval <<-RUBY, __FILE__, __LINE__ + 1
    # Extends ActionMailer#default_url_options capabilities
    # by merging the latest request context into the default url options.
    #
    # Returns the default url options Hash.
    def default_url_options_with_current_request(*args)
      defaults = {}
      request  = Thread.current[:request]

      if request
        host     = request.host
        port     = request.port
        protocol = request.protocol
        standard_port = request.standard_port

        defaults[:protocol] = protocol
        defaults[:host]     = host
        defaults[:port]     = port if port != standard_port
      end

      default_url_options_without_current_request(*args).merge(defaults)
    end

    alias_method_chain :default_url_options, :current_request
  RUBY
end

Instance Method Details

#requestObject

Get the current request. This assists in making request-based e-mail addresses. For example:

mail :from => "no-reply@#{request.try(:domain) || 'example.com'}", .....

Remember if the mailer is delivered outside the context of a request then this method returns nil. Hence the try(:domain) as well as the fallback domain.



55
56
57
# File 'lib/actionmailer_with_request.rb', line 55

def request
  Thread.current[:request]
end