Search code examples
ruby-on-railsemailcloudcontrol

Cloudcontrol Rails 3 mail


Problem: Errno::ECONNREFUSED (Connection refused - connect(2) for "localhost" port 25): on cloudcontrol server.

Environment smtp settings:

   config.action_mailer.smtp_settings = {
    address: "smtp.mandrillapp.com",
    port: 587,
    enable_starttls_auto: true, 
    user_name: ENV["MANDRILL_USER"],
    password: ENV["MANDRILL_PASSWORD"],
    authentication: 'login',
    domain: 'domain.example'
}

When checking the Project::Application.config.action_mailer.smtp_settings on server, receive this and it is correct:

{:address=>"smtp.mandrillapp.com", :port=>587, :enable_starttls_auto=>true, :user_name=>"correct_user", :password=>"correct_password", :authentication=>"login"}

But still cat't send email becouse of problem described above. Mailer somehow skips this settings and uses :address=>"localhost", :port=>25 If I use Net::SMTP directly with indicating the address and port on the server console it sends mail properly:

Net::SMTP.start('smtp.mandrillapp.com', 587, 'some_domain', ENV["MANDRILL_USER"], ENV["MANDRILL_PASSWORD"], :login) do |smtp|
 smtp.send_message msgstr, 
 '[email protected]',
 '[email protected]'
end

=> #<Net::SMTP::Response:0x007f1a6e763998 @status="250", @string="250 2.0.0 Ok: queued as B768D480191\n">

Can anyone help to set smtp settings on cloudcontrol? Or have I missed somethig about the cloudcontrol platform?

It is actually staging server...

Project::Application.configure do

 config.cache_classes = true
 config.action_controller.default_url_options = {:host => "staging_server_host"}
 config.action_mailer.default_url_options = {:host => 'staging_server_host'}
 config.consider_all_requests_local = false

 config.action_controller.perform_caching = true
 config.serve_static_assets = false
 config.action_mailer.delivery_method = :smtp

 config.action_mailer.perform_deliveries = true
 config.assets.compress = true
 config.assets.compile = true

 config.assets.digest = true
 config.log_level = :debug
 config.action_controller.asset_host = "staging_server_host"

 config.action_mailer.raise_delivery_errors = true
 config.i18n.fallbacks = true
 config.active_support.deprecation = :notify

 config.after_initialize do
   config.action_mailer.smtp_settings = {
       address: "smtp.mandrillapp.com",
       port: 587, # ports 587 and 2525 are also supported with STARTTLS
       enable_starttls_auto: true, # detects and uses STARTTLS
       user_name: ENV["MANDRILL_USER"],
       password: ENV["MANDRILL_PASSWORD"], # SMTP password is any valid mandrill API key
       authentication: 'login', # Mandrill supports 'plain' or 'login'
       domain: 'cloudcontrolapp.com', # your domain to identify your server when connecting
   }
 end
end

EDITED: Here is Procfile I found on server:

web: bundle exec thin start -R config.ru -e $RAILS_ENV -p $PORT
rake: bundle exec rake
worker: bundle exec rake jobs:work
console: bundle exec rails console

Solution

  • The problem was here in staging.rb:

    config.after_initialize do
      #adding smtp settings in this block was invisible (or too late) for staging.rb
    end
    

    Possibly it will help someone who is not familiar with rails initializing process. I am not really:)