5fe75649b3
#changed_merge_request_email was really sending emails about merge request reassignments. Updated method name to reflect that. Update method to take ids and then perform #finds itself during mailer queue worker kick-off.
75 lines
2.6 KiB
Ruby
75 lines
2.6 KiB
Ruby
class Notify < ActionMailer::Base
|
|
include Resque::Mailer
|
|
add_template_helper ApplicationHelper
|
|
|
|
default_url_options[:host] = EMAIL_OPTS["host"]
|
|
default_url_options[:protocol] = -> { EMAIL_OPTS["protocol"] ? EMAIL_OPTS["protocol"] : "http" }.call
|
|
|
|
default from: EMAIL_OPTS["from"]
|
|
|
|
def new_user_email(user_id, password)
|
|
@user = User.find(user_id)
|
|
@password = password
|
|
mail(:to => @user.email, :subject => "gitlab | Account was created for you")
|
|
end
|
|
|
|
def new_issue_email(issue)
|
|
@issue = Issue.find(issue['id'])
|
|
@user = @issue.assignee
|
|
@project = @issue.project
|
|
|
|
mail(:to => @user.email, :subject => "gitlab | New Issue was created")
|
|
end
|
|
|
|
def note_wall_email(user, note)
|
|
@user = user
|
|
@note = Note.find(note['id'])
|
|
@project = @note.project
|
|
mail(:to => @user['email'], :subject => "gitlab | #{@note.project.name} ")
|
|
end
|
|
|
|
def note_commit_email(user, note)
|
|
@user = user
|
|
@note = Note.find(note['id'])
|
|
@project = @note.project
|
|
@commit = @note.target
|
|
mail(:to => @user['email'], :subject => "gitlab | note for commit | #{@note.project.name} ")
|
|
end
|
|
|
|
def note_merge_request_email(user, note)
|
|
@user = user
|
|
@note = Note.find(note['id'])
|
|
@project = @note.project
|
|
@merge_request = @note.noteable
|
|
mail(:to => @user['email'], :subject => "gitlab | note for merge request | #{@note.project.name} ")
|
|
end
|
|
|
|
def note_issue_email(user, note)
|
|
@user = user
|
|
@note = Note.find(note['id'])
|
|
@project = @note.project
|
|
@issue = @note.noteable
|
|
mail(:to => @user['email'], :subject => "gitlab | note for issue #{@issue.id} | #{@note.project.name} ")
|
|
end
|
|
|
|
def new_merge_request_email(merge_request)
|
|
@merge_request = MergeRequest.find(merge_request['id'])
|
|
@user = @merge_request.assignee
|
|
@project = @merge_request.project
|
|
mail(:to => @user.email, :subject => "gitlab | new merge request | #{@merge_request.title} ")
|
|
end
|
|
|
|
def reassigned_merge_request_email(recipient_id, merge_request_id, previous_assignee_id)
|
|
recipient = User.find(recipient_id)
|
|
@merge_request = MergeRequest.find(merge_request_id)
|
|
@previous_assignee ||= User.find(previous_assignee_id)
|
|
mail(:to => recipient.email, :subject => "gitlab | merge request changed | #{@merge_request.title} ")
|
|
end
|
|
|
|
def reassigned_issue_email(recipient_id, issue_id, previous_assignee_id)
|
|
recipient = User.find(recipient_id)
|
|
@issue = Issue.find(issue_id)
|
|
@previous_assignee ||= User.find(previous_assignee_id)
|
|
mail(:to => recipient.email, :subject => "gitlab | changed issue | #{@issue.title} ")
|
|
end
|
|
end
|