public
Description: Authenticate your Rails app using any IMAP server!
Homepage: http://daniel.collectiveidea.com/blog/tags/imap_authenticatable
Clone URL: git://github.com/collectiveidea/imap_authenticatable.git
Click here to lend your support to: imap_authenticatable and make a donation at www.pledgie.com !
100644 45 lines (31 sloc) 1.409 kb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
IMAPAuthenticatable
===================
 
A quick library for authenticating against an IMAP server.
 
See http://daniel.collectiveidea.com/blog/tags/imap_authenticatable for more info.
 
It expects a model with a 'username' column. You must pass a host.
 
Example:
 
class User < ActiveRecord::Base
  imap_authenticatable :host => 'mail.example.com'
  
  ...
end
 
 
other options:
:allow_new_users => true/false
Alters whether to use find_by_username or find_or_create_by_username.
The default is true (find or create).
:default_domain => 'example.com'
What usernames have at the end.
Defaults to the :host option.
:append_domain => false/true
Should we always add or remove the default_domain (with preceding '@) value?
The default is false (always remove).
:ssl => false/true
Sets whether to connect via SSL (TLS). You must have OpenSSL installed.
Defaults to false.
:port => 143
Sets the port. The :ssl option will set the port automatically unless you override it.
Defaults to 143 if :ssl => false, 993 if :ssl => true
 
 
Other options may be added as need arises.
 
 
Testing:
 
To mock the IMAP login in your tests, add the following line to the top of your test_helper.rb
  require File.join(File.dirname(__FILE__), '..', 'vendor', 'plugins', 'imap_authenticatable', 'test', 'mocks', 'imap.rb')
 
This mock makes the valid password the reverse of the username (username.reverse).