Skip to content

RExchange is an easy to use Microsoft Exchange Server WebDAV communication wrapper . This is a fork of the rubyforge project

License

Notifications You must be signed in to change notification settings

kuemmelHH/rexchange

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

28 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

= RExchange

RExchange is a pure ruby wrapper for the Microsoft Exchange Server WebDAV API

== Things you should know

  • Requires Ruby 1.8.4 (or later, for the extended WebDAV support in the net/http library)
  • RExchange is cross-platform compatible, being written in pure Ruby
  • Kiwi fruits are packed with vitamins

== Why should you use RExchange

  • It makes interacting with Exchange simple
  • It was written for a real application, and does real work reliably day in and day out

== Example

# We pass our uri (pointing directly to a mailbox), a username, and a password to RExchange::open
# to create a RExchange::Session. Notice that we escape the "\" in our username.
RExchange::open('https://example.com/exchange/admin/', 'mydomain\\admin', 'secret') do |mailbox|

	# The block parameter ("mailbox" in this case) is actually the Session itself.
	# You can refer to folders by chaining them as method calls. "inbox" in this case
	# isn't a defined method for Session, but part of the DSL to refer to folder names.
	# Each folder name returns a RExchange::Folder. The folder is Enumerable, allowing
	# iteration over the items in the folder, depending on the DAV:content-class of
	# the folder.
	mailbox.inbox.each do |message|

		# The "message" block parameter is a RExchange::Message object. You have access to
		# several attributes of the message, including: href, from, to, message_id, date,
		# importance, has_attachment? and body.
		p message.subject

		# The RExchange::Message#move_to method moves the message to another folder, in this
		# case, an "archive" folder off of the inbox.
		message.move_to mailbox.inbox.archive
	end

	# Folder names are "normalized", replacing dashes and spaces with underscores,
	# squeezing out multiple underscores in a row, and downcasing the whole thing.
	# So a folder name such as "My Very-long Folder Name" would look like:
	mailbox.my_very_long_folder_name

	# The Enumerable mixin gives us an Folder#entries method in case we just want to
	# return an array.
	messages = mailbox.inbox.entries

	# Other methods, like Enumerable#map and Enumerable#sort_by let us manipulate
	# the Folder in fun ways:
	puts mailbox.contacts.sort_by { |contact| contact.first_name }.map do |contact|
		<<-CONTACT
			Name:    #{contact.first_name} #{contact.last_name}
			Email:   #{contact.email}
			Phone:   #{contact.phone}
		CONTACT
	end

end

# We can access the Global Address Book by accessing the "/public" folder:
RExchange::open('https://example.com/public', 'mydomain\\somebody', 'secret') do |mailbox|

	puts mailbox.company_contacts.each do |contact|
		<<-CONTACT
			Company: #{contact.company}
			Name:    #{contact.first_name} #{contact.last_name}
			Email:   #{contact.email}
			Phone:   #{contact.phone}
		CONTACT
 end

end

== Caveats

There are several features missing (simply because we didn't need them yet). Among them:

  • The ability to delete messages or folders
  • The ability to create folders
  • There's no mechanism for sending new messages, or replying or forwarding existing ones
  • There are a lot more message attributes we're not retrieving since they weren't useful to us, but they might be to you
  • Exporting an email or entire folder tree to offline storage
  • And much much more!

If you'd like to see any of these features, or have some ideas of your own you'd like to see implemented don't hesitate to let us know, and if it strikes our fancy maybe you'll get some free programming!

About

RExchange is an easy to use Microsoft Exchange Server WebDAV communication wrapper . This is a fork of the rubyforge project

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Ruby 100.0%