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

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

101 lines
2.5 KiB
Ruby
Raw Permalink Normal View History

2018-11-08 19:23:39 +05:30
# frozen_string_literal: true
2020-04-08 14:13:33 +05:30
class EmailsOnPushWorker # rubocop:disable Scalability/IdempotentWorker
2018-03-17 18:26:18 +05:30
include ApplicationWorker
2014-09-02 18:07:02 +05:30
2021-10-27 15:23:28 +05:30
data_consistency :always
2021-06-08 01:23:25 +05:30
sidekiq_options retry: 3
2016-06-02 11:05:42 +05:30
attr_reader :email, :skip_premailer
2019-12-21 20:55:43 +05:30
feature_category :source_code_management
2020-04-22 19:07:51 +05:30
urgency :low
2019-12-26 22:10:19 +05:30
worker_resource_boundary :cpu
2020-03-13 15:44:24 +05:30
weight 2
2019-12-21 20:55:43 +05:30
2015-04-26 12:48:37 +05:30
def perform(project_id, recipients, push_data, options = {})
options.symbolize_keys!
options.reverse_merge!(
2022-08-27 11:52:29 +05:30
send_from_committer_email: false,
disable_diffs: false
2015-04-26 12:48:37 +05:30
)
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
2017-08-17 22:00:37 +05:30
compare = CompareService.new(project, after_sha)
.execute(project, before_sha)
2016-09-13 17:45:13 +05:30
diff_refs = compare.diff_refs
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?
2017-08-17 22:00:37 +05:30
compare = CompareService.new(project, before_sha)
.execute(project, after_sha)
2016-09-13 17:45:13 +05:30
diff_refs = compare.diff_refs
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
2021-06-08 01:23:25 +05:30
Integrations::EmailsOnPush.valid_recipients(recipients).each do |recipient|
2019-07-07 11:18:12 +05:30
send_email(
recipient,
project_id,
2022-08-27 11:52:29 +05:30
author_id: author_id,
ref: ref,
action: action,
compare: compare,
reverse_compare: reverse_compare,
diff_refs: diff_refs,
2019-07-07 11:18:12 +05:30
send_from_committer_email: send_from_committer_email,
2022-08-27 11:52:29 +05:30
disable_diffs: disable_diffs
2019-07-07 11:18:12 +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.full_name}' to #{recipient}: #{e}")
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)
2021-12-11 22:18:48 +05:30
@email ||= Notify.repository_push_email(project_id, options).tap do |mail|
Premailer::Rails::Hook.perform(mail)
end
current_email = email.dup
current_email.to = recipient
current_email.add_message_id
current_email.header[:skip_premailer] = true
current_email.deliver_now
2016-06-02 11:05:42 +05:30
end
2014-09-02 18:07:02 +05:30
end