To check out this repository please hg clone the following URL, or open the URL using EasyMercurial or your preferred Mercurial client.

Statistics Download as Zip
| Branch: | Tag: | Revision:

root / lib / tasks / email.rake @ 442:753f1380d6bc

History | View | Annotate | Download (7.95 KB)

1 0:513646585e45 Chris
# Redmine - project management software
2 441:cbce1fd3b1b7 Chris
# Copyright (C) 2006-2011  Jean-Philippe Lang
3 0:513646585e45 Chris
#
4
# This program is free software; you can redistribute it and/or
5
# modify it under the terms of the GNU General Public License
6
# as published by the Free Software Foundation; either version 2
7
# of the License, or (at your option) any later version.
8 441:cbce1fd3b1b7 Chris
#
9 0:513646585e45 Chris
# This program is distributed in the hope that it will be useful,
10
# but WITHOUT ANY WARRANTY; without even the implied warranty of
11
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12
# GNU General Public License for more details.
13 441:cbce1fd3b1b7 Chris
#
14 0:513646585e45 Chris
# You should have received a copy of the GNU General Public License
15
# along with this program; if not, write to the Free Software
16
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
17
18
namespace :redmine do
19
  namespace :email do
20
21
    desc <<-END_DESC
22
Read an email from standard input.
23

24
General options:
25
  unknown_user=ACTION      how to handle emails from an unknown user
26
                           ACTION can be one of the following values:
27
                           ignore: email is ignored (default)
28
                           accept: accept as anonymous user
29
                           create: create a user account
30
  no_permission_check=1    disable permission checking when receiving
31
                           the email
32 441:cbce1fd3b1b7 Chris

33 0:513646585e45 Chris
Issue attributes control options:
34
  project=PROJECT          identifier of the target project
35
  status=STATUS            name of the target status
36
  tracker=TRACKER          name of the target tracker
37
  category=CATEGORY        name of the target category
38
  priority=PRIORITY        name of the target priority
39
  allow_override=ATTRS     allow email content to override attributes
40
                           specified by previous options
41
                           ATTRS is a comma separated list of attributes
42

43
Examples:
44
  # No project specified. Emails MUST contain the 'Project' keyword:
45
  rake redmine:email:read RAILS_ENV="production" < raw_email
46

47
  # Fixed project and default tracker specified, but emails can override
48
  # both tracker and priority attributes:
49
  rake redmine:email:read RAILS_ENV="production" \\
50
                  project=foo \\
51
                  tracker=bug \\
52
                  allow_override=tracker,priority < raw_email
53
END_DESC
54
55
    task :read => :environment do
56
      options = { :issue => {} }
57
      %w(project status tracker category priority).each { |a| options[:issue][a.to_sym] = ENV[a] if ENV[a] }
58
      options[:allow_override] = ENV['allow_override'] if ENV['allow_override']
59
      options[:unknown_user] = ENV['unknown_user'] if ENV['unknown_user']
60
      options[:no_permission_check] = ENV['no_permission_check'] if ENV['no_permission_check']
61 441:cbce1fd3b1b7 Chris
62 0:513646585e45 Chris
      MailHandler.receive(STDIN.read, options)
63
    end
64 441:cbce1fd3b1b7 Chris
65 0:513646585e45 Chris
    desc <<-END_DESC
66
Read emails from an IMAP server.
67

68
General options:
69
  unknown_user=ACTION      how to handle emails from an unknown user
70
                           ACTION can be one of the following values:
71
                           ignore: email is ignored (default)
72
                           accept: accept as anonymous user
73
                           create: create a user account
74
  no_permission_check=1    disable permission checking when receiving
75
                           the email
76 441:cbce1fd3b1b7 Chris

77 0:513646585e45 Chris
Available IMAP options:
78
  host=HOST                IMAP server host (default: 127.0.0.1)
79
  port=PORT                IMAP server port (default: 143)
80
  ssl=SSL                  Use SSL? (default: false)
81
  username=USERNAME        IMAP account
82
  password=PASSWORD        IMAP password
83
  folder=FOLDER            IMAP folder to read (default: INBOX)
84 441:cbce1fd3b1b7 Chris

85 0:513646585e45 Chris
Issue attributes control options:
86
  project=PROJECT          identifier of the target project
87
  status=STATUS            name of the target status
88
  tracker=TRACKER          name of the target tracker
89
  category=CATEGORY        name of the target category
90
  priority=PRIORITY        name of the target priority
91
  allow_override=ATTRS     allow email content to override attributes
92
                           specified by previous options
93
                           ATTRS is a comma separated list of attributes
94 441:cbce1fd3b1b7 Chris

95 0:513646585e45 Chris
Processed emails control options:
96
  move_on_success=MAILBOX  move emails that were successfully received
