debian-mirror-gitlab/app/mailers/notify.rb

175 lines
5.3 KiB
Ruby
Raw Normal View History

2015-09-25 12:07:36 +05:30
class Notify < BaseMailer
2014-09-02 18:07:02 +05:30
include ActionDispatch::Routing::PolymorphicRoutes
include Emails::Issues
include Emails::MergeRequests
include Emails::Notes
include Emails::Projects
include Emails::Profile
2015-12-23 02:04:40 +05:30
include Emails::Builds
2016-11-03 12:29:30 +05:30
include Emails::Pipelines
include Emails::Members
2014-09-02 18:07:02 +05:30
add_template_helper MergeRequestsHelper
2016-06-02 11:05:42 +05:30
add_template_helper DiffHelper
add_template_helper BlobHelper
2015-04-26 12:48:37 +05:30
add_template_helper EmailsHelper
add_template_helper MembersHelper
add_template_helper GitlabRoutingHelper
2015-04-26 12:48:37 +05:30
def test_email(recipient_email, subject, body)
mail(to: recipient_email,
subject: subject,
body: body.html_safe,
content_type: 'text/html'
2015-12-23 02:04:40 +05:30
)
2015-04-26 12:48:37 +05:30
end
# 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
def can_send_from_user_email?(sender)
sender_domain = sender.email.split("@").last
self.class.allowed_email_domains.include?(sender_domain)
end
2015-12-23 02:04:40 +05:30
private
2014-09-02 18:07:02 +05:30
# 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-04-26 12:48:37 +05:30
def sender(sender_id, send_from_user_email = false)
return unless sender = User.find(sender_id)
2015-09-11 14:41:01 +05:30
2015-04-26 12:48:37 +05:30
address = default_sender_address
address.display_name = sender.name
if send_from_user_email && can_send_from_user_email?(sender)
address.address = sender.email
2014-09-02 18:07:02 +05:30
end
2015-04-26 12:48:37 +05:30
address.format
2014-09-02 18:07:02 +05:30
end
# 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)
2015-04-26 12:48:37 +05:30
@current_user = User.find(recipient_id)
@current_user.notification_email
2014-09-02 18:07:02 +05:30
end
# 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')
# => "Lorem ipsum"
#
# # 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')
# => "Ruby on Rails | Lorem ipsum "
#
# # Accepts multiple arguments
# >> subject('Lorem ipsum', 'Dolor sit amet')
# => "Lorem ipsum | Dolor sit amet"
def subject(*extra)
subject = ""
subject << "#{@project.name} | " if @project
subject << extra.join(' | ') if extra.present?
2016-11-03 12:29:30 +05:30
subject << " | #{Gitlab.config.gitlab.email_subject_suffix}" if Gitlab.config.gitlab.email_subject_suffix.present?
2014-09-02 18:07:02 +05:30
subject
end
# 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
2015-09-25 12:07:36 +05:30
def mail_thread(model, headers = {})
2016-01-29 22:53:50 +05:30
add_project_headers
2015-09-25 12:07:36 +05:30
headers["X-GitLab-#{model.class.name}-ID"] = model.id
headers['X-GitLab-Reply-Key'] = reply_key
2015-09-25 12:07:36 +05:30
2016-09-29 09:46:39 +05:30
if !@labels_url && @sent_notification && @sent_notification.unsubscribable?
2016-10-01 15:18:49 +05:30
headers['List-Unsubscribe'] = "<#{unsubscribe_sent_notification_url(@sent_notification, force: true)}>"
2016-09-29 09:46:39 +05:30
@sent_notification_url = unsubscribe_sent_notification_url(@sent_notification)
end
if Gitlab::IncomingEmail.enabled?
2015-09-25 12:07:36 +05:30
address = Mail::Address.new(Gitlab::IncomingEmail.reply_address(reply_key))
address.display_name = @project.name_with_namespace
headers['Reply-To'] = address
2016-06-02 11:05:42 +05:30
fallback_reply_message_id = "<reply-#{reply_key}@#{Gitlab.config.gitlab.host}>".freeze
headers['References'] ||= ''
headers['References'] << ' ' << fallback_reply_message_id
2015-09-25 12:07:36 +05:30
@reply_by_email = true
end
mail(headers)
end
2014-09-02 18:07:02 +05:30
# Send an email that starts a new conversation thread,
# with headers suitable for grouping by thread in email clients.
#
# See: mail_answer_thread
2015-09-25 12:07:36 +05:30
def mail_new_thread(model, headers = {})
2014-09-02 18:07:02 +05:30
headers['Message-ID'] = message_id(model)
2015-09-25 12:07:36 +05:30
mail_thread(model, headers)
2014-09-02 18:07:02 +05:30
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'
#
2015-09-25 12:07:36 +05:30
def mail_answer_thread(model, headers = {})
2015-10-24 18:46:33 +05:30
headers['Message-ID'] = "<#{SecureRandom.hex}@#{Gitlab.config.gitlab.host}>"
2014-09-02 18:07:02 +05:30
headers['In-Reply-To'] = message_id(model)
headers['References'] = message_id(model)
2015-09-25 12:07:36 +05:30
headers[:subject].prepend('Re: ') if headers[:subject]
2014-09-02 18:07:02 +05:30
2015-09-25 12:07:36 +05:30
mail_thread(model, headers)
2014-09-02 18:07:02 +05:30
end
2015-04-26 12:48:37 +05:30
2015-09-25 12:07:36 +05:30
def reply_key
@reply_key ||= SentNotification.reply_key
2015-04-26 12:48:37 +05:30
end
2016-01-29 22:53:50 +05:30
def add_project_headers
return unless @project
headers['X-GitLab-Project'] = @project.name
headers['X-GitLab-Project-Id'] = @project.id
headers['X-GitLab-Project-Path'] = @project.path_with_namespace
end
2014-09-02 18:07:02 +05:30
end