2012-10-09 18:25:29 -04:00
|
|
|
class MergeRequestObserver < ActiveRecord::Observer
|
|
|
|
cattr_accessor :current_user
|
|
|
|
|
|
|
|
def after_create(merge_request)
|
|
|
|
if merge_request.assignee && merge_request.assignee != current_user
|
2013-01-09 08:44:05 +03:00
|
|
|
Notify.delay.new_merge_request_email(merge_request.id)
|
2012-10-09 18:25:29 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2013-02-18 12:40:56 +04:00
|
|
|
def after_close(merge_request, transition)
|
2012-10-09 18:25:29 -04:00
|
|
|
send_reassigned_email(merge_request) if merge_request.is_being_reassigned?
|
|
|
|
|
2013-02-18 12:40:56 +04:00
|
|
|
Note.create_status_change_note(merge_request, current_user, merge_request.state)
|
|
|
|
end
|
|
|
|
|
|
|
|
def after_reopen(merge_request, transition)
|
|
|
|
send_reassigned_email(merge_request) if merge_request.is_being_reassigned?
|
|
|
|
|
|
|
|
Note.create_status_change_note(merge_request, current_user, merge_request.state)
|
|
|
|
end
|
|
|
|
|
|
|
|
def after_update(merge_request)
|
|
|
|
send_reassigned_email(merge_request) if merge_request.is_being_reassigned?
|
2012-10-09 18:25:29 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
protected
|
|
|
|
|
|
|
|
def send_reassigned_email(merge_request)
|
2012-10-11 11:05:13 -04:00
|
|
|
recipients_ids = merge_request.assignee_id_was, merge_request.assignee_id
|
|
|
|
recipients_ids.delete current_user.id
|
2012-10-09 18:25:29 -04:00
|
|
|
|
2012-10-11 11:05:13 -04:00
|
|
|
recipients_ids.each do |recipient_id|
|
2013-01-09 08:44:05 +03:00
|
|
|
Notify.delay.reassigned_merge_request_email(recipient_id, merge_request.id, merge_request.assignee_id_was)
|
2012-10-11 11:05:13 -04:00
|
|
|
end
|
2012-10-09 18:25:29 -04:00
|
|
|
end
|
|
|
|
end
|