2011-10-08 17:36:38 -04:00
|
|
|
class Notify < ActionMailer::Base
|
2014-02-24 06:12:29 -05:00
|
|
|
include ActionDispatch::Routing::PolymorphicRoutes
|
|
|
|
|
2013-03-19 14:00:41 -04:00
|
|
|
include Emails::Issues
|
|
|
|
include Emails::MergeRequests
|
|
|
|
include Emails::Notes
|
|
|
|
include Emails::Projects
|
2013-09-11 14:17:28 -04:00
|
|
|
include Emails::Profile
|
|
|
|
include Emails::Groups
|
2013-01-09 00:44:05 -05:00
|
|
|
|
2012-04-23 08:32:56 -04:00
|
|
|
add_template_helper ApplicationHelper
|
2012-08-08 23:02:55 -04:00
|
|
|
add_template_helper GitlabMarkdownHelper
|
2013-07-17 10:35:11 -04:00
|
|
|
add_template_helper MergeRequestsHelper
|
2014-11-11 10:10:24 -05:00
|
|
|
add_template_helper EmailsHelper
|
2012-04-23 08:32:56 -04:00
|
|
|
|
2012-12-14 19:16:25 -05:00
|
|
|
default_url_options[:host] = Gitlab.config.gitlab.host
|
|
|
|
default_url_options[:protocol] = Gitlab.config.gitlab.protocol
|
2014-01-24 21:59:42 -05:00
|
|
|
default_url_options[:port] = Gitlab.config.gitlab.port unless Gitlab.config.gitlab_on_standard_port?
|
2012-12-28 13:11:28 -05:00
|
|
|
default_url_options[:script_name] = Gitlab.config.gitlab.relative_url_root
|
2012-03-31 08:59:06 -04:00
|
|
|
|
2014-02-17 12:49:42 -05:00
|
|
|
default from: Proc.new { default_sender_address.format }
|
2013-12-09 09:36:21 -05:00
|
|
|
default reply_to: "noreply@#{Gitlab.config.gitlab.host}"
|
2011-10-08 17:36:38 -04:00
|
|
|
|
2014-02-17 10:25:40 -05:00
|
|
|
# Just send email with 2 seconds delay
|
2013-02-01 10:04:41 -05:00
|
|
|
def self.delay
|
|
|
|
delay_for(2.seconds)
|
|
|
|
end
|
2012-10-13 14:55:50 -04:00
|
|
|
|
2015-01-18 10:29:37 -05:00
|
|
|
def test_email(recipient_email, subject, body)
|
|
|
|
mail(to: recipient_email,
|
2014-12-04 09:22:10 -05:00
|
|
|
subject: subject,
|
|
|
|
body: body.html_safe,
|
|
|
|
content_type: 'text/html'
|
|
|
|
)
|
|
|
|
end
|
|
|
|
|
2015-02-25 09:49:40 -05:00
|
|
|
# Splits "gitlab.corp.company.com" up into "gitlab.corp.company.com",
|
|
|
|
# "corp.company.com" and "company.com".
|
|
|
|
# Respects set tld length so "company.co.uk" won't match "somethingelse.uk"
|
|
|
|
def self.allowed_email_domains
|
|
|
|
domain_parts = Gitlab.config.gitlab.host.split(".")
|
|
|
|
allowed_domains = []
|
|
|
|
begin
|
|
|
|
allowed_domains << domain_parts.join(".")
|
|
|
|
domain_parts.shift
|
|
|
|
end while domain_parts.length > ActionDispatch::Http::URL.tld_length
|
|
|
|
|
|
|
|
allowed_domains
|
|
|
|
end
|
|
|
|
|
2012-08-20 23:04:53 -04:00
|
|
|
private
|
|
|
|
|
2014-02-17 12:49:42 -05:00
|
|
|
# The default email address to send emails from
|
|
|
|
def default_sender_address
|
|
|
|
address = Mail::Address.new(Gitlab.config.gitlab.email_from)
|
2015-01-02 07:47:22 -05:00
|
|
|
address.display_name = Gitlab.config.gitlab.email_display_name
|
2014-02-17 12:49:42 -05:00
|
|
|
address
|
|
|
|
end
|
|
|
|
|
|
|
|
# Return an email address that displays the name of the sender.
|
|
|
|
# Only the displayed name changes; the actual email address is always the same.
|
2015-02-25 08:05:45 -05:00
|
|
|
def sender(sender_id, send_from_user_email = false)
|
2014-02-17 12:49:42 -05:00
|
|
|
if sender = User.find(sender_id)
|
|
|
|
address = default_sender_address
|
|
|
|
address.display_name = sender.name
|
2015-02-25 08:05:45 -05:00
|
|
|
|
2015-02-25 09:49:40 -05:00
|
|
|
sender_domain = sender.email.split("@").last
|
|
|
|
if send_from_user_email && self.class.allowed_email_domains.include?(sender_domain)
|
2015-02-25 08:05:45 -05:00
|
|
|
address.address = sender.email
|
|
|
|
end
|
|
|
|
|
2014-02-17 12:49:42 -05:00
|
|
|
address.format
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2012-08-20 23:18:57 -04:00
|
|
|
# Look up a User by their ID and return their email address
|
|
|
|
#
|
|
|
|
# recipient_id - User ID
|
|
|
|
#
|
|
|
|
# Returns a String containing the User's email address.
|
|
|
|
def recipient(recipient_id)
|
|
|
|
if recipient = User.find(recipient_id)
|
2015-02-06 18:23:58 -05:00
|
|
|
recipient.notification_email
|
2012-08-20 23:18:57 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2014-01-21 19:34:39 -05:00
|
|
|
# Set the References header field
|
|
|
|
#
|
|
|
|
# local_part - The local part of the referenced message ID
|
|
|
|
#
|
|
|
|
def set_reference(local_part)
|
|
|
|
headers["References"] = "<#{local_part}@#{Gitlab.config.gitlab.host}>"
|
|
|
|
end
|
|
|
|
|
2012-08-20 23:04:53 -04:00
|
|
|
# Formats arguments into a String suitable for use as an email subject
|
|
|
|
#
|
|
|
|
# extra - Extra Strings to be inserted into the subject
|
|
|
|
#
|
|
|
|
# Examples
|
|
|
|
#
|
|
|
|
# >> subject('Lorem ipsum')
|
2014-02-17 10:45:28 -05:00
|
|
|
# => "Lorem ipsum"
|
2012-08-20 23:04:53 -04:00
|
|
|
#
|
|
|
|
# # Automatically inserts Project name when @project is set
|
|
|
|
# >> @project = Project.last
|
|
|
|
# => #<Project id: 1, name: "Ruby on Rails", path: "ruby_on_rails", ...>
|
|
|
|
# >> subject('Lorem ipsum')
|
2014-02-17 10:45:28 -05:00
|
|
|
# => "Ruby on Rails | Lorem ipsum "
|
2012-08-20 23:04:53 -04:00
|
|
|
#
|
|
|
|
# # Accepts multiple arguments
|
|
|
|
# >> subject('Lorem ipsum', 'Dolor sit amet')
|
2014-02-17 10:45:28 -05:00
|
|
|
# => "Lorem ipsum | Dolor sit amet"
|
2012-08-20 23:04:53 -04:00
|
|
|
def subject(*extra)
|
2014-02-17 10:45:28 -05:00
|
|
|
subject = ""
|
2014-02-18 04:34:57 -05:00
|
|
|
subject << "#{@project.name} | " if @project
|
2014-02-17 10:45:28 -05:00
|
|
|
subject << extra.join(' | ') if extra.present?
|
2012-12-31 12:46:40 -05:00
|
|
|
subject
|
2011-12-18 09:07:47 -05:00
|
|
|
end
|
2014-02-24 06:12:29 -05:00
|
|
|
|
|
|
|
# Return a string suitable for inclusion in the 'Message-Id' mail header.
|
|
|
|
#
|
|
|
|
# The message-id is generated from the unique URL to a model object.
|
|
|
|
def message_id(model)
|
|
|
|
model_name = model.class.model_name.singular_route_key
|
|
|
|
"<#{model_name}_#{model.id}@#{Gitlab.config.gitlab.host}>"
|
|
|
|
end
|
|
|
|
|
|
|
|
# Send an email that starts a new conversation thread,
|
|
|
|
# with headers suitable for grouping by thread in email clients.
|
|
|
|
#
|
|
|
|
# See: mail_answer_thread
|
|
|
|
def mail_new_thread(model, headers = {}, &block)
|
|
|
|
headers['Message-ID'] = message_id(model)
|
2015-02-07 12:35:50 -05:00
|
|
|
headers['X-GitLab-Project'] = "#{@project.name} | " if @project
|
2014-02-24 06:12:29 -05:00
|
|
|
mail(headers, &block)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Send an email that responds to an existing conversation thread,
|
|
|
|
# with headers suitable for grouping by thread in email clients.
|
|
|
|
#
|
|
|
|
# For grouping emails by thread, email clients heuristics require the answers to:
|
|
|
|
#
|
|
|
|
# * have a subject that begin by 'Re: '
|
|
|
|
# * have a 'In-Reply-To' or 'References' header that references the original 'Message-ID'
|
|
|
|
#
|
|
|
|
def mail_answer_thread(model, headers = {}, &block)
|
|
|
|
headers['In-Reply-To'] = message_id(model)
|
|
|
|
headers['References'] = message_id(model)
|
2015-02-07 12:35:50 -05:00
|
|
|
headers['X-GitLab-Project'] = "#{@project.name} | " if @project
|
2014-02-24 06:12:29 -05:00
|
|
|
|
2015-03-24 21:28:10 -04:00
|
|
|
if headers[:subject]
|
2014-02-24 06:12:29 -05:00
|
|
|
headers[:subject].prepend('Re: ')
|
|
|
|
end
|
|
|
|
|
|
|
|
mail(headers, &block)
|
|
|
|
end
|
2011-10-08 17:36:38 -04:00
|
|
|
end
|