module TMail
Quoting methods¶ ↑
TMail - The EMail Swiss Army Knife for Ruby¶ ↑
The TMail library provides you with a very complete way to handle and manipulate EMails from within your Ruby programs.
Used as the backbone for email handling by the Ruby on Rails and Nitro web frameworks as well as a bunch of other Ruby apps including the Ruby-Talk mailing list to newsgroup email gateway, it is a proven and reliable email handler that won't let you down.
Originally created by Minero Aoki, TMail has been recently picked up by Mikel Lindsaar and is being actively maintained. Numerous backlogged bug fixes have been applied as well as Ruby 1.9 compatibility and a swath of documentation to boot.
TMail allows you to treat an email totally as an object and allow you to get on with your own programming without having to worry about crafting the perfect email address validation parser, or assembling an email from all it's component parts.
TMail handles the most complex part of the email - the header. It generates and parses headers and provides you with instant access to their innards through simple and logically named accessor and setter methods.
TMail also provides a wrapper to Net/SMTP as well as Unix Mailbox handling methods to directly read emails from your unix mailbox, parse them and use them.
Following is the comprehensive list of methods to access TMail::Mail objects. You can also check out TMail::Mail, TMail::Address and TMail::Headers for other lists.
Constants
- MaildirLoader
- MboxLoader
- MhLoader
Public Class Methods
Provides a new email boundary to separate parts of the email. This is a random string based off the current time, so should be fairly unique.
For Example:
TMail.new_boundary #=> "mimepart_47bf656968207_25a8fbb80114" TMail.new_boundary #=> "mimepart_47bf66051de4_25a8fbb80240"
# File lib/tmail/utils.rb, line 67 def TMail.new_boundary 'mimepart_' + random_tag end
Provides a new email message ID. You can use this to generate unique email message id's for your email so you can track them.
Optionally takes a fully qualified domain name (default to the current hostname returned by Socket.gethostname) that will be appended to the message ID.
For Example:
email.message_id = TMail.new_message_id #=> "<47bf66845380e_25a8fbb80332@baci.local.tmail>" email.to_s #=> "Message-Id: <47bf668b633f1_25a8fbb80475@baci.local.tmail>\n\n" email.message_id = TMail.new_message_id("lindsaar.net") #=> "<47bf668b633f1_25a8fbb80475@lindsaar.net.tmail>" email.to_s #=> "Message-Id: <47bf668b633f1_25a8fbb80475@lindsaar.net.tmail>\n\n"
# File lib/tmail/utils.rb, line 87 def TMail.new_message_id( fqdn = nil ) fqdn ||= ::Socket.gethostname "<#{random_tag()}@#{fqdn}.tmail>" end