2019-12-04 20:38:33 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
# Concern handling functionality around deciding whether to send notification
|
|
|
|
# for activities on a specified branch or not. Will be included in
|
2021-09-04 01:27:46 +05:30
|
|
|
# Integrations::BaseChatNotification and PipelinesEmailService classes.
|
2019-12-04 20:38:33 +05:30
|
|
|
module NotificationBranchSelection
|
|
|
|
extend ActiveSupport::Concern
|
|
|
|
|
2022-08-13 15:12:31 +05:30
|
|
|
class_methods do
|
|
|
|
def branch_choices
|
|
|
|
[
|
|
|
|
[_('All branches'), 'all'].freeze,
|
|
|
|
[_('Default branch'), 'default'].freeze,
|
|
|
|
[_('Protected branches'), 'protected'].freeze,
|
|
|
|
[_('Default branch and protected branches'), 'default_and_protected'].freeze
|
|
|
|
].freeze
|
|
|
|
end
|
2020-04-22 19:07:51 +05:30
|
|
|
end
|
2019-12-04 20:38:33 +05:30
|
|
|
|
|
|
|
def notify_for_branch?(data)
|
|
|
|
ref = if data[:ref]
|
|
|
|
Gitlab::Git.ref_name(data[:ref])
|
|
|
|
else
|
|
|
|
data.dig(:object_attributes, :ref)
|
|
|
|
end
|
|
|
|
|
|
|
|
is_default_branch = ref == project.default_branch
|
2019-12-21 20:55:43 +05:30
|
|
|
is_protected_branch = ProtectedBranch.protected?(project, ref)
|
2019-12-04 20:38:33 +05:30
|
|
|
|
|
|
|
case branches_to_be_notified
|
|
|
|
when "all"
|
|
|
|
true
|
|
|
|
when "default"
|
|
|
|
is_default_branch
|
|
|
|
when "protected"
|
|
|
|
is_protected_branch
|
|
|
|
when "default_and_protected"
|
|
|
|
is_default_branch || is_protected_branch
|
|
|
|
else
|
|
|
|
false
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|