c8a115c0e3
Any mention of Issues, MergeRequests, or Commits via GitLab-flavored markdown references in descriptions, titles, or attached Notes creates a back-reference Note that links to the original referencer. Furthermore, pushing commits with commit messages that match a (configurable) regexp to a project's default branch will close any issues mentioned by GFM in the matched closing phrase. If accepting a merge request would close any Issues in this way, a banner is appended to the merge request's main panel to indicate this.
56 lines
1.7 KiB
Ruby
56 lines
1.7 KiB
Ruby
class MergeRequestObserver < ActivityObserver
|
|
observe :merge_request
|
|
|
|
def after_create(merge_request)
|
|
if merge_request.author_id
|
|
create_event(merge_request, Event.determine_action(merge_request))
|
|
end
|
|
|
|
notification.new_merge_request(merge_request, current_user)
|
|
|
|
merge_request.create_cross_references!(merge_request.project, current_user)
|
|
end
|
|
|
|
def after_close(merge_request, transition)
|
|
create_event(merge_request, Event::CLOSED)
|
|
Note.create_status_change_note(merge_request, merge_request.target_project, current_user, merge_request.state, nil)
|
|
|
|
notification.close_mr(merge_request, current_user)
|
|
end
|
|
|
|
def after_merge(merge_request, transition)
|
|
notification.merge_mr(merge_request)
|
|
# Since MR can be merged via sidekiq
|
|
# to prevent event duplication do this check
|
|
return true if merge_request.merge_event
|
|
|
|
Event.create(
|
|
project: merge_request.target_project,
|
|
target_id: merge_request.id,
|
|
target_type: merge_request.class.name,
|
|
action: Event::MERGED,
|
|
author_id: merge_request.author_id_of_changes
|
|
)
|
|
end
|
|
|
|
def after_reopen(merge_request, transition)
|
|
create_event(merge_request, Event::REOPENED)
|
|
Note.create_status_change_note(merge_request, merge_request.target_project, current_user, merge_request.state, nil)
|
|
end
|
|
|
|
def after_update(merge_request)
|
|
notification.reassigned_merge_request(merge_request, current_user) if merge_request.is_being_reassigned?
|
|
|
|
merge_request.notice_added_references(merge_request.project, current_user)
|
|
end
|
|
|
|
def create_event(record, status)
|
|
Event.create(
|
|
project: record.target_project,
|
|
target_id: record.id,
|
|
target_type: record.class.name,
|
|
action: status,
|
|
author_id: current_user.id
|
|
)
|
|
end
|
|
end
|