2013-03-19 14:00:41 -04:00
|
|
|
module Emails
|
|
|
|
module MergeRequests
|
2013-03-28 06:52:44 -04:00
|
|
|
def new_merge_request_email(recipient_id, merge_request_id)
|
2013-03-19 14:00:41 -04:00
|
|
|
@merge_request = MergeRequest.find(merge_request_id)
|
2013-12-16 12:56:47 -05:00
|
|
|
@project = @merge_request.project
|
2014-02-18 05:12:01 -05:00
|
|
|
@target_url = project_merge_request_url(@project, @merge_request)
|
2014-02-24 06:12:29 -05:00
|
|
|
mail_new_thread(@merge_request,
|
|
|
|
from: sender(@merge_request.author_id),
|
|
|
|
cc: recipient(recipient_id),
|
|
|
|
subject: subject("#{@merge_request.title} (##{@merge_request.iid})"))
|
2013-03-19 14:00:41 -04:00
|
|
|
end
|
|
|
|
|
2014-02-17 12:49:42 -05:00
|
|
|
def reassigned_merge_request_email(recipient_id, merge_request_id, previous_assignee_id, updated_by_user_id)
|
2013-03-19 14:00:41 -04:00
|
|
|
@merge_request = MergeRequest.find(merge_request_id)
|
2014-01-19 13:55:59 -05:00
|
|
|
@previous_assignee = User.find_by(id: previous_assignee_id) if previous_assignee_id
|
2013-12-16 12:56:47 -05:00
|
|
|
@project = @merge_request.project
|
2014-02-18 05:12:01 -05:00
|
|
|
@target_url = project_merge_request_url(@project, @merge_request)
|
2014-02-24 06:12:29 -05:00
|
|
|
mail_answer_thread(@merge_request,
|
|
|
|
from: sender(updated_by_user_id),
|
|
|
|
cc: recipient(recipient_id),
|
|
|
|
subject: subject("#{@merge_request.title} (##{@merge_request.iid})"))
|
2013-03-19 14:00:41 -04:00
|
|
|
end
|
2013-03-28 06:14:53 -04:00
|
|
|
|
|
|
|
def closed_merge_request_email(recipient_id, merge_request_id, updated_by_user_id)
|
|
|
|
@merge_request = MergeRequest.find(merge_request_id)
|
|
|
|
@updated_by = User.find updated_by_user_id
|
2013-12-16 12:56:47 -05:00
|
|
|
@project = @merge_request.project
|
2014-02-18 05:12:01 -05:00
|
|
|
@target_url = project_merge_request_url(@project, @merge_request)
|
2014-02-24 06:12:29 -05:00
|
|
|
mail_answer_thread(@merge_request,
|
|
|
|
from: sender(updated_by_user_id),
|
|
|
|
cc: recipient(recipient_id),
|
|
|
|
subject: subject("#{@merge_request.title} (##{@merge_request.iid})"))
|
2013-03-28 06:14:53 -04:00
|
|
|
end
|
|
|
|
|
2014-03-24 10:11:35 -04:00
|
|
|
def merged_merge_request_email(recipient_id, merge_request_id, updated_by_user_id)
|
2013-03-28 06:14:53 -04:00
|
|
|
@merge_request = MergeRequest.find(merge_request_id)
|
2013-12-16 12:56:47 -05:00
|
|
|
@project = @merge_request.project
|
2014-02-18 05:12:01 -05:00
|
|
|
@target_url = project_merge_request_url(@project, @merge_request)
|
2014-02-24 06:12:29 -05:00
|
|
|
mail_answer_thread(@merge_request,
|
|
|
|
from: sender(updated_by_user_id),
|
|
|
|
cc: recipient(recipient_id),
|
|
|
|
subject: subject("#{@merge_request.title} (##{@merge_request.iid})"))
|
2013-03-28 06:14:53 -04:00
|
|
|
end
|
2013-03-19 14:00:41 -04:00
|
|
|
end
|
2013-04-25 10:15:33 -04:00
|
|
|
|
|
|
|
# Over rides default behavour to show source/target
|
|
|
|
# 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')
|
|
|
|
# => "GitLab Merge Request | Lorem ipsum"
|
|
|
|
#
|
|
|
|
# # Automatically inserts Project name:
|
|
|
|
# Forked MR
|
|
|
|
# => source project => <Project id: 1, name: "Ruby on Rails", path: "ruby_on_rails", ...>
|
|
|
|
# => target project => <Project id: 2, name: "My Ror", path: "ruby_on_rails", ...>
|
|
|
|
# => source branch => source
|
|
|
|
# => target branch => target
|
|
|
|
# >> subject('Lorem ipsum')
|
|
|
|
# => "GitLab Merge Request | Ruby on Rails:source >> My Ror:target | Lorem ipsum "
|
|
|
|
#
|
|
|
|
# Non Forked MR
|
|
|
|
# => source project => <Project id: 1, name: "Ruby on Rails", path: "ruby_on_rails", ...>
|
|
|
|
# => target project => <Project id: 1, name: "Ruby on Rails", path: "ruby_on_rails", ...>
|
|
|
|
# => source branch => source
|
|
|
|
# => target branch => target
|
|
|
|
# >> subject('Lorem ipsum')
|
|
|
|
# => "GitLab Merge Request | Ruby on Rails | source >> target | Lorem ipsum "
|
|
|
|
# # Accepts multiple arguments
|
|
|
|
# >> subject('Lorem ipsum', 'Dolor sit amet')
|
|
|
|
# => "GitLab Merge Request | Lorem ipsum | Dolor sit amet"
|
|
|
|
def subject(*extra)
|
2014-02-17 10:45:28 -05:00
|
|
|
subject = "Merge Request | "
|
2013-04-25 10:15:33 -04:00
|
|
|
if @merge_request.for_fork?
|
|
|
|
subject << "#{@merge_request.source_project.name_with_namespace}:#{merge_request.source_branch} >> #{@merge_request.target_project.name_with_namespace}:#{merge_request.target_branch}"
|
|
|
|
else
|
|
|
|
subject << "#{@merge_request.source_project.name_with_namespace} | #{merge_request.source_branch} >> #{merge_request.target_branch}"
|
|
|
|
end
|
|
|
|
subject << " | " + extra.join(' | ') if extra.present?
|
|
|
|
subject
|
|
|
|
end
|
2013-07-17 10:35:11 -04:00
|
|
|
|
2013-03-19 14:00:41 -04:00
|
|
|
end
|