mail-portertech 2.6.2.edge

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (153) hide show
  1. checksums.yaml +7 -0
  2. data/CHANGELOG.rdoc +753 -0
  3. data/CONTRIBUTING.md +60 -0
  4. data/Dependencies.txt +2 -0
  5. data/Gemfile +15 -0
  6. data/MIT-LICENSE +20 -0
  7. data/README.md +683 -0
  8. data/Rakefile +29 -0
  9. data/TODO.rdoc +9 -0
  10. data/lib/mail.rb +91 -0
  11. data/lib/mail/attachments_list.rb +104 -0
  12. data/lib/mail/body.rb +291 -0
  13. data/lib/mail/check_delivery_params.rb +20 -0
  14. data/lib/mail/configuration.rb +75 -0
  15. data/lib/mail/core_extensions/nil.rb +19 -0
  16. data/lib/mail/core_extensions/object.rb +13 -0
  17. data/lib/mail/core_extensions/smtp.rb +24 -0
  18. data/lib/mail/core_extensions/string.rb +43 -0
  19. data/lib/mail/core_extensions/string/access.rb +145 -0
  20. data/lib/mail/core_extensions/string/multibyte.rb +78 -0
  21. data/lib/mail/elements.rb +14 -0
  22. data/lib/mail/elements/address.rb +270 -0
  23. data/lib/mail/elements/address_list.rb +51 -0
  24. data/lib/mail/elements/content_disposition_element.rb +26 -0
  25. data/lib/mail/elements/content_location_element.rb +21 -0
  26. data/lib/mail/elements/content_transfer_encoding_element.rb +17 -0
  27. data/lib/mail/elements/content_type_element.rb +31 -0
  28. data/lib/mail/elements/date_time_element.rb +22 -0
  29. data/lib/mail/elements/envelope_from_element.rb +39 -0
  30. data/lib/mail/elements/message_ids_element.rb +24 -0
  31. data/lib/mail/elements/mime_version_element.rb +22 -0
  32. data/lib/mail/elements/phrase_list.rb +16 -0
  33. data/lib/mail/elements/received_element.rb +26 -0
  34. data/lib/mail/encodings.rb +304 -0
  35. data/lib/mail/encodings/7bit.rb +31 -0
  36. data/lib/mail/encodings/8bit.rb +31 -0
  37. data/lib/mail/encodings/base64.rb +33 -0
  38. data/lib/mail/encodings/binary.rb +31 -0
  39. data/lib/mail/encodings/quoted_printable.rb +39 -0
  40. data/lib/mail/encodings/transfer_encoding.rb +58 -0
  41. data/lib/mail/envelope.rb +30 -0
  42. data/lib/mail/field.rb +247 -0
  43. data/lib/mail/field_list.rb +33 -0
  44. data/lib/mail/fields.rb +35 -0
  45. data/lib/mail/fields/bcc_field.rb +56 -0
  46. data/lib/mail/fields/cc_field.rb +55 -0
  47. data/lib/mail/fields/comments_field.rb +41 -0
  48. data/lib/mail/fields/common/address_container.rb +16 -0
  49. data/lib/mail/fields/common/common_address.rb +135 -0
  50. data/lib/mail/fields/common/common_date.rb +35 -0
  51. data/lib/mail/fields/common/common_field.rb +57 -0
  52. data/lib/mail/fields/common/common_message_id.rb +48 -0
  53. data/lib/mail/fields/common/parameter_hash.rb +58 -0
  54. data/lib/mail/fields/content_description_field.rb +19 -0
  55. data/lib/mail/fields/content_disposition_field.rb +70 -0
  56. data/lib/mail/fields/content_id_field.rb +62 -0
  57. data/lib/mail/fields/content_location_field.rb +42 -0
  58. data/lib/mail/fields/content_transfer_encoding_field.rb +44 -0
  59. data/lib/mail/fields/content_type_field.rb +201 -0
  60. data/lib/mail/fields/date_field.rb +57 -0
  61. data/lib/mail/fields/from_field.rb +55 -0
  62. data/lib/mail/fields/in_reply_to_field.rb +56 -0
  63. data/lib/mail/fields/keywords_field.rb +44 -0
  64. data/lib/mail/fields/message_id_field.rb +82 -0
  65. data/lib/mail/fields/mime_version_field.rb +53 -0
  66. data/lib/mail/fields/optional_field.rb +13 -0
  67. data/lib/mail/fields/received_field.rb +75 -0
  68. data/lib/mail/fields/references_field.rb +56 -0
  69. data/lib/mail/fields/reply_to_field.rb +55 -0
  70. data/lib/mail/fields/resent_bcc_field.rb +55 -0
  71. data/lib/mail/fields/resent_cc_field.rb +55 -0
  72. data/lib/mail/fields/resent_date_field.rb +35 -0
  73. data/lib/mail/fields/resent_from_field.rb +55 -0
  74. data/lib/mail/fields/resent_message_id_field.rb +34 -0
  75. data/lib/mail/fields/resent_sender_field.rb +62 -0
  76. data/lib/mail/fields/resent_to_field.rb +55 -0
  77. data/lib/mail/fields/return_path_field.rb +65 -0
  78. data/lib/mail/fields/sender_field.rb +67 -0
  79. data/lib/mail/fields/structured_field.rb +51 -0
  80. data/lib/mail/fields/subject_field.rb +16 -0
  81. data/lib/mail/fields/to_field.rb +55 -0
  82. data/lib/mail/fields/unstructured_field.rb +204 -0
  83. data/lib/mail/header.rb +274 -0
  84. data/lib/mail/indifferent_hash.rb +146 -0
  85. data/lib/mail/mail.rb +267 -0
  86. data/lib/mail/matchers/has_sent_mail.rb +157 -0
  87. data/lib/mail/message.rb +2160 -0
  88. data/lib/mail/multibyte.rb +42 -0
  89. data/lib/mail/multibyte/chars.rb +474 -0
  90. data/lib/mail/multibyte/exceptions.rb +8 -0
  91. data/lib/mail/multibyte/unicode.rb +400 -0
  92. data/lib/mail/multibyte/utils.rb +60 -0
  93. data/lib/mail/network.rb +14 -0
  94. data/lib/mail/network/delivery_methods/exim.rb +52 -0
  95. data/lib/mail/network/delivery_methods/file_delivery.rb +45 -0
  96. data/lib/mail/network/delivery_methods/sendmail.rb +89 -0
  97. data/lib/mail/network/delivery_methods/smtp.rb +142 -0
  98. data/lib/mail/network/delivery_methods/smtp_connection.rb +61 -0
  99. data/lib/mail/network/delivery_methods/test_mailer.rb +44 -0
  100. data/lib/mail/network/retriever_methods/base.rb +63 -0
  101. data/lib/mail/network/retriever_methods/imap.rb +173 -0
  102. data/lib/mail/network/retriever_methods/pop3.rb +140 -0
  103. data/lib/mail/network/retriever_methods/test_retriever.rb +43 -0
  104. data/lib/mail/parsers.rb +26 -0
  105. data/lib/mail/parsers/address_lists_parser.rb +132 -0
  106. data/lib/mail/parsers/content_disposition_parser.rb +67 -0
  107. data/lib/mail/parsers/content_location_parser.rb +35 -0
  108. data/lib/mail/parsers/content_transfer_encoding_parser.rb +33 -0
  109. data/lib/mail/parsers/content_type_parser.rb +64 -0
  110. data/lib/mail/parsers/date_time_parser.rb +36 -0
  111. data/lib/mail/parsers/envelope_from_parser.rb +45 -0
  112. data/lib/mail/parsers/message_ids_parser.rb +39 -0
  113. data/lib/mail/parsers/mime_version_parser.rb +41 -0
  114. data/lib/mail/parsers/phrase_lists_parser.rb +33 -0
  115. data/lib/mail/parsers/ragel.rb +17 -0
  116. data/lib/mail/parsers/ragel/common.rl +184 -0
  117. data/lib/mail/parsers/ragel/date_time.rl +30 -0
  118. data/lib/mail/parsers/ragel/parser_info.rb +61 -0
  119. data/lib/mail/parsers/ragel/ruby.rb +39 -0
  120. data/lib/mail/parsers/ragel/ruby/machines/address_lists_machine.rb +14864 -0
  121. data/lib/mail/parsers/ragel/ruby/machines/address_lists_machine.rb.rl +37 -0
  122. data/lib/mail/parsers/ragel/ruby/machines/content_disposition_machine.rb +751 -0
  123. data/lib/mail/parsers/ragel/ruby/machines/content_disposition_machine.rb.rl +37 -0
  124. data/lib/mail/parsers/ragel/ruby/machines/content_location_machine.rb +614 -0
  125. data/lib/mail/parsers/ragel/ruby/machines/content_location_machine.rb.rl +37 -0
  126. data/lib/mail/parsers/ragel/ruby/machines/content_transfer_encoding_machine.rb +447 -0
  127. data/lib/mail/parsers/ragel/ruby/machines/content_transfer_encoding_machine.rb.rl +37 -0
  128. data/lib/mail/parsers/ragel/ruby/machines/content_type_machine.rb +825 -0
  129. data/lib/mail/parsers/ragel/ruby/machines/content_type_machine.rb.rl +37 -0
  130. data/lib/mail/parsers/ragel/ruby/machines/date_time_machine.rb +817 -0
  131. data/lib/mail/parsers/ragel/ruby/machines/date_time_machine.rb.rl +37 -0
  132. data/lib/mail/parsers/ragel/ruby/machines/envelope_from_machine.rb +2129 -0
  133. data/lib/mail/parsers/ragel/ruby/machines/envelope_from_machine.rb.rl +37 -0
  134. data/lib/mail/parsers/ragel/ruby/machines/message_ids_machine.rb +1570 -0
  135. data/lib/mail/parsers/ragel/ruby/machines/message_ids_machine.rb.rl +37 -0
  136. data/lib/mail/parsers/ragel/ruby/machines/mime_version_machine.rb +440 -0
  137. data/lib/mail/parsers/ragel/ruby/machines/mime_version_machine.rb.rl +37 -0
  138. data/lib/mail/parsers/ragel/ruby/machines/phrase_lists_machine.rb +564 -0
  139. data/lib/mail/parsers/ragel/ruby/machines/phrase_lists_machine.rb.rl +37 -0
  140. data/lib/mail/parsers/ragel/ruby/machines/rb_actions.rl +51 -0
  141. data/lib/mail/parsers/ragel/ruby/machines/received_machine.rb +5144 -0
  142. data/lib/mail/parsers/ragel/ruby/machines/received_machine.rb.rl +37 -0
  143. data/lib/mail/parsers/ragel/ruby/parser.rb.rl.erb +37 -0
  144. data/lib/mail/parsers/received_parser.rb +47 -0
  145. data/lib/mail/part.rb +120 -0
  146. data/lib/mail/parts_list.rb +57 -0
  147. data/lib/mail/patterns.rb +37 -0
  148. data/lib/mail/utilities.rb +225 -0
  149. data/lib/mail/values/unicode_tables.dat +0 -0
  150. data/lib/mail/version.rb +4 -0
  151. data/lib/mail/version_specific/ruby_1_8.rb +119 -0
  152. data/lib/mail/version_specific/ruby_1_9.rb +159 -0
  153. metadata +276 -0
