539c70c7d6
Forked MR's will print Project:Branch <source_project_with_path>:<source_branch> -> <target_project_with_path>:<target_branch> Non forked MR's will print Branch <source_branch> -> <target_branch> Change-Id: I89399aec2e7fde8e4b64b110a48099a95ae4f038
66 lines
3 KiB
Ruby
66 lines
3 KiB
Ruby
module Emails
|
|
module MergeRequests
|
|
def new_merge_request_email(recipient_id, merge_request_id)
|
|
@merge_request = MergeRequest.find(merge_request_id)
|
|
mail(to: recipient(recipient_id), subject: subject("new merge request !#{@merge_request.id}", @merge_request.title))
|
|
end
|
|
|
|
def reassigned_merge_request_email(recipient_id, merge_request_id, previous_assignee_id)
|
|
@merge_request = MergeRequest.find(merge_request_id)
|
|
@previous_assignee = User.find_by_id(previous_assignee_id) if previous_assignee_id
|
|
mail(to: recipient(recipient_id), subject: subject("changed merge request !#{@merge_request.id}", @merge_request.title))
|
|
end
|
|
|
|
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
|
|
mail(to: recipient(recipient_id), subject: subject("Closed merge request !#{@merge_request.id}", @merge_request.title))
|
|
end
|
|
|
|
def merged_merge_request_email(recipient_id, merge_request_id)
|
|
@merge_request = MergeRequest.find(merge_request_id)
|
|
mail(to: recipient(recipient_id), subject: subject("Accepted merge request !#{@merge_request.id}", @merge_request.title))
|
|
end
|
|
end
|
|
|
|
# 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)
|
|
subject = "GitLab Merge Request |"
|
|
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
|
|
|
|
end
|