97
                           to MAILBOX instead of deleting them
98
  move_on_failure=MAILBOX  move emails that were ignored to MAILBOX
99 441:cbce1fd3b1b7 Chris

100 0:513646585e45 Chris
Examples:
101
  # No project specified. Emails MUST contain the 'Project' keyword:
102 441:cbce1fd3b1b7 Chris

103 0:513646585e45 Chris
  rake redmine:email:receive_iamp RAILS_ENV="production" \\
104
    host=imap.foo.bar username=redmine@example.net password=xxx
105

106

107
  # Fixed project and default tracker specified, but emails can override
108
  # both tracker and priority attributes:
109 441:cbce1fd3b1b7 Chris

110 0:513646585e45 Chris
  rake redmine:email:receive_iamp RAILS_ENV="production" \\
111
    host=imap.foo.bar username=redmine@example.net password=xxx ssl=1 \\
112
    project=foo \\
113
    tracker=bug \\
114
    allow_override=tracker,priority
115
END_DESC
116
117
    task :receive_imap => :environment do
118
      imap_options = {:host => ENV['host'],
119
                      :port => ENV['port'],
120
                      :ssl => ENV['ssl'],
121
                      :username => ENV['username'],
122
                      :password => ENV['password'],
123
                      :folder => ENV['folder'],
124
                      :move_on_success => ENV['move_on_success'],
125
                      :move_on_failure => ENV['move_on_failure']}
126 441:cbce1fd3b1b7 Chris
127 0:513646585e45 Chris
      options = { :issue => {} }
128
      %w(project status tracker category priority).each { |a| options[:issue][a.to_sym] = ENV[a] if ENV[a] }
129
      options[:allow_override] = ENV['allow_override'] if ENV['allow_override']
130
      options[:unknown_user] = ENV['unknown_user'] if ENV['unknown_user']
131
      options[:no_permission_check] = ENV['no_permission_check'] if ENV['no_permission_check']
132
133
      Redmine::IMAP.check(imap_options, options)
134
    end
135 441:cbce1fd3b1b7 Chris
136 0:513646585e45 Chris
    desc <<-END_DESC
137
Read emails from an POP3 server.
138

139
Available POP3 options:
140
  host=HOST                POP3 server host (default: 127.0.0.1)
141
  port=PORT                POP3 server port (default: 110)
142
  username=USERNAME        POP3 account
143
  password=PASSWORD        POP3 password
144
  apop=1                   use APOP authentication (default: false)
145
  delete_unprocessed=1     delete messages that could not be processed
146
                           successfully from the server (default
147
                           behaviour is to leave them on the server)
148

149
See redmine:email:receive_imap for more options and examples.
150
END_DESC
151 441:cbce1fd3b1b7 Chris
152 0:513646585e45 Chris
    task :receive_pop3 => :environment do
153
      pop_options  = {:host => ENV['host'],
154
                      :port => ENV['port'],
155
                      :apop => ENV['apop'],
156
                      :username => ENV['username'],
157
                      :password => ENV['password'],
158
                      :delete_unprocessed => ENV['delete_unprocessed']}
159 441:cbce1fd3b1b7 Chris
160 0:513646585e45 Chris
      options = { :issue => {} }
161
      %w(project status tracker category priority).each { |a| options[:issue][a.to_sym] = ENV[a] if ENV[a] }
162
      options[:allow_override] = ENV['allow_override'] if ENV['allow_override']
163
      options[:unknown_user] = ENV['unknown_user'] if ENV['unknown_user']
164
      options[:no_permission_check] = ENV['no_permission_check'] if ENV['no_permission_check']
165 441:cbce1fd3b1b7 Chris
166 0:513646585e45 Chris
      Redmine::POP3.check(pop_options, options)
167
    end
168 441:cbce1fd3b1b7 Chris
169 37:94944d00e43c chris
    desc "Send a test email to the user with the provided login name"
170
    task :test, :login, :needs => :environment do |task, args|
171
      include Redmine::I18n
172 441:cbce1fd3b1b7 Chris
      abort l(:notice_email_error, "Please include the user login to test with. Example: rake redmine:email:test[login]") if args[:login].blank?
173 37:94944d00e43c chris
174
      user = User.find_by_login(args[:login])
175 441:cbce1fd3b1b7 Chris
      abort l(:notice_email_error, "User #{args[:login]} not found") unless user && user.logged?
176
177 37:94944d00e43c chris
      ActionMailer::Base.raise_delivery_errors = true
178
      begin
179
        Mailer.deliver_test(User.current)
180
        puts l(:notice_email_sent, user.mail)
181
      rescue Exception => e
182
        abort l(:notice_email_error, e.message)
183
      end
184
    end
185 0:513646585e45 Chris
  end
186
end