aboutsummaryrefslogtreecommitdiffstats
path: root/actionmailer
diff options
context:
space:
mode:
authorDavid Heinemeier Hansson <david@loudthinking.com>2005-03-18 16:03:29 +0000
committerDavid Heinemeier Hansson <david@loudthinking.com>2005-03-18 16:03:29 +0000
commit38591db14ff43540cfc039d8fa9aa0001a8de7b8 (patch)
treeb2d9620bd7841eae6ee56c58f61d835611ec3541 /actionmailer
parent060b9b16aa4104858c13e4fd467b05c8e4fda127 (diff)
downloadrails-38591db14ff43540cfc039d8fa9aa0001a8de7b8.tar.gz
rails-38591db14ff43540cfc039d8fa9aa0001a8de7b8.tar.bz2
rails-38591db14ff43540cfc039d8fa9aa0001a8de7b8.zip
Added better quoting and attachments handling in anticipation for ActionMailer::Receiver framework
git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@916 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
Diffstat (limited to 'actionmailer')
-rw-r--r--actionmailer/lib/action_mailer/vendor/tmail/attachments.rb25
-rwxr-xr-xactionmailer/lib/action_mailer/vendor/tmail/mail.rb2
-rw-r--r--actionmailer/lib/action_mailer/vendor/tmail/quoting.rb81
3 files changed, 108 insertions, 0 deletions
diff --git a/actionmailer/lib/action_mailer/vendor/tmail/attachments.rb b/actionmailer/lib/action_mailer/vendor/tmail/attachments.rb
new file mode 100644
index 0000000000..fb6629d67e
--- /dev/null
+++ b/actionmailer/lib/action_mailer/vendor/tmail/attachments.rb
@@ -0,0 +1,25 @@
+require 'stringio'
+
+module TMail
+ class Attachment < StringIO
+ attr_accessor :original_filename, :content_type
+ end
+
+ class Mail
+ def has_attachments?
+ multipart? && parts.any? { |part| part.header["content-type"].main_type != "text" }
+ end
+
+ def attachments
+ if multipart?
+ parts.collect { |part|
+ if part.header["content-type"].main_type != "text"
+ attachment = Attachment.new(Base64.decode64(part.body))
+ attachment.original_filename = part.header["content-type"].params["name"].strip.dup
+ attachment
+ end
+ }.compact
+ end
+ end
+ end
+end \ No newline at end of file
diff --git a/actionmailer/lib/action_mailer/vendor/tmail/mail.rb b/actionmailer/lib/action_mailer/vendor/tmail/mail.rb
index bfea9b6db4..85a80fd29c 100755
--- a/actionmailer/lib/action_mailer/vendor/tmail/mail.rb
+++ b/actionmailer/lib/action_mailer/vendor/tmail/mail.rb
@@ -14,6 +14,8 @@ require 'tmail/header'
require 'tmail/port'
require 'tmail/config'
require 'tmail/utils'
+require 'tmail/attachments'
+require 'tmail/quoting'
require 'socket'
diff --git a/actionmailer/lib/action_mailer/vendor/tmail/quoting.rb b/actionmailer/lib/action_mailer/vendor/tmail/quoting.rb
new file mode 100644
index 0000000000..1a882934c9
--- /dev/null
+++ b/actionmailer/lib/action_mailer/vendor/tmail/quoting.rb
@@ -0,0 +1,81 @@
+require 'iconv'
+require 'base64'
+
+module TMail
+ class Mail
+ def unquoted_subject(to_charset = 'utf-8')
+ Unquoter.unquote_and_convert_to(subject, to_charset)
+ end
+
+ def unquoted_body(to_charset = 'utf-8')
+ Unquoter.unquote_and_convert_to(body, to_charset, header["content-type"]["charset"])
+ end
+
+ def unquoted_body_with_all_parts(to_charset = 'utf-9', &block)
+ attachment_presenter = block || Proc.new { |file_name| "Attachment: #{file_name}\n" }
+
+ if multipart?
+ parts.collect { |part|
+ part.header["content-type"].main_type == "text" ?
+ part.unquoted_body : attachment_presenter.call(part.header["content-type"].params["name"])
+ }.join
+ else
+ unquoted_body
+ end
+ end
+ end
+
+ class Unquoter
+ class << self
+ def unquote_and_convert_to(text, to_charset, from_charset = "iso-8859-1")
+ if text =~ /^=\?(.*?)\?(.)\?(.*)\?=$/
+ from_charset = $1
+ quoting_method = $2
+ text = $3
+ case quoting_method
+ when "Q" then
+ unquote_quoted_printable_and_convert_to(text, from_charset, to_charset)
+ when "B" then
+ unquote_base64_and_convert_to(text, from_charset, to_charset)
+ else
+ raise "unknown quoting method #{quoting_method.inspect}"
+ end
+ else
+ unquote_quoted_printable_and_convert_to(text, from_charset, to_charset)
+ end
+ end
+
+ def unquote_quoted_printable_and_convert_to(text, from, to)
+ Iconv.iconv(to, from, text.gsub(/_/," ").unpack("M*").first).first
+ end
+
+ def unquote_base64_and_convert_to(text, from, to)
+ Iconv.iconv(to, from, Base64.decode64(text)).first
+ end
+ end
+ end
+end
+
+if __FILE__ == $0
+ require 'test/unit'
+
+ class TC_Unquoter < Test::Unit::TestCase
+ def test_unquote_quoted_printable
+ a ="=?ISO-8859-1?Q?[166417]_Bekr=E6ftelse_fra_Rejsefeber?="
+ b = TMail::Unquoter.unquote_and_convert_to(a, 'utf-8')
+ assert_equal "[166417] Bekr\303\246ftelse fra Rejsefeber", b
+ end
+
+ def test_unquote_base64
+ a ="=?ISO-8859-1?B?WzE2NjQxN10gQmVrcuZmdGVsc2UgZnJhIFJlanNlZmViZXI=?="
+ b = TMail::Unquoter.unquote_and_convert_to(a, 'utf-8')
+ assert_equal "[166417] Bekr\303\246ftelse fra Rejsefeber", b
+ end
+
+ def test_unquote_without_charset
+ a ="[166417]_Bekr=E6ftelse_fra_Rejsefeber"
+ b = TMail::Unquoter.unquote_and_convert_to(a, 'utf-8')
+ assert_equal "[166417] Bekr\303\246ftelse fra Rejsefeber", b
+ end
+ end
+end