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
|
2013-11-08 10:04:36 -05:00
|
|
|
mail(to: recipient(recipient_id), subject: subject("New merge request ##{@merge_request.iid}", @merge_request.title))
|
2013-03-19 14:00:41 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
def reassigned_merge_request_email(recipient_id, merge_request_id, previous_assignee_id)
|
|
|
|
@merge_request = MergeRequest.find(merge_request_id)
|
2013-07-01 12:01:19 -04: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
|
2013-11-08 10:04:36 -05:00
|
|
|
mail(to: recipient(recipient_id), subject: subject("Changed merge request ##{@merge_request.iid}", @merge_request.title))
|
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
|
2013-11-08 10:04:36 -05:00
|
|
|
mail(to: recipient(recipient_id), subject: subject("Closed merge request ##{@merge_request.iid}", @merge_request.title))
|
2013-03-28 06:14:53 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
def merged_merge_request_email(recipient_id, merge_request_id)
|
|
|
|
@merge_request = MergeRequest.find(merge_request_id)
|
2013-12-16 12:56:47 -05:00
|
|
|
@project = @merge_request.project
|
2013-11-08 10:04:36 -05:00
|
|
|
mail(to: recipient(recipient_id), subject: subject("Accepted merge request ##{@merge_request.iid}", @merge_request.title))
|
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)
|
|
|
|
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
|
2013-07-17 10:35:11 -04:00
|
|
|
|
2013-03-19 14:00:41 -04:00
|
|
|
end
|