debian-mirror-gitlab/app/workers/emails_on_push_worker.rb

101 lines
2.8 KiB
Ruby
Raw Normal View History

2014-09-02 18:07:02 +05:30
class EmailsOnPushWorker
include Sidekiq::Worker
sidekiq_options queue: :mailers
2016-06-02 11:05:42 +05:30
attr_reader :email, :skip_premailer
2015-04-26 12:48:37 +05:30
def perform(project_id, recipients, push_data, options = {})
options.symbolize_keys!
options.reverse_merge!(
2015-09-25 12:07:36 +05:30
send_from_committer_email: false,
2015-04-26 12:48:37 +05:30
disable_diffs: false
)
send_from_committer_email = options[:send_from_committer_email]
disable_diffs = options[:disable_diffs]
2014-09-02 18:07:02 +05:30
project = Project.find(project_id)
before_sha = push_data["before"]
after_sha = push_data["after"]
2015-04-26 12:48:37 +05:30
ref = push_data["ref"]
2014-09-02 18:07:02 +05:30
author_id = push_data["user_id"]
2015-09-25 12:07:36 +05:30
action =
2015-04-26 12:48:37 +05:30
if Gitlab::Git.blank_ref?(before_sha)
2015-09-25 12:07:36 +05:30
:create
2015-04-26 12:48:37 +05:30
elsif Gitlab::Git.blank_ref?(after_sha)
:delete
else
:push
end
2016-06-02 11:05:42 +05:30
diff_refs = nil
2015-04-26 12:48:37 +05:30
compare = nil
reverse_compare = false
2016-08-24 12:49:21 +05:30
2015-04-26 12:48:37 +05:30
if action == :push
2016-08-24 12:49:21 +05:30
merge_base_sha = project.merge_base_commit(before_sha, after_sha).try(:sha)
2015-04-26 12:48:37 +05:30
compare = Gitlab::Git::Compare.new(project.repository.raw_repository, before_sha, after_sha)
2016-08-24 12:49:21 +05:30
diff_refs = Gitlab::Diff::DiffRefs.new(
base_sha: merge_base_sha,
start_sha: before_sha,
head_sha: after_sha
)
2014-09-02 18:07:02 +05:30
2015-04-26 12:48:37 +05:30
return false if compare.same
2014-09-02 18:07:02 +05:30
2015-04-26 12:48:37 +05:30
if compare.commits.empty?
compare = Gitlab::Git::Compare.new(project.repository.raw_repository, after_sha, before_sha)
2016-08-24 12:49:21 +05:30
diff_refs = Gitlab::Diff::DiffRefs.new(
base_sha: merge_base_sha,
start_sha: after_sha,
head_sha: before_sha
)
2015-04-26 12:48:37 +05:30
reverse_compare = true
return false if compare.commits.empty?
end
end
2014-09-02 18:07:02 +05:30
2016-06-02 11:05:42 +05:30
recipients.split.each do |recipient|
2015-09-25 12:07:36 +05:30
begin
2016-06-02 11:05:42 +05:30
send_email(
2015-09-25 12:07:36 +05:30
recipient,
2016-06-02 11:05:42 +05:30
project_id,
author_id: author_id,
ref: ref,
action: action,
compare: compare,
reverse_compare: reverse_compare,
diff_refs: diff_refs,
send_from_committer_email: send_from_committer_email,
disable_diffs: disable_diffs
)
2015-09-25 12:07:36 +05:30
# These are input errors and won't be corrected even if Sidekiq retries
rescue Net::SMTPFatalError, Net::SMTPSyntaxError => e
logger.info("Failed to send e-mail for project '#{project.name_with_namespace}' to #{recipient}: #{e}")
end
2014-09-02 18:07:02 +05:30
end
2015-04-26 12:48:37 +05:30
ensure
2016-06-02 11:05:42 +05:30
@email = nil
2015-04-26 12:48:37 +05:30
compare = nil
GC.start
2014-09-02 18:07:02 +05:30
end
2016-06-02 11:05:42 +05:30
private
def send_email(recipient, project_id, options)
# Generating the body of this email can be expensive, so only do it once
@skip_premailer ||= email.present?
@email ||= Notify.repository_push_email(project_id, options)
email.to = recipient
email.add_message_id
email.header[:skip_premailer] = true if skip_premailer
email.deliver_now
end
2014-09-02 18:07:02 +05:30
end