@@ -0,0 +1,33 @@
1
+ # encoding: utf-8
2
+ module Mail
3
+
4
+ # Field List class provides an enhanced array that keeps a list of
5
+ # email fields in order. And allows you to insert new fields without
6
+ # having to worry about the order they will appear in.
7
+ class FieldList < Array
8
+
9
+ include Enumerable
10
+
11
+ # Insert the field in sorted order.
12
+ #
13
+ # Heavily based on bisect.insort from Python, which is:
14
+ # Copyright (C) 2001-2013 Python Software Foundation.
15
+ # Licensed under <http://docs.python.org/license.html>
16
+ # From <http://hg.python.org/cpython/file/2.7/Lib/bisect.py>
17
+ def <<( new_field )
18
+ lo = 0
19
+ hi = size
20
+
21
+ while lo < hi
22
+ mid = (lo + hi) / 2
23
+ if new_field < self[mid]
24
+ hi = mid
25
+ else
26
+ lo = mid + 1
27
+ end
28
+ end
29
+
30
+ insert(lo, new_field)
31
+ end
32
+ end
33
+ end
@@ -0,0 +1,35 @@
1
+ module Mail
2
+ register_autoload :UnstructuredField, 'mail/fields/unstructured_field'
3
+ register_autoload :StructuredField, 'mail/fields/structured_field'
4
+ register_autoload :OptionalField, 'mail/fields/optional_field'
5
+
6
+ register_autoload :BccField, 'mail/fields/bcc_field'
7
+ register_autoload :CcField, 'mail/fields/cc_field'
8
+ register_autoload :CommentsField, 'mail/fields/comments_field'
9
+ register_autoload :ContentDescriptionField, 'mail/fields/content_description_field'
10
+ register_autoload :ContentDispositionField, 'mail/fields/content_disposition_field'
11
+ register_autoload :ContentIdField, 'mail/fields/content_id_field'
12
+ register_autoload :ContentLocationField, 'mail/fields/content_location_field'
13
+ register_autoload :ContentTransferEncodingField, 'mail/fields/content_transfer_encoding_field'
14
+ register_autoload :ContentTypeField, 'mail/fields/content_type_field'
15
+ register_autoload :DateField, 'mail/fields/date_field'
16
+ register_autoload :FromField, 'mail/fields/from_field'
17
+ register_autoload :InReplyToField, 'mail/fields/in_reply_to_field'
18
+ register_autoload :KeywordsField, 'mail/fields/keywords_field'
19
+ register_autoload :MessageIdField, 'mail/fields/message_id_field'
20
+ register_autoload :MimeVersionField, 'mail/fields/mime_version_field'
21
+ register_autoload :ReceivedField, 'mail/fields/received_field'
22
+ register_autoload :ReferencesField, 'mail/fields/references_field'
23
+ register_autoload :ReplyToField, 'mail/fields/reply_to_field'
24
+ register_autoload :ResentBccField, 'mail/fields/resent_bcc_field'
25
+ register_autoload :ResentCcField, 'mail/fields/resent_cc_field'
26
+ register_autoload :ResentDateField, 'mail/fields/resent_date_field'
27
+ register_autoload :ResentFromField, 'mail/fields/resent_from_field'
28
+ register_autoload :ResentMessageIdField, 'mail/fields/resent_message_id_field'
29
+ register_autoload :ResentSenderField, 'mail/fields/resent_sender_field'
30
+ register_autoload :ResentToField, 'mail/fields/resent_to_field'
31
+ register_autoload :ReturnPathField, 'mail/fields/return_path_field'
32
+ register_autoload :SenderField, 'mail/fields/sender_field'
33
+ register_autoload :SubjectField, 'mail/fields/subject_field'
34
+ register_autoload :ToField, 'mail/fields/to_field'
35
+ end
@@ -0,0 +1,56 @@
1
+ # encoding: utf-8
2
+ #
3
+ # = Blind Carbon Copy Field
4
+ #
5
+ # The Bcc field inherits from StructuredField and handles the Bcc: header
6
+ # field in the email.
7
+ #
8
+ # Sending bcc to a mail message will instantiate a Mail::Field object that
9
+ # has a BccField as its field type. This includes all Mail::CommonAddress
10
+ # module instance metods.
11
+ #
12
+ # Only one Bcc field can appear in a header, though it can have multiple
13
+ # addresses and groups of addresses.
14
+ #
15
+ # == Examples:
16
+ #
17
+ # mail = Mail.new
18
+ # mail.bcc = 'Mikel Lindsaar <mikel@test.lindsaar.net>, ada@test.lindsaar.net'
19
+ # mail.bcc #=> ['mikel@test.lindsaar.net', 'ada@test.lindsaar.net']
20
+ # mail[:bcc] #=> '#<Mail::Field:0x180e5e8 @field=#<Mail::BccField:0x180e1c4
21
+ # mail['bcc'] #=> '#<Mail::Field:0x180e5e8 @field=#<Mail::BccField:0x180e1c4
22
+ # mail['Bcc'] #=> '#<Mail::Field:0x180e5e8 @field=#<Mail::BccField:0x180e1c4
23
+ #
24
+ # mail[:bcc].encoded #=> '' # Bcc field does not get output into an email
25
+ # mail[:bcc].decoded #=> 'Mikel Lindsaar <mikel@test.lindsaar.net>, ada@test.lindsaar.net'
26
+ # mail[:bcc].addresses #=> ['mikel@test.lindsaar.net', 'ada@test.lindsaar.net']
27
+ # mail[:bcc].formatted #=> ['Mikel Lindsaar <mikel@test.lindsaar.net>', 'ada@test.lindsaar.net']
28
+ #
29
+ require 'mail/fields/common/common_address'
30
+
31
+ module Mail
32
+ class BccField < StructuredField
33
+
34
+ include Mail::CommonAddress
35
+
36
+ FIELD_NAME = 'bcc'
37
+ CAPITALIZED_FIELD = 'Bcc'
38
+
39
+ def initialize(value = '', charset = 'utf-8')
40
+ @charset = charset
41
+ super(CAPITALIZED_FIELD, strip_field(FIELD_NAME, value), charset)
42
+ self.parse
43
+ self
44
+ end
45
+
46
+ # Bcc field should never be :encoded
47
+ def encoded
48
+ ''
49
+ end
50
+
51
+ def decoded
52
+ do_decode
53
+ end
54
+
55
+ end
56
+ end
@@ -0,0 +1,55 @@
1
+ # encoding: utf-8
2
+ #
3
+ # = Carbon Copy Field
4
+ #
5
+ # The Cc field inherits from StructuredField and handles the Cc: header
6
+ # field in the email.
7
+ #
8
+ # Sending cc to a mail message will instantiate a Mail::Field object that
9
+ # has a CcField as its field type. This includes all Mail::CommonAddress
10
+ # module instance metods.
11
+ #
12
+ # Only one Cc field can appear in a header, though it can have multiple
13
+ # addresses and groups of addresses.
14
+ #
15
+ # == Examples:
16
+ #
17
+ # mail = Mail.new
18
+ # mail.cc = 'Mikel Lindsaar <mikel@test.lindsaar.net>, ada@test.lindsaar.net'
19
+ # mail.cc #=> ['mikel@test.lindsaar.net', 'ada@test.lindsaar.net']
20
+ # mail[:cc] #=> '#<Mail::Field:0x180e5e8 @field=#<Mail::CcField:0x180e1c4
21
+ # mail['cc'] #=> '#<Mail::Field:0x180e5e8 @field=#<Mail::CcField:0x180e1c4
22
+ # mail['Cc'] #=> '#<Mail::Field:0x180e5e8 @field=#<Mail::CcField:0x180e1c4
23
+ #
24
+ # mail[:cc].encoded #=> 'Cc: Mikel Lindsaar <mikel@test.lindsaar.net>, ada@test.lindsaar.net\r\n'
25
+ # mail[:cc].decoded #=> 'Mikel Lindsaar <mikel@test.lindsaar.net>, ada@test.lindsaar.net'
26
+ # mail[:cc].addresses #=> ['mikel@test.lindsaar.net', 'ada@test.lindsaar.net']
27
+ # mail[:cc].formatted #=> ['Mikel Lindsaar <mikel@test.lindsaar.net>', 'ada@test.lindsaar.net']
28
+ #
29
+ require 'mail/fields/common/common_address'
30
+
31
+ module Mail
32
+ class CcField < StructuredField
33
+
34
+ include Mail::CommonAddress
35
+
36
+ FIELD_NAME = 'cc'
37
+ CAPITALIZED_FIELD = 'Cc'
38
+
39
+ def initialize(value = nil, charset = 'utf-8')
40
+ self.charset = charset
41
+ super(CAPITALIZED_FIELD, strip_field(FIELD_NAME, value), charset)
42
+ self.parse
43
+ self
44
+ end
45
+
46
+ def encoded
47
+ do_encode(CAPITALIZED_FIELD)
48
+ end
49
+
50
+ def decoded
51
+ do_decode
52
+ end
53
+
54
+ end
55
+ end
@@ -0,0 +1,41 @@
1
+ # encoding: utf-8
2
+ #
3
+ # = Comments Field
4
+ #
5
+ # The Comments field inherits from UnstructuredField and handles the Comments:
6
+ # header field in the email.
7
+ #
8
+ # Sending comments to a mail message will instantiate a Mail::Field object that
9
+ # has a CommentsField as its field type.
10
+ #
11
+ # An email header can have as many comments fields as it wants. There is no upper
12
+ # limit, the comments field is also optional (that is, no comment is needed)
13
+ #
14
+ # == Examples:
15
+ #
16
+ # mail = Mail.new
17
+ # mail.comments = 'This is a comment'
18
+ # mail.comments #=> 'This is a comment'
19
+ # mail[:comments] #=> '#<Mail::Field:0x180e5e8 @field=#<Mail::CommentsField:0x180e1c4
20
+ # mail['comments'] #=> '#<Mail::Field:0x180e5e8 @field=#<Mail::CommentsField:0x180e1c4
21
+ # mail['comments'] #=> '#<Mail::Field:0x180e5e8 @field=#<Mail::CommentsField:0x180e1c4
22
+ #
23
+ # mail.comments = "This is another comment"
24
+ # mail[:comments].map { |c| c.to_s }
25
+ # #=> ['This is a comment', "This is another comment"]
26
+ #
27
+ module Mail
28
+ class CommentsField < UnstructuredField
29
+
30
+ FIELD_NAME = 'comments'
31
+ CAPITALIZED_FIELD = 'Comments'
32
+
33
+ def initialize(value = nil, charset = 'utf-8')
34
+ @charset = charset
35
+ super(CAPITALIZED_FIELD, strip_field(FIELD_NAME, value))
36
+ self.parse
37
+ self
38
+ end
39
+
40
+ end
41
+ end
@@ -0,0 +1,16 @@
1
+ module Mail
2
+
3
+ class AddressContainer < Array
4
+
5
+ def initialize(field, list = [])
6
+ @field = field
7
+ super(list)
8
+ end
9
+
10
+ def << (address)
11
+ @field << address
12
+ end
13
+
14
+ end
15
+
16
+ end
@@ -0,0 +1,135 @@
1
+ # encoding: utf-8
2
+ require 'mail/fields/common/address_container'
3
+
4
+ module Mail
5
+ module CommonAddress # :nodoc:
6
+
7
+ def parse(val = value)
8
+ unless val.blank?
9
+ @address_list = AddressList.new(encode_if_needed(val))
10
+ else
11
+ nil
12
+ end
13
+ end
14
+
15
+ def charset
16
+ @charset
17
+ end
18
+
19
+ def encode_if_needed(val)
20
+ Encodings.address_encode(val, charset)
21
+ end
22
+
23
+ # Allows you to iterate through each address object in the address_list
24
+ def each
25
+ address_list.addresses.each do |address|
26
+ yield(address)
27
+ end
28
+ end
29
+
30
+ # Returns the address string of all the addresses in the address list
31
+ def addresses
32
+ list = address_list.addresses.map { |a| a.address }
33
+ Mail::AddressContainer.new(self, list)
34
+ end
35
+
36
+ # Returns the formatted string of all the addresses in the address list
37
+ def formatted
38
+ list = address_list.addresses.map { |a| a.format }
39
+ Mail::AddressContainer.new(self, list)
40
+ end
41
+
42
+ # Returns the display name of all the addresses in the address list
43
+ def display_names
44
+ list = address_list.addresses.map { |a| a.display_name }
45
+ Mail::AddressContainer.new(self, list)
46
+ end
47
+
48
+ # Returns the actual address objects in the address list
49
+ def addrs
50
+ list = address_list.addresses
51
+ Mail::AddressContainer.new(self, list)
52
+ end
53
+
54
+ # Returns a hash of group name => address strings for the address list
55
+ def groups
56
+ address_list.addresses_grouped_by_group
57
+ end
58
+
59
+ # Returns the addresses that are part of groups
60
+ def group_addresses
61
+ decoded_group_addresses
62
+ end
63
+
64
+ # Returns a list of decoded group addresses
65
+ def decoded_group_addresses
66
+ groups.map { |k,v| v.map { |a| a.decoded } }.flatten
67
+ end
68
+
69
+ # Returns a list of encoded group addresses
70
+ def encoded_group_addresses
71
+ groups.map { |k,v| v.map { |a| a.encoded } }.flatten
72
+ end
73
+
74
+ # Returns the name of all the groups in a string
75
+ def group_names # :nodoc:
76
+ address_list.group_names
77
+ end
78
+
79
+ def default
80
+ addresses
81
+ end
82
+
83
+ def <<(val)
84
+ case
85
+ when val.nil?
86
+ raise ArgumentError, "Need to pass an address to <<"
87
+ when val.blank?
88
+ parse(encoded)
89
+ else
90
+ self.value = [self.value, val].reject {|a| a.blank? }.join(", ")
91
+ end
92
+ end
93
+
94
+ def value=(val)
95
+ super
96
+ parse(self.value)
97
+ end
98
+
99
+ private
100
+
101
+ def do_encode(field_name)
102
+ return '' if value.blank?
103
+ address_array = address_list.addresses.reject { |a| encoded_group_addresses.include?(a.encoded) }.compact.map { |a| a.encoded }
104
+ address_text = address_array.join(", \r\n\s")
105
+ group_array = groups.map { |k,v| "#{k}: #{v.map { |a| a.encoded }.join(", \r\n\s")};" }
106
+ group_text = group_array.join(" \r\n\s")
107
+ return_array = [address_text, group_text].reject { |a| a.blank? }
108
+ "#{field_name}: #{return_array.join(", \r\n\s")}\r\n"
109
+ end
110
+
111
+ def do_decode
112
+ return nil if value.blank?
113
+ address_array = address_list.addresses.reject { |a| decoded_group_addresses.include?(a.decoded) }.map { |a| a.decoded }
114
+ address_text = address_array.join(", ")
115
+ group_array = groups.map { |k,v| "#{k}: #{v.map { |a| a.decoded }.join(", ")};" }
116
+ group_text = group_array.join(" ")
117
+ return_array = [address_text, group_text].reject { |a| a.blank? }
118
+ return_array.join(", ")
119
+ end
120
+
121
+ def address_list # :nodoc:
122
+ @address_list ||= AddressList.new(value)
123
+ end
124
+
125
+ def get_group_addresses(group_list)
126
+ if group_list.respond_to?(:addresses)
127
+ group_list.addresses.map do |address|
128
+ Mail::Address.new(address)
129
+ end
130
+ else
131
+ []
132
+ end
133
+ end
134
+ end
135
+ end
@@ -0,0 +1,35 @@
1
+ # encoding: utf-8
2
+ module Mail
3
+ module CommonDate # :nodoc:
4
+ # Returns a date time object of the parsed date
5
+ def date_time
6
+ ::DateTime.parse("#{element.date_string} #{element.time_string}")
7
+ end
8
+
9
+ def default
10
+ date_time
11
+ end
12
+
13
+ def parse(val = value)
14
+ unless val.blank?
15
+ @element = Mail::DateTimeElement.new(val)
16
+ else
17
+ nil
18
+ end
19
+ end
20
+
21
+ private
22
+
23
+ def do_encode(field_name)
24
+ "#{field_name}: #{value}\r\n"
25
+ end
26
+
27
+ def do_decode
28
+ "#{value}"
29
+ end
30
+
31
+ def element
32
+ @element ||= Mail::DateTimeElement.new(value)
33
+ end
34
+ end
35
+ end
@@ -0,0 +1,57 @@
1
+ # encoding: utf-8
2
+ module Mail
3
+ module CommonField # :nodoc:
4
+
5
+ def name=(value)
6
+ @name = value
7
+ end
8
+
9
+ def name
10
+ @name ||= nil
11
+ end
12
+
13
+ def value=(value)
14
+ @length = nil
15
+ @tree = nil
16
+ @element = nil
17
+ @value = value
18
+ end
19
+
20
+ def value
21
+ @value
22
+ end
23
+
24
+ def to_s
25
+ decoded.to_s
26
+ end
27
+
28
+ def default
29
+ decoded
30
+ end
31
+
32
+ def field_length
33
+ @length ||= "#{name}: #{encode(decoded)}".length
34
+ end
35
+
36
+ def responsible_for?( val )
37
+ name.to_s.casecmp(val.to_s) == 0
38
+ end
39
+
40
+ private
41
+
42
+ def strip_field(field_name, value)
43
+ if value.is_a?(Array)
44
+ value
45
+ else
46
+ value.to_s.sub(/#{field_name}:\s+/i, '')
47
+ end
48
+ end
49
+
50
+ FILENAME_RE = /\b(filename|name)=([^;"\r\n]+\s[^;"\r\n]+)/
51
+ def ensure_filename_quoted(value)
52
+ if value.is_a?(String)
53
+ value.sub! FILENAME_RE, '\1="\2"'
54
+ end
55
+ end
56
+ end
57
+ end