Skip to content

Commit

Permalink
setup smtp settings
Browse files Browse the repository at this point in the history
  • Loading branch information
danielvlopes committed Jan 27, 2010
1 parent 9e7792c commit 31eff82
Show file tree
Hide file tree
Showing 3 changed files with 73 additions and 1 deletion.
1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
config/database.yml
config/initializers/smtp_settings.rb
coverage
db/schema.*
db/*.sqlite3
Expand Down
6 changes: 5 additions & 1 deletion config/environments/production.rb
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
require 'smtp_tls'
# Settings specified here will take precedence over those in config/environment.rb

# The production environment is meant for finished, "live" apps.
Expand Down Expand Up @@ -25,4 +26,7 @@
# config.action_mailer.raise_delivery_errors = false

# Enable threaded mode
# config.threadsafe!
# config.threadsafe!

config.action_mailer.raise_delivery_errors = true
config.action_mailer.delivery_method = :smtp
67 changes: 67 additions & 0 deletions lib/smtp_tls.rb
Original file line number Diff line number Diff line change
@@ -0,0 +1,67 @@
require "openssl"
require "net/smtp"

Net::SMTP.class_eval do
private
def do_start(helodomain, user, secret, authtype)
raise IOError, 'SMTP session already started' if @started
check_auth_args user, secret, authtype if user or secret

sock = timeout(@open_timeout) { TCPSocket.open(@address, @port) }
@socket = Net::InternetMessageIO.new(sock)
@socket.read_timeout = 60 #@read_timeout
#@socket.debug_output = STDERR #@debug_output

check_response(critical { recv_response() })
do_helo(helodomain)

if starttls
raise 'openssl library not installed' unless defined?(OpenSSL)
ssl = OpenSSL::SSL::SSLSocket.new(sock)
ssl.sync_close = true
ssl.connect
@socket = Net::InternetMessageIO.new(ssl)
@socket.read_timeout = 60 #@read_timeout
#@socket.debug_output = STDERR #@debug_output
do_helo(helodomain)
end

authenticate user, secret, authtype if user
@started = true
ensure
unless @started
# authentication failed, cancel connection.
@socket.close if not @started and @socket and not @socket.closed?
@socket = nil
end
end

def do_helo(helodomain)
begin
if @esmtp
ehlo helodomain
else
helo helodomain
end
rescue Net::ProtocolError
if @esmtp
@esmtp = false
@error_occured = false
retry
end
raise
end
end

def starttls
getok('STARTTLS') rescue return false
return true
end

def quit
begin
getok('QUIT')
rescue EOFError, OpenSSL::SSL::SSLError
end
end
end

0 comments on commit 31eff82

Please sign in to comment.