annotate lib/tasks/email.rake @ 1621:3a510bf6a9bc

Merge from live branch
author Chris Cannam
date Fri, 13 Jul 2018 10:44:33 +0100
parents e248c7af89ec
children
rev   line source
Chris@1115 1 # Redmine - project management software
Chris@1494 2 # Copyright (C) 2006-2014 Jean-Philippe Lang
Chris@1115 3 #
Chris@1115 4 # This program is free software; you can redistribute it and/or
Chris@1115 5 # modify it under the terms of the GNU General Public License
Chris@1115 6 # as published by the Free Software Foundation; either version 2
Chris@1115 7 # of the License, or (at your option) any later version.
Chris@1115 8 #
Chris@1115 9 # This program is distributed in the hope that it will be useful,
Chris@1115 10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
Chris@1115 11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
Chris@1115 12 # GNU General Public License for more details.
Chris@1115 13 #
Chris@1115 14 # You should have received a copy of the GNU General Public License
Chris@1115 15 # along with this program; if not, write to the Free Software
Chris@1115 16 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
Chris@1115 17
Chris@1115 18 namespace :redmine do
Chris@1115 19 namespace :email do
Chris@1115 20
Chris@1115 21 desc <<-END_DESC
Chris@1115 22 Read an email from standard input.
Chris@1115 23
Chris@1115 24 General options:
Chris@1115 25 unknown_user=ACTION how to handle emails from an unknown user
Chris@1115 26 ACTION can be one of the following values:
Chris@1115 27 ignore: email is ignored (default)
Chris@1115 28 accept: accept as anonymous user
Chris@1115 29 create: create a user account
Chris@1115 30 no_permission_check=1 disable permission checking when receiving
Chris@1115 31 the email
Chris@1464 32 no_account_notice=1 disable new user account notification
Chris@1464 33 default_group=foo,bar adds created user to foo and bar groups
Chris@1115 34
Chris@1115 35 Issue attributes control options:
Chris@1115 36 project=PROJECT identifier of the target project
Chris@1115 37 status=STATUS name of the target status
Chris@1115 38 tracker=TRACKER name of the target tracker
Chris@1115 39 category=CATEGORY name of the target category
Chris@1115 40 priority=PRIORITY name of the target priority
Chris@1115 41 allow_override=ATTRS allow email content to override attributes
Chris@1115 42 specified by previous options
Chris@1115 43 ATTRS is a comma separated list of attributes
Chris@1115 44
Chris@1115 45 Examples:
Chris@1115 46 # No project specified. Emails MUST contain the 'Project' keyword:
Chris@1115 47 rake redmine:email:read RAILS_ENV="production" < raw_email
Chris@1115 48
Chris@1115 49 # Fixed project and default tracker specified, but emails can override
Chris@1115 50 # both tracker and priority attributes:
Chris@1115 51 rake redmine:email:read RAILS_ENV="production" \\
Chris@1115 52 project=foo \\
Chris@1115 53 tracker=bug \\
Chris@1115 54 allow_override=tracker,priority < raw_email
Chris@1115 55 END_DESC
Chris@1115 56
Chris@1115 57 task :read => :environment do
Chris@1464 58 MailHandler.receive(STDIN.read, MailHandler.extract_options_from_env(ENV))
Chris@1115 59 end
Chris@1115 60
Chris@1115 61 desc <<-END_DESC
Chris@1115 62 Read emails from an IMAP server.
Chris@1115 63
Chris@1115 64 General options:
Chris@1115 65 unknown_user=ACTION how to handle emails from an unknown user
Chris@1115 66 ACTION can be one of the following values:
Chris@1115 67 ignore: email is ignored (default)
Chris@1115 68 accept: accept as anonymous user
Chris@1115 69 create: create a user account
Chris@1115 70 no_permission_check=1 disable permission checking when receiving
Chris@1115 71 the email
Chris@1464 72 no_account_notice=1 disable new user account notification
Chris@1464 73 default_group=foo,bar adds created user to foo and bar groups
Chris@1115 74
Chris@1115 75 Available IMAP options:
Chris@1115 76 host=HOST IMAP server host (default: 127.0.0.1)
Chris@1115 77 port=PORT IMAP server port (default: 143)
Chris@1115 78 ssl=SSL Use SSL? (default: false)
Chris@1115 79 username=USERNAME IMAP account
Chris@1115 80 password=PASSWORD IMAP password
Chris@1115 81 folder=FOLDER IMAP folder to read (default: INBOX)
Chris@1115 82
Chris@1115 83 Issue attributes control options:
Chris@1115 84 project=PROJECT identifier of the target project
Chris@1115 85 status=STATUS name of the target status
Chris@1115 86 tracker=TRACKER name of the target tracker
Chris@1115 87 category=CATEGORY name of the target category
Chris@1115 88 priority=PRIORITY name of the target priority
Chris@1115 89 allow_override=ATTRS allow email content to override attributes
Chris@1115 90 specified by previous options
Chris@1115 91 ATTRS is a comma separated list of attributes
Chris@1115 92
Chris@1115 93 Processed emails control options:
Chris@1115 94 move_on_success=MAILBOX move emails that were successfully received
Chris@1115 95 to MAILBOX instead of deleting them
Chris@1115 96 move_on_failure=MAILBOX move emails that were ignored to MAILBOX
Chris@1115 97
Chris@1115 98 Examples:
Chris@1115 99 # No project specified. Emails MUST contain the 'Project' keyword:
Chris@1115 100
Chris@1115 101 rake redmine:email:receive_imap RAILS_ENV="production" \\
Chris@1115 102 host=imap.foo.bar username=redmine@example.net password=xxx
Chris@1115 103
Chris@1115 104
Chris@1115 105 # Fixed project and default tracker specified, but emails can override
Chris@1115 106 # both tracker and priority attributes:
Chris@1115 107
Chris@1115 108 rake redmine:email:receive_imap RAILS_ENV="production" \\
Chris@1115 109 host=imap.foo.bar username=redmine@example.net password=xxx ssl=1 \\
Chris@1115 110 project=foo \\
Chris@1115 111 tracker=bug \\
Chris@1115 112 allow_override=tracker,priority
Chris@1115 113 END_DESC
Chris@1115 114
Chris@1115 115 task :receive_imap => :environment do
Chris@1115 116 imap_options = {:host => ENV['host'],
Chris@1115 117 :port => ENV['port'],
Chris@1115 118 :ssl => ENV['ssl'],
Chris@1115 119 :username => ENV['username'],
Chris@1115 120 :password => ENV['password'],
Chris@1115 121 :folder => ENV['folder'],
Chris@1115 122 :move_on_success => ENV['move_on_success'],
Chris@1115 123 :move_on_failure => ENV['move_on_failure']}
Chris@1115 124
Chris@1464 125 Redmine::IMAP.check(imap_options, MailHandler.extract_options_from_env(ENV))
Chris@1115 126 end
Chris@1115 127
Chris@1115 128 desc <<-END_DESC
Chris@1115 129 Read emails from an POP3 server.
Chris@1115 130
Chris@1115 131 Available POP3 options:
Chris@1115 132 host=HOST POP3 server host (default: 127.0.0.1)
Chris@1115 133 port=PORT POP3 server port (default: 110)
Chris@1115 134 username=USERNAME POP3 account
Chris@1115 135 password=PASSWORD POP3 password
Chris@1115 136 apop=1 use APOP authentication (default: false)
Chris@1115 137 delete_unprocessed=1 delete messages that could not be processed
Chris@1115 138 successfully from the server (default
Chris@1115 139 behaviour is to leave them on the server)
Chris@1115 140
Chris@1115 141 See redmine:email:receive_imap for more options and examples.
Chris@1115 142 END_DESC
Chris@1115 143
Chris@1115 144 task :receive_pop3 => :environment do
Chris@1115 145 pop_options = {:host => ENV['host'],
Chris@1115 146 :port => ENV['port'],
Chris@1115 147 :apop => ENV['apop'],
Chris@1115 148 :username => ENV['username'],
Chris@1115 149 :password => ENV['password'],
Chris@1115 150 :delete_unprocessed => ENV['delete_unprocessed']}
Chris@1115 151
Chris@1464 152 Redmine::POP3.check(pop_options, MailHandler.extract_options_from_env(ENV))
Chris@1115 153 end
Chris@1115 154
Chris@1115 155 desc "Send a test email to the user with the provided login name"
Chris@1115 156 task :test, [:login] => :environment do |task, args|
Chris@1115 157 include Redmine::I18n
Chris@1115 158 abort l(:notice_email_error, "Please include the user login to test with. Example: rake redmine:email:test[login]") if args[:login].blank?
Chris@1115 159
Chris@1115 160 user = User.find_by_login(args[:login])
Chris@1115 161 abort l(:notice_email_error, "User #{args[:login]} not found") unless user && user.logged?
Chris@1115 162
Chris@1115 163 ActionMailer::Base.raise_delivery_errors = true
Chris@1115 164 begin
Chris@1115 165 Mailer.with_synched_deliveries do
Chris@1115 166 Mailer.test_email(user).deliver
Chris@1115 167 end
Chris@1115 168 puts l(:notice_email_sent, user.mail)
Chris@1115 169 rescue Exception => e
Chris@1115 170 abort l(:notice_email_error, e.message)
Chris@1115 171 end
Chris@1115 172 end
Chris@1115 173 end
Chris@1115 174 end