Commit 3383cf0a authored by Rémy Coutable's avatar Rémy Coutable

[EE] Reduce remaining diff with CE in app/services

Signed-off-by: default avatarRémy Coutable <remy@rymai.me>
parent 410789ad
...@@ -8,3 +8,5 @@ module MirrorHelper ...@@ -8,3 +8,5 @@ module MirrorHelper
} }
end end
end end
MirrorHelper.prepend(EE::MirrorHelper)
...@@ -2,18 +2,18 @@ ...@@ -2,18 +2,18 @@
module Applications module Applications
class CreateService class CreateService
prepend ::EE::Applications::CreateService # rubocop: disable Cop/InjectEnterpriseEditionModule attr_reader :current_user, :params
# rubocop: disable CodeReuse/ActiveRecord
def initialize(current_user, params) def initialize(current_user, params)
@current_user = current_user @current_user = current_user
@params = params.except(:ip_address) @params = params.except(:ip_address) # rubocop: disable CodeReuse/ActiveRecord
end end
# rubocop: enable CodeReuse/ActiveRecord
# EE would override and use `request` arg # EE would override and use `request` arg
def execute(request) def execute(request)
Doorkeeper::Application.create(@params) Doorkeeper::Application.create(params)
end end
end end
end end
Applications::CreateService.prepend(EE::Applications::CreateService)
...@@ -3,8 +3,6 @@ ...@@ -3,8 +3,6 @@
# Base class for services that count a single resource such as the number of # Base class for services that count a single resource such as the number of
# issues for a project. # issues for a project.
class BaseCountService class BaseCountService
prepend ::EE::BaseCountService # rubocop: disable Cop/InjectEnterpriseEditionModule
def relation_for_count def relation_for_count
raise( raise(
NotImplementedError, NotImplementedError,
...@@ -50,3 +48,5 @@ class BaseCountService ...@@ -50,3 +48,5 @@ class BaseCountService
Rails.cache.write(key, block_given? ? yield : uncached_count, raw: raw?) Rails.cache.write(key, block_given? ? yield : uncached_count, raw: raw?)
end end
end end
BaseCountService.prepend(EE::BaseCountService)
...@@ -3,8 +3,6 @@ ...@@ -3,8 +3,6 @@
module Boards module Boards
module Issues module Issues
class CreateService < Boards::BaseService class CreateService < Boards::BaseService
prepend ::EE::Boards::Issues::CreateService # rubocop: disable Cop/InjectEnterpriseEditionModule
attr_accessor :project attr_accessor :project
def initialize(parent, project, user, params = {}) def initialize(parent, project, user, params = {})
...@@ -37,3 +35,5 @@ module Boards ...@@ -37,3 +35,5 @@ module Boards
end end
end end
end end
Boards::Issues::CreateService.prepend(EE::Boards::Issues::CreateService)
...@@ -3,8 +3,6 @@ ...@@ -3,8 +3,6 @@
module Boards module Boards
module Lists module Lists
class ListService < Boards::BaseService class ListService < Boards::BaseService
prepend ::EE::Boards::Lists::ListService # rubocop: disable Cop/InjectEnterpriseEditionModule
def execute(board) def execute(board)
board.lists.create(list_type: :backlog) unless board.lists.backlog.exists? board.lists.create(list_type: :backlog) unless board.lists.backlog.exists?
...@@ -13,3 +11,5 @@ module Boards ...@@ -13,3 +11,5 @@ module Boards
end end
end end
end end
Boards::Lists::ListService.prepend(EE::Boards::Lists::ListService)
...@@ -2,10 +2,11 @@ ...@@ -2,10 +2,11 @@
module Emails module Emails
class BaseService class BaseService
attr_reader :current_user attr_reader :current_user, :params, :user
def initialize(current_user, params = {}) def initialize(current_user, params = {})
@current_user, @params = current_user, params.dup @current_user = current_user
@params = params.dup
@user = params.delete(:user) @user = params.delete(:user)
end end
end end
......
...@@ -2,15 +2,14 @@ ...@@ -2,15 +2,14 @@
module Emails module Emails
class CreateService < ::Emails::BaseService class CreateService < ::Emails::BaseService
prepend ::EE::Emails::CreateService # rubocop: disable Cop/InjectEnterpriseEditionModule
def execute(extra_params = {}) def execute(extra_params = {})
skip_confirmation = @params.delete(:skip_confirmation) skip_confirmation = params.delete(:skip_confirmation)
email = @user.emails.create(@params.merge(extra_params))
email&.confirm if skip_confirmation && current_user.admin? user.emails.create(params.merge(extra_params)).tap do |email|
email email&.confirm if skip_confirmation && current_user.admin?
end
end end
end end
end end
Emails::CreateService.prepend(EE::Emails::CreateService)
...@@ -2,8 +2,6 @@ ...@@ -2,8 +2,6 @@
module Emails module Emails
class DestroyService < ::Emails::BaseService class DestroyService < ::Emails::BaseService
prepend ::EE::Emails::DestroyService # rubocop: disable Cop/InjectEnterpriseEditionModule
def execute(email) def execute(email)
email.destroy && update_secondary_emails! email.destroy && update_secondary_emails!
end end
...@@ -19,3 +17,5 @@ module Emails ...@@ -19,3 +17,5 @@ module Emails
end end
end end
end end
Emails::DestroyService.prepend(EE::Emails::DestroyService)
...@@ -55,10 +55,6 @@ class GitPushService < BaseService ...@@ -55,10 +55,6 @@ class GitPushService < BaseService
update_gitattributes if default_branch? update_gitattributes if default_branch?
end end
if Gitlab::CurrentSettings.elasticsearch_indexing? && default_branch?
ElasticCommitIndexerWorker.perform_async(@project.id, params[:oldrev], params[:newrev])
end
execute_related_hooks execute_related_hooks
perform_housekeeping perform_housekeeping
...@@ -143,10 +139,8 @@ class GitPushService < BaseService ...@@ -143,10 +139,8 @@ class GitPushService < BaseService
UpdateMergeRequestsWorker UpdateMergeRequestsWorker
.perform_async(project.id, current_user.id, params[:oldrev], params[:newrev], params[:ref]) .perform_async(project.id, current_user.id, params[:oldrev], params[:newrev], params[:ref])
mirror_update = project.mirror? && project.repository.up_to_date_with_upstream?(branch_name)
EventCreateService.new.push(project, current_user, build_push_data) EventCreateService.new.push(project, current_user, build_push_data)
Ci::CreatePipelineService.new(project, current_user, build_push_data).execute(:push, mirror_update: mirror_update) Ci::CreatePipelineService.new(project, current_user, build_push_data).execute(:push, pipeline_options)
project.execute_hooks(build_push_data.dup, :push_hooks) project.execute_hooks(build_push_data.dup, :push_hooks)
project.execute_services(build_push_data.dup, :push_hooks) project.execute_services(build_push_data.dup, :push_hooks)
...@@ -237,4 +231,12 @@ class GitPushService < BaseService ...@@ -237,4 +231,12 @@ class GitPushService < BaseService
def last_pushed_commits def last_pushed_commits
@last_pushed_commits ||= @push_commits.last(PROCESS_COMMIT_LIMIT) @last_pushed_commits ||= @push_commits.last(PROCESS_COMMIT_LIMIT)
end end
private
def pipeline_options
{} # to be overriden in EE
end
end end
GitPushService.prepend(EE::GitPushService)
...@@ -10,7 +10,7 @@ class GitTagPushService < BaseService ...@@ -10,7 +10,7 @@ class GitTagPushService < BaseService
@push_data = build_push_data @push_data = build_push_data
EventCreateService.new.push(project, current_user, push_data) EventCreateService.new.push(project, current_user, push_data)
Ci::CreatePipelineService.new(project, current_user, push_data).execute(:push, mirror_update: params[:mirror_update]) Ci::CreatePipelineService.new(project, current_user, push_data).execute(:push, pipeline_options)
SystemHooksService.new.execute_hooks(build_system_push_data, :tag_push_hooks) SystemHooksService.new.execute_hooks(build_system_push_data, :tag_push_hooks)
project.execute_hooks(push_data.dup, :tag_push_hooks) project.execute_hooks(push_data.dup, :tag_push_hooks)
...@@ -59,4 +59,10 @@ class GitTagPushService < BaseService ...@@ -59,4 +59,10 @@ class GitTagPushService < BaseService
[], [],
'') '')
end end
def pipeline_options
{} # to be overriden in EE
end
end end
GitTagPushService.prepend(EE::GitTagPushService)
...@@ -2,8 +2,6 @@ ...@@ -2,8 +2,6 @@
module Groups module Groups
class DestroyService < Groups::BaseService class DestroyService < Groups::BaseService
prepend ::EE::Groups::DestroyService # rubocop: disable Cop/InjectEnterpriseEditionModule
DestroyError = Class.new(StandardError) DestroyError = Class.new(StandardError)
def async_execute def async_execute
...@@ -36,3 +34,5 @@ module Groups ...@@ -36,3 +34,5 @@ module Groups
# rubocop: enable CodeReuse/ActiveRecord # rubocop: enable CodeReuse/ActiveRecord
end end
end end
Groups::DestroyService.prepend(EE::Groups::DestroyService)
...@@ -51,8 +51,6 @@ module Issuable ...@@ -51,8 +51,6 @@ module Issuable
end end
def group def group
return new_entity.group if new_entity.respond_to?(:group) && new_entity.group
if new_entity.project&.group && current_user.can?(:read_group, new_entity.project.group) if new_entity.project&.group && current_user.can?(:read_group, new_entity.project.group)
new_entity.project.group new_entity.project.group
end end
...@@ -60,3 +58,11 @@ module Issuable ...@@ -60,3 +58,11 @@ module Issuable
end end
end end
end end
# In the case we are eager-loading, `ee/app/services/ee/issuable/clone/base_service.rb`
# is loaded first, and explicitely requires this file to avoid a
# "TypeError: superclass must be a Class (Module given)" error.
# That also means that we cannot perform the prepending in this file otherwise
# we'd get a circular dependency error, thus we perform the prepending in
# `ee/app/services/ee/issuable/clone/base_service.rb` in that case.
Issuable::Clone::BaseService.prepend(EE::Issuable::Clone::BaseService) unless Rails.configuration.eager_load
# frozen_string_literal: true # frozen_string_literal: true
class IssuableBaseService < BaseService class IssuableBaseService < BaseService
prepend ::EE::IssuableBaseService # rubocop: disable Cop/InjectEnterpriseEditionModule
private private
attr_accessor :params, :skip_milestone_email attr_accessor :params, :skip_milestone_email
...@@ -390,3 +388,5 @@ class IssuableBaseService < BaseService ...@@ -390,3 +388,5 @@ class IssuableBaseService < BaseService
project project
end end
end end
IssuableBaseService.prepend(EE::IssuableBaseService)
...@@ -3,7 +3,6 @@ ...@@ -3,7 +3,6 @@
module Issues module Issues
class BuildService < Issues::BaseService class BuildService < Issues::BaseService
include ResolveDiscussions include ResolveDiscussions
prepend ::EE::Issues::BuildService # rubocop: disable Cop/InjectEnterpriseEditionModule
def execute def execute
filter_resolve_discussion_params filter_resolve_discussion_params
...@@ -58,9 +57,11 @@ module Issues ...@@ -58,9 +57,11 @@ module Issues
end end
def issue_params def issue_params
@issue_params ||= issue_params_with_info_from_discussions.merge(whitelisted_issue_params) @issue_params ||= build_issue_params
end end
private
def whitelisted_issue_params def whitelisted_issue_params
if can?(current_user, :admin_issue, project) if can?(current_user, :admin_issue, project)
params.slice(:title, :description, :milestone_id) params.slice(:title, :description, :milestone_id)
...@@ -68,5 +69,11 @@ module Issues ...@@ -68,5 +69,11 @@ module Issues
params.slice(:title, :description) params.slice(:title, :description)
end end
end end
def build_issue_params
issue_params_with_info_from_discussions.merge(whitelisted_issue_params)
end
end end
end end
Issues::BuildService.prepend(EE::Issues::BuildService)
...@@ -2,8 +2,6 @@ ...@@ -2,8 +2,6 @@
module Issues module Issues
class MoveService < Issuable::Clone::BaseService class MoveService < Issuable::Clone::BaseService
prepend ::EE::Issues::MoveService # rubocop: disable Cop/InjectEnterpriseEditionModule
MoveError = Class.new(StandardError) MoveError = Class.new(StandardError)
def execute(issue, target_project) def execute(issue, target_project)
...@@ -66,3 +64,5 @@ module Issues ...@@ -66,3 +64,5 @@ module Issues
end end
end end
end end
Issues::MoveService.prepend(EE::Issues::MoveService)
...@@ -2,8 +2,6 @@ ...@@ -2,8 +2,6 @@
module MergeRequests module MergeRequests
class UpdateService < MergeRequests::BaseService class UpdateService < MergeRequests::BaseService
prepend ::EE::MergeRequests::UpdateService # rubocop: disable Cop/InjectEnterpriseEditionModule
def execute(merge_request) def execute(merge_request)
# We don't allow change of source/target projects and source branch # We don't allow change of source/target projects and source branch
# after merge request was created # after merge request was created
...@@ -136,3 +134,5 @@ module MergeRequests ...@@ -136,3 +134,5 @@ module MergeRequests
end end
end end
end end
MergeRequests::UpdateService.prepend(EE::MergeRequests::UpdateService)
...@@ -5,12 +5,16 @@ module Notes ...@@ -5,12 +5,16 @@ module Notes
UPDATE_SERVICES = { UPDATE_SERVICES = {
'Issue' => Issues::UpdateService, 'Issue' => Issues::UpdateService,
'MergeRequest' => MergeRequests::UpdateService, 'MergeRequest' => MergeRequests::UpdateService,
'Commit' => Commits::TagService, 'Commit' => Commits::TagService
'Epic' => Epics::UpdateService
}.freeze }.freeze
private_constant :UPDATE_SERVICES
def self.update_services
UPDATE_SERVICES
end
def self.noteable_update_service(note) def self.noteable_update_service(note)
UPDATE_SERVICES[note.noteable_type] update_services[note.noteable_type]
end end
def self.supported?(note) def self.supported?(note)
...@@ -36,3 +40,5 @@ module Notes ...@@ -36,3 +40,5 @@ module Notes
end end
end end
end end
Notes::QuickActionsService.prepend(EE::Notes::QuickActionsService)
...@@ -242,8 +242,6 @@ module NotificationRecipientService ...@@ -242,8 +242,6 @@ module NotificationRecipientService
end end
class Default < Base class Default < Base
prepend ::EE::NotificationRecipientBuilders::Default # rubocop: disable Cop/InjectEnterpriseEditionModule
MENTION_TYPE_ACTIONS = [:new_issue, :new_merge_request].freeze MENTION_TYPE_ACTIONS = [:new_issue, :new_merge_request].freeze
attr_reader :target attr_reader :target
...@@ -251,6 +249,7 @@ module NotificationRecipientService ...@@ -251,6 +249,7 @@ module NotificationRecipientService
attr_reader :action attr_reader :action
attr_reader :previous_assignee attr_reader :previous_assignee
attr_reader :skip_current_user attr_reader :skip_current_user
def initialize(target, current_user, action:, custom_action: nil, previous_assignee: nil, skip_current_user: true) def initialize(target, current_user, action:, custom_action: nil, previous_assignee: nil, skip_current_user: true)
@target = target @target = target
@current_user = current_user @current_user = current_user
...@@ -260,15 +259,13 @@ module NotificationRecipientService ...@@ -260,15 +259,13 @@ module NotificationRecipientService
@skip_current_user = skip_current_user @skip_current_user = skip_current_user
end end
def add_watchers
add_project_watchers
end
def build! def build!
add_participants(current_user) add_participants(current_user)
add_watchers
if project
add_project_watchers
else # for group level targets
add_group_watchers
end
add_custom_notifications add_custom_notifications
# Re-assign is considered as a mention of the new assignee # Re-assign is considered as a mention of the new assignee
...@@ -414,4 +411,5 @@ module NotificationRecipientService ...@@ -414,4 +411,5 @@ module NotificationRecipientService
end end
end end
NotificationRecipientService::Builder::Default.prepend(EE::NotificationRecipientBuilders::Default) # rubocop: disable Cop/InjectEnterpriseEditionModule
NotificationRecipientService.prepend(EE::NotificationRecipientService) NotificationRecipientService.prepend(EE::NotificationRecipientService)
...@@ -12,8 +12,6 @@ module Projects ...@@ -12,8 +12,6 @@ module Projects
# #
# Projects::AfterRenameService.new(project).execute # Projects::AfterRenameService.new(project).execute
class AfterRenameService class AfterRenameService
prepend ::EE::Projects::AfterRenameService # rubocop: disable Cop/InjectEnterpriseEditionModule
# @return [String] The Project being renamed. # @return [String] The Project being renamed.
attr_reader :project attr_reader :project
...@@ -141,3 +139,5 @@ module Projects ...@@ -141,3 +139,5 @@ module Projects
end end
end end
end end
Projects::AfterRenameService.prepend(EE::Projects::AfterRenameService)
...@@ -2,8 +2,6 @@ ...@@ -2,8 +2,6 @@
module Projects module Projects
class AutocompleteService < BaseService class AutocompleteService < BaseService
prepend EE::Projects::AutocompleteService # rubocop: disable Cop/InjectEnterpriseEditionModule
include LabelsAsHash include LabelsAsHash
def issues def issues
IssuesFinder.new(current_user, project_id: project.id, state: 'opened').execute.select([:iid, :title]) IssuesFinder.new(current_user, project_id: project.id, state: 'opened').execute.select([:iid, :title])
...@@ -40,3 +38,5 @@ module Projects ...@@ -40,3 +38,5 @@ module Projects
end end
end end
end end
Projects::AutocompleteService.prepend(EE::Projects::AutocompleteService)
...@@ -51,4 +51,4 @@ module Projects ...@@ -51,4 +51,4 @@ module Projects
end end
end end
::Projects::CleanupService.prepend(::EE::Projects::CleanupService) Projects::CleanupService.prepend(EE::Projects::CleanupService)
...@@ -2,7 +2,6 @@ ...@@ -2,7 +2,6 @@
module Projects module Projects
class CreateFromTemplateService < BaseService class CreateFromTemplateService < BaseService
prepend ::EE::Projects::CreateFromTemplateService # rubocop: disable Cop/InjectEnterpriseEditionModule
include Gitlab::Utils::StrongMemoize include Gitlab::Utils::StrongMemoize
def initialize(user, params) def initialize(user, params)
...@@ -27,3 +26,5 @@ module Projects ...@@ -27,3 +26,5 @@ module Projects
end end
end end
end end
Projects::CreateFromTemplateService.prepend(EE::Projects::CreateFromTemplateService)
...@@ -2,8 +2,6 @@ ...@@ -2,8 +2,6 @@
module Projects module Projects
class CreateService < BaseService class CreateService < BaseService
prepend ::EE::Projects::CreateService # rubocop: disable Cop/InjectEnterpriseEditionModule
def initialize(user, params) def initialize(user, params)
@current_user, @params = user, params.dup @current_user, @params = user, params.dup
@skip_wiki = @params.delete(:skip_wiki) @skip_wiki = @params.delete(:skip_wiki)
...@@ -198,3 +196,5 @@ module Projects ...@@ -198,3 +196,5 @@ module Projects
end end
end end
end end
Projects::CreateService.prepend(EE::Projects::CreateService)
...@@ -3,7 +3,6 @@ ...@@ -3,7 +3,6 @@
module Projects module Projects
class DestroyService < BaseService class DestroyService < BaseService
include Gitlab::ShellAdapter include Gitlab::ShellAdapter
prepend ::EE::Projects::DestroyService # rubocop: disable Cop/InjectEnterpriseEditionModule
DestroyError = Class.new(StandardError) DestroyError = Class.new(StandardError)
...@@ -219,3 +218,5 @@ module Projects ...@@ -219,3 +218,5 @@ module Projects
end end
end end
end end
Projects::DestroyService.prepend(EE::Projects::DestroyService)
...@@ -5,7 +5,6 @@ ...@@ -5,7 +5,6 @@
# The latter will under the hood just import an archive supplied by GitLab. # The latter will under the hood just import an archive supplied by GitLab.
module Projects module Projects
class GitlabProjectsImportService class GitlabProjectsImportService
prepend ::EE::Projects::GitlabProjectsImportService # rubocop: disable Cop/InjectEnterpriseEditionModule
include Gitlab::Utils::StrongMemoize include Gitlab::Utils::StrongMemoize
include Gitlab::TemplateHelper include Gitlab::TemplateHelper
...@@ -70,3 +69,5 @@ module Projects ...@@ -70,3 +69,5 @@ module Projects
end end
end end
end end
Projects::GitlabProjectsImportService.prepend(EE::Projects::GitlabProjectsImportService)
...@@ -3,8 +3,6 @@ ...@@ -3,8 +3,6 @@
module Projects module Projects
module GroupLinks module GroupLinks
class CreateService < BaseService class CreateService < BaseService
prepend ::EE::Projects::GroupLinks::CreateService # rubocop: disable Cop/InjectEnterpriseEditionModule
def execute(group) def execute(group)
return false unless group return false unless group
...@@ -17,3 +15,5 @@ module Projects ...@@ -17,3 +15,5 @@ module Projects
end end
end end
end end
Projects::GroupLinks::CreateService.prepend(EE::Projects::GroupLinks::CreateService)
...@@ -3,8 +3,6 @@ ...@@ -3,8 +3,6 @@
module Projects module Projects
module GroupLinks module GroupLinks
class DestroyService < BaseService class DestroyService < BaseService
prepend ::EE::Projects::GroupLinks::DestroyService # rubocop: disable Cop/InjectEnterpriseEditionModule
def execute(group_link) def execute(group_link)
return false unless group_link return false unless group_link
...@@ -13,3 +11,5 @@ module Projects ...@@ -13,3 +11,5 @@ module Projects
end end
end end
end end
Projects::GroupLinks::DestroyService.prepend(EE::Projects::GroupLinks::DestroyService)
...@@ -7,8 +7,6 @@ module Projects ...@@ -7,8 +7,6 @@ module Projects
class MigrateAttachmentsService < BaseService class MigrateAttachmentsService < BaseService
attr_reader :logger, :old_disk_path, :new_disk_path attr_reader :logger, :old_disk_path, :new_disk_path
prepend ::EE::Projects::HashedStorage::MigrateAttachmentsService # rubocop: disable Cop/InjectEnterpriseEditionModule
def initialize(project, old_disk_path, logger: nil) def initialize(project, old_disk_path, logger: nil)
@project = project @project = project
@logger = logger || Rails.logger @logger = logger || Rails.logger
...@@ -64,3 +62,5 @@ module Projects ...@@ -64,3 +62,5 @@ module Projects
end end
end end
end end
Projects::HashedStorage::MigrateAttachmentsService.prepend(EE::Projects::HashedStorage::MigrateAttachmentsService)
...@@ -3,8 +3,6 @@ ...@@ -3,8 +3,6 @@
module Projects module Projects
module HashedStorage module HashedStorage
class MigrateRepositoryService < BaseRepositoryService class MigrateRepositoryService < BaseRepositoryService
prepend ::EE::Projects::HashedStorage::MigrateRepositoryService # rubocop: disable Cop/InjectEnterpriseEditionModule
def execute def execute
try_to_set_repository_read_only! try_to_set_repository_read_only!
...@@ -52,3 +50,5 @@ module Projects ...@@ -52,3 +50,5 @@ module Projects
end end
end end
end end
Projects::HashedStorage::MigrateRepositoryService.prepend(EE::Projects::HashedStorage::MigrateRepositoryService)
...@@ -13,8 +13,6 @@ module Projects ...@@ -13,8 +13,6 @@ module Projects
include Gitlab::ShellAdapter include Gitlab::ShellAdapter
TransferError = Class.new(StandardError) TransferError = Class.new(StandardError)
prepend ::EE::Projects::TransferService # rubocop: disable Cop/InjectEnterpriseEditionModule
def execute(new_namespace) def execute(new_namespace)
@new_namespace = new_namespace @new_namespace = new_namespace
...@@ -172,3 +170,5 @@ module Projects ...@@ -172,3 +170,5 @@ module Projects
end end
end end
end end
Projects::TransferService.prepend(EE::Projects::TransferService)
...@@ -4,8 +4,6 @@ module Projects ...@@ -4,8 +4,6 @@ module Projects
class UpdateService < BaseService class UpdateService < BaseService
include UpdateVisibilityLevel include UpdateVisibilityLevel
prepend ::EE::Projects::UpdateService # rubocop: disable Cop/InjectEnterpriseEditionModule
ValidationError = Class.new(StandardError) ValidationError = Class.new(StandardError)
# rubocop: disable CodeReuse/ActiveRecord # rubocop: disable CodeReuse/ActiveRecord
...@@ -135,3 +133,5 @@ module Projects ...@@ -135,3 +133,5 @@ module Projects
end end
end end
end end
Projects::UpdateService.prepend(EE::Projects::UpdateService)
...@@ -3,18 +3,17 @@ ...@@ -3,18 +3,17 @@
module ProtectedBranches module ProtectedBranches
class ApiService < BaseService class ApiService < BaseService
def create def create
@push_params = AccessLevelParams.new(:push, params) ::ProtectedBranches::CreateService.new(@project, @current_user, protected_branch_params).execute
@merge_params = AccessLevelParams.new(:merge, params) end
@unprotect_params = AccessLevelParams.new(:unprotect, params)
protected_branch_params = { def protected_branch_params
{
name: params[:name], name: params[:name],
push_access_levels_attributes: @push_params.access_levels, push_access_levels_attributes: AccessLevelParams.new(:push, params).access_levels,
merge_access_levels_attributes: @merge_params.access_levels, merge_access_levels_attributes: AccessLevelParams.new(:merge, params).access_levels
unprotect_access_levels_attributes: @unprotect_params.access_levels
} }
::ProtectedBranches::CreateService.new(@project, @current_user, protected_branch_params).execute
end end
end end
end end
ProtectedBranches::ApiService.prepend(EE::ProtectedBranches::ApiService)
...@@ -6,30 +6,31 @@ ...@@ -6,30 +6,31 @@
# lives in this service. # lives in this service.
module ProtectedBranches module ProtectedBranches
class LegacyApiUpdateService < BaseService class LegacyApiUpdateService < BaseService
attr_reader :protected_branch, :developers_can_push, :developers_can_merge
def execute(protected_branch) def execute(protected_branch)
@protected_branch = protected_branch
@developers_can_push = params.delete(:developers_can_push) @developers_can_push = params.delete(:developers_can_push)
@developers_can_merge = params.delete(:developers_can_merge) @developers_can_merge = params.delete(:developers_can_merge)
@protected_branch = protected_branch
protected_branch.transaction do protected_branch.transaction do
delete_redundant_ee_access_levels delete_redundant_access_levels
case @developers_can_push case developers_can_push
when true when true
params[:push_access_levels_attributes] = [{ access_level: Gitlab::Access::DEVELOPER }] params[:push_access_levels_attributes] = [{ access_level: Gitlab::Access::DEVELOPER }]
when false when false
params[:push_access_levels_attributes] = [{ access_level: Gitlab::Access::MAINTAINER }] params[:push_access_levels_attributes] = [{ access_level: Gitlab::Access::MAINTAINER }]
end end
case @developers_can_merge case developers_can_merge
when true when true
params[:merge_access_levels_attributes] = [{ access_level: Gitlab::Access::DEVELOPER }] params[:merge_access_levels_attributes] = [{ access_level: Gitlab::Access::DEVELOPER }]
when false when false
params[:merge_access_levels_attributes] = [{ access_level: Gitlab::Access::MAINTAINER }] params[:merge_access_levels_attributes] = [{ access_level: Gitlab::Access::MAINTAINER }]
end end
service = ProtectedBranches::UpdateService.new(@project, @current_user, @params) service = ProtectedBranches::UpdateService.new(project, current_user, params)
service.execute(protected_branch) service.execute(protected_branch)
end end
end end
...@@ -37,34 +38,15 @@ module ProtectedBranches ...@@ -37,34 +38,15 @@ module ProtectedBranches
private private
def delete_redundant_access_levels def delete_redundant_access_levels
unless @developers_can_merge.nil? unless developers_can_merge.nil?
@protected_branch.merge_access_levels.destroy_all # rubocop: disable DestroyAll # rubocop: disable DestroyAll protected_branch.merge_access_levels.destroy_all # rubocop: disable DestroyAll
end
unless @developers_can_push.nil?
@protected_branch.push_access_levels.destroy_all # rubocop: disable DestroyAll # rubocop: disable DestroyAll
end end
end
# If a protected branch can have more than one access level (EE), only unless developers_can_push.nil?
# remove the relevant access levels. If we don't do this, we'll have a protected_branch.push_access_levels.destroy_all # rubocop: disable DestroyAll
# failed validation.
def delete_redundant_ee_access_levels
case @developers_can_merge
when true
@protected_branch.merge_access_levels.developer.destroy_all # rubocop: disable DestroyAll
when false
@protected_branch.merge_access_levels.developer.destroy_all # rubocop: disable DestroyAll
@protected_branch.merge_access_levels.maintainer.destroy_all # rubocop: disable DestroyAll
end
case @developers_can_push
when true
@protected_branch.push_access_levels.developer.destroy_all # rubocop: disable DestroyAll
when false
@protected_branch.push_access_levels.developer.destroy_all # rubocop: disable DestroyAll
@protected_branch.push_access_levels.maintainer.destroy_all # rubocop: disable DestroyAll
end end
end end
end end
end end
ProtectedBranches::LegacyApiUpdateService.prepend(EE::ProtectedBranches::LegacyApiUpdateService)
...@@ -4,6 +4,7 @@ module QuickActions ...@@ -4,6 +4,7 @@ module QuickActions
class InterpretService < BaseService class InterpretService < BaseService
include Gitlab::Utils::StrongMemoize include Gitlab::Utils::StrongMemoize
include Gitlab::QuickActions::Dsl include Gitlab::QuickActions::Dsl
attr_reader :issuable attr_reader :issuable
SHRUG = '¯\\_(ツ)_/¯'.freeze SHRUG = '¯\\_(ツ)_/¯'.freeze
......
...@@ -17,15 +17,7 @@ module Search ...@@ -17,15 +17,7 @@ module Search
@projects = super.inside_path(group.full_path) @projects = super.inside_path(group.full_path)
end end
# rubocop: disable CodeReuse/ActiveRecord
def elastic_projects
@elastic_projects ||= projects.pluck(:id)
end
# rubocop: enable CodeReuse/ActiveRecord
def elastic_global
false
end
end end
end end
Search::GroupService.prepend(EE::Search::GroupService)
...@@ -9,17 +9,10 @@ module Search ...@@ -9,17 +9,10 @@ module Search
end end
def execute def execute
if Gitlab::CurrentSettings.elasticsearch_search? Gitlab::ProjectSearchResults.new(current_user,
Gitlab::Elastic::ProjectSearchResults.new(current_user, project,
params[:search], params[:search],
project.id, params[:repository_ref])
params[:repository_ref])
else
Gitlab::ProjectSearchResults.new(current_user,
project,
params[:search],
params[:repository_ref])
end
end end
def scope def scope
...@@ -27,3 +20,5 @@ module Search ...@@ -27,3 +20,5 @@ module Search
end end
end end
end end
Search::ProjectService.prepend(EE::Search::ProjectService)
...@@ -130,7 +130,6 @@ class SystemHooksService ...@@ -130,7 +130,6 @@ class SystemHooksService
{ {
group_name: model.group.name, group_name: model.group.name,
group_path: model.group.path, group_path: model.group.path,
group_plan: model.group.plan&.name,
group_id: model.group.id, group_id: model.group.id,
user_username: model.user.username, user_username: model.user.username,
user_name: model.user.name, user_name: model.user.name,
......
...@@ -2,8 +2,6 @@ ...@@ -2,8 +2,6 @@
module Users module Users
class BuildService < BaseService class BuildService < BaseService
prepend ::EE::Users::BuildService # rubocop: disable Cop/InjectEnterpriseEditionModule
delegate :user_default_internal_regex_enabled?, delegate :user_default_internal_regex_enabled?,
:user_default_internal_regex_instance, :user_default_internal_regex_instance,
to: :'Gitlab::CurrentSettings.current_application_settings' to: :'Gitlab::CurrentSettings.current_application_settings'
...@@ -123,3 +121,5 @@ module Users ...@@ -123,3 +121,5 @@ module Users
end end
end end
end end
Users::BuildService.prepend(EE::Users::BuildService)
...@@ -2,8 +2,6 @@ ...@@ -2,8 +2,6 @@
module Users module Users
class DestroyService class DestroyService
prepend ::EE::Users::DestroyService # rubocop: disable Cop/InjectEnterpriseEditionModule
DestroyError = Class.new(StandardError) DestroyError = Class.new(StandardError)
attr_accessor :current_user attr_accessor :current_user
...@@ -66,3 +64,5 @@ module Users ...@@ -66,3 +64,5 @@ module Users
end end
end end
end end
Users::DestroyService.prepend(EE::Users::DestroyService)
...@@ -3,6 +3,7 @@ ...@@ -3,6 +3,7 @@
module Users module Users
class UpdateService < BaseService class UpdateService < BaseService
include NewUserNotifier include NewUserNotifier
def initialize(current_user, params = {}) def initialize(current_user, params = {})
@current_user = current_user @current_user = current_user
@user = params.delete(:user) @user = params.delete(:user)
......
# frozen_string_literal: true
module EE
module MirrorHelper
def render_mirror_failed_message(raw_message:)
mirror_last_update_at = @project.import_state.last_update_at
message = "The repository failed to update #{time_ago_with_tooltip(mirror_last_update_at)}.".html_safe
return message if raw_message
message.insert(0, "#{icon('warning triangle')} ")
if can?(current_user, :admin_project, @project)
link_to message, project_mirror_path(@project)
else
message
end
end
def branch_diverged_tooltip_message
message = [s_('Branches|The branch could not be updated automatically because it has diverged from its upstream counterpart.')]
if can?(current_user, :push_code, @project)
message << '<br>'
message << s_("Branches|To discard the local changes and overwrite the branch with the upstream version, delete it here and choose 'Update Now' above.")
end
message.join
end
def options_for_mirror_user
options_from_collection_for_select(default_mirror_users, :id, :name, @project.mirror_user_id || current_user.id)
end
def mirrored_repositories_count(project = @project)
count = project.mirror == true ? 1 : 0
count + @project.remote_mirrors.to_a.count { |mirror| mirror.enabled }
end
end
end
# frozen_string_literal: true
module MirrorHelper
def render_mirror_failed_message(raw_message:)
mirror_last_update_at = @project.import_state.last_update_at
message = "The repository failed to update #{time_ago_with_tooltip(mirror_last_update_at)}.".html_safe
return message if raw_message
message.insert(0, "#{icon('warning triangle')} ")
if can?(current_user, :admin_project, @project)
link_to message, project_mirror_path(@project)
else
message
end
end
def branch_diverged_tooltip_message
message = [s_('Branches|The branch could not be updated automatically because it has diverged from its upstream counterpart.')]
if can?(current_user, :push_code, @project)
message << '<br>'
message << s_("Branches|To discard the local changes and overwrite the branch with the upstream version, delete it here and choose 'Update Now' above.")
end
message.join
end
def options_for_mirror_user
options_from_collection_for_select(default_mirror_users, :id, :name, @project.mirror_user_id || current_user.id)
end
def mirrored_repositories_count(project = @project)
count = project.mirror == true ? 1 : 0
count + @project.remote_mirrors.to_a.count { |mirror| mirror.enabled }
end
def mirrors_form_data_attributes
{ project_mirror_ssh_endpoint: ssh_host_keys_project_mirror_path(@project, :json),
project_mirror_endpoint: project_mirror_path(@project) }
end
end
...@@ -2,8 +2,10 @@ ...@@ -2,8 +2,10 @@
module EE module EE
module Applications module Applications
# rubocop:disable Gitlab/ModuleWithInstanceVariables
module CreateService module CreateService
extend ::Gitlab::Utils::Override
override :execute
def execute(request) def execute(request)
super.tap do |application| super.tap do |application|
audit_event_service(request.remote_ip).for_user(application.name).security_event audit_event_service(request.remote_ip).for_user(application.name).security_event
...@@ -11,8 +13,8 @@ module EE ...@@ -11,8 +13,8 @@ module EE
end end
def audit_event_service(ip_address) def audit_event_service(ip_address)
::AuditEventService.new(@current_user, ::AuditEventService.new(current_user,
@current_user, current_user,
action: :custom, action: :custom,
custom_message: 'OAuth access granted', custom_message: 'OAuth access granted',
ip_address: ip_address) ip_address: ip_address)
......
...@@ -8,9 +8,9 @@ module EE ...@@ -8,9 +8,9 @@ module EE
# could be incorrect for 2 weeks. # could be incorrect for 2 weeks.
override :cache_options override :cache_options
def cache_options def cache_options
value = super super.tap do |options|
value[:expires_in] = 20.minutes if ::Gitlab::Geo.secondary? options[:expires_in] = 20.minutes if ::Gitlab::Geo.secondary?
value end
end end
end end
end end
...@@ -8,17 +8,18 @@ module EE ...@@ -8,17 +8,18 @@ module EE
override :issue_params override :issue_params
def issue_params def issue_params
assignee_ids = Array(list.user_id || board.assignee&.id) super.tap do |options|
milestone_id = list.milestone_id || board.milestone_id assignee_ids = Array(list.user_id || board.assignee&.id)
milestone_id = list.milestone_id || board.milestone_id
{ options[:label_ids].concat(board.label_ids)
label_ids: [list.label_id, *board.label_ids], options.merge!(
weight: board.weight, weight: board.weight,
milestone_id: milestone_id, milestone_id: milestone_id,
# This can be removed when boards have multiple assignee support. # This can be removed when boards have multiple assignee support.
# See https://gitlab.com/gitlab-org/gitlab-ee/issues/3786 # See https://gitlab.com/gitlab-org/gitlab-ee/issues/3786
assignee_ids: assignee_ids assignee_ids: assignee_ids)
} end
end end
end end
end end
......
...@@ -4,36 +4,32 @@ module EE ...@@ -4,36 +4,32 @@ module EE
module Boards module Boards
module Lists module Lists
module ListService module ListService
extend ::Gitlab::Utils::Override
# When adding a new licensed type, make sure to also add # When adding a new licensed type, make sure to also add
# it on license.rb with the pattern "board_<list_type>_lists" # it on license.rb with the pattern "board_<list_type>_lists"
LICENSED_LIST_TYPES = [:assignee, :milestone].freeze LICENSED_LIST_TYPES = %i[assignee milestone].freeze
extend ::Gitlab::Utils::Override
override :execute override :execute
# rubocop: disable CodeReuse/ActiveRecord
def execute(board) def execute(board)
not_available_lists = not_available_lists = list_type_features_availability(board)
list_type_features_availability(board).select { |_, available| !available } .select { |_, available| !available }
if not_available_lists.any? if not_available_lists.any?
super.where.not(list_type: not_available_lists.keys) super.where.not(list_type: not_available_lists.keys) # rubocop: disable CodeReuse/ActiveRecord
else else
super super
end end
end end
# rubocop: enable CodeReuse/ActiveRecord
private private
def list_type_features_availability(board) def list_type_features_availability(board)
parent = board.parent parent = board.parent
{}.tap do |hash| LICENSED_LIST_TYPES.each_with_object({}) do |list_type, hash|
LICENSED_LIST_TYPES.each do |list_type| list_type_key = ::List.list_types[list_type]
list_type_key = ::List.list_types[list_type] hash[list_type_key] = parent&.feature_available?(:"board_#{list_type}_lists")
hash[list_type_key] = parent&.feature_available?(:"board_#{list_type}_lists")
end
end end
end end
end end
......
...@@ -3,9 +3,11 @@ ...@@ -3,9 +3,11 @@
module EE module EE
module Emails module Emails
module CreateService module CreateService
extend ::Gitlab::Utils::Override
include ::EE::Emails::BaseService # rubocop: disable Cop/InjectEnterpriseEditionModule include ::EE::Emails::BaseService # rubocop: disable Cop/InjectEnterpriseEditionModule
def execute(*args, &blk) override :execute
def execute(extra_params = {})
super.tap do |email| super.tap do |email|
log_audit_event(action: :create) if email.persisted? log_audit_event(action: :create) if email.persisted?
end end
......
...@@ -3,9 +3,11 @@ ...@@ -3,9 +3,11 @@
module EE module EE
module Emails module Emails
module DestroyService module DestroyService
extend ::Gitlab::Utils::Override
include ::EE::Emails::BaseService # rubocop: disable Cop/InjectEnterpriseEditionModule include ::EE::Emails::BaseService # rubocop: disable Cop/InjectEnterpriseEditionModule
def execute(*args, &blk) override :execute
def execute(email)
super.tap do super.tap do
log_audit_event(action: :destroy) log_audit_event(action: :destroy)
end end
......
# frozen_string_literal: true
module EE
module GitPushService
extend ::Gitlab::Utils::Override
protected
override :execute_related_hooks
def execute_related_hooks
if ::Gitlab::CurrentSettings.elasticsearch_indexing? && default_branch?
::ElasticCommitIndexerWorker.perform_async(project.id, params[:oldrev], params[:newrev])
end
super
end
private
override :pipeline_options
def pipeline_options
{ mirror_update: project.mirror? && project.repository.up_to_date_with_upstream?(branch_name) }
end
end
end
# frozen_string_literal: true
module EE
module GitTagPushService
extend ::Gitlab::Utils::Override
private
override :pipeline_options
def pipeline_options
{ mirror_update: params[:mirror_update] }
end
end
end
# frozen_string_literal: true
# When this file is eager-loaded **before `issuable/clone/base_service.rb`**, the
# `Issuable::Clone::BaseService` constant is defined (in this file) as a module,
# making subsequent inheritance from `::Issuable::Clone::BaseService` (e.g. in
# `EE::IssuePromoteService`) failing with a "TypeError: superclass must be a
# Class (Module given)" error.
# Explicitely requiring `issuable/clone/base_service.rb` makes sure that the
# correct `::Issuable::Clone::BaseService` constant is defined first.
require_dependency 'issuable/clone/base_service' if Rails.configuration.eager_load
module EE
module Issuable
module Clone
module BaseService
extend ::Gitlab::Utils::Override
private
override :group
def group
if new_entity.respond_to?(:group) && new_entity.group
new_entity.group
else
super
end
end
end
end
end
end
# When this file is eager-loaded, since we explicitely require
# `issuable/clone/base_service.rb` above, we cannot perform the prepend in
# `issuable/clone/base_service.rb` otherwise we'd get a circular dependency
# error. Thus we perform the prepend in this file, after
# `Issuable::Clone::BaseService` and `EE::Issuable::Clone::BaseService` are defined.
Issuable::Clone::BaseService.prepend(EE::Issuable::Clone::BaseService) if Rails.configuration.eager_load
...@@ -2,10 +2,12 @@ ...@@ -2,10 +2,12 @@
module EE module EE
module IssuableBaseService module IssuableBaseService
extend ::Gitlab::Utils::Override
include ::Gitlab::Utils::StrongMemoize include ::Gitlab::Utils::StrongMemoize
private private
override :filter_params
def filter_params(issuable) def filter_params(issuable)
# This security check is repeated here to avoid multiple backports, # This security check is repeated here to avoid multiple backports,
# this should be refactored to be reused from the base class. # this should be refactored to be reused from the base class.
......
...@@ -3,6 +3,8 @@ ...@@ -3,6 +3,8 @@
module EE module EE
module Issues module Issues
module BuildService module BuildService
extend ::Gitlab::Utils::Override
def issue_params_from_template def issue_params_from_template
return {} unless project.feature_available?(:issuable_default_templates) return {} unless project.feature_available?(:issuable_default_templates)
...@@ -13,8 +15,9 @@ module EE ...@@ -13,8 +15,9 @@ module EE
# They take precedence over eachother like this # They take precedence over eachother like this
# passed params > discussion params > template params # passed params > discussion params > template params
# The template params are filled in here, and might be overwritten by super # The template params are filled in here, and might be overwritten by super
def issue_params override :build_issue_params
@issue_params ||= issue_params_from_template.merge(super) def build_issue_params
issue_params_from_template.merge(super)
end end
end end
end end
......
...@@ -3,6 +3,9 @@ ...@@ -3,6 +3,9 @@
module EE module EE
module Issues module Issues
module MoveService module MoveService
extend ::Gitlab::Utils::Override
override :update_old_entity
def update_old_entity def update_old_entity
rewrite_epic_issue rewrite_epic_issue
super super
......
...@@ -35,6 +35,8 @@ module EE ...@@ -35,6 +35,8 @@ module EE
merge_request merge_request
end end
private
override :create_branch_change_note override :create_branch_change_note
def create_branch_change_note(merge_request, branch_type, old_branch, new_branch) def create_branch_change_note(merge_request, branch_type, old_branch, new_branch)
super super
...@@ -42,8 +44,6 @@ module EE ...@@ -42,8 +44,6 @@ module EE
reset_approvals(merge_request) reset_approvals(merge_request)
end end
private
def reset_approvals(merge_request) def reset_approvals(merge_request)
target_project = merge_request.target_project target_project = merge_request.target_project
......
# frozen_string_literal: true
module EE
module Notes
module QuickActionsService
extend ActiveSupport::Concern
include ::Gitlab::Utils::StrongMemoize
prepended do
EE_UPDATE_SERVICES = const_get(:UPDATE_SERVICES).merge(
'Epic' => Epics::UpdateService
).freeze
EE::Notes::QuickActionsService.private_constant :EE_UPDATE_SERVICES
end
class_methods do
extend ::Gitlab::Utils::Override
override :update_services
def update_services
EE_UPDATE_SERVICES
end
end
end
end
end
...@@ -4,6 +4,7 @@ module EE ...@@ -4,6 +4,7 @@ module EE
module NotificationRecipientBuilders module NotificationRecipientBuilders
module Default module Default
extend ActiveSupport::Concern extend ActiveSupport::Concern
extend ::Gitlab::Utils::Override
class_methods do class_methods do
extend ::Gitlab::Utils::Override extend ::Gitlab::Utils::Override
...@@ -13,6 +14,15 @@ module EE ...@@ -13,6 +14,15 @@ module EE
super.append(:new_epic) super.append(:new_epic)
end end
end end
override :add_watchers
def add_watchers
if project
super
else # for group level targets
add_group_watchers
end
end
end end
end end
end end
...@@ -7,16 +7,14 @@ module EE ...@@ -7,16 +7,14 @@ module EE
override :execute override :execute
def execute def execute
succeeded = super super.tap do
# It's possible that some error occurred, but at the end of the day
# It's possible that some error occurred, but at the end of the day # if the project is destroyed from the database, we should log events
# if the project is destroyed from the database, we should log events # and clean up where we can.
# and clean up where we can. if project&.destroyed?
if project&.destroyed? mirror_cleanup(project)
mirror_cleanup(project) end
end end
succeeded
end end
override :log_destroy_event override :log_destroy_event
......
# frozen_string_literal: true
module EE
module ProtectedBranches
module ApiService
extend ::Gitlab::Utils::Override
override :protected_branch_params
def protected_branch_params
super.tap do |hash|
hash[:unprotect_access_levels_attributes] = ::ProtectedBranches::AccessLevelParams.new(:unprotect, params).access_levels
end
end
end
end
end
# frozen_string_literal: true
module EE
module ProtectedBranches
module LegacyApiUpdateService
extend ::Gitlab::Utils::Override
private
# If a protected branch can have more than one access level (EE), only
# remove the relevant access levels. If we don't do this, we'll have a
# failed validation.
override :delete_redundant_access_levels
def delete_redundant_access_levels
case developers_can_merge
when true
protected_branch.merge_access_levels.developer.destroy_all # rubocop: disable DestroyAll
when false
protected_branch.merge_access_levels.developer.destroy_all # rubocop: disable DestroyAll
protected_branch.merge_access_levels.maintainer.destroy_all # rubocop: disable DestroyAll
end
case developers_can_push
when true
protected_branch.push_access_levels.developer.destroy_all # rubocop: disable DestroyAll
when false
protected_branch.push_access_levels.developer.destroy_all # rubocop: disable DestroyAll
protected_branch.push_access_levels.maintainer.destroy_all # rubocop: disable DestroyAll
end
end
end
end
end
# frozen_string_literal: true
module EE
module Search
module GroupService
def elastic_projects
@elastic_projects ||= projects.pluck(:id) # rubocop:disable CodeReuse/ActiveRecord
end
def elastic_global
false
end
end
end
end
# frozen_string_literal: true
module EE
module Search
module ProjectService
extend ::Gitlab::Utils::Override
override :execute
def execute
if ::Gitlab::CurrentSettings.elasticsearch_search?
::Gitlab::Elastic::ProjectSearchResults.new(current_user,
params[:search],
project.id,
params[:repository_ref])
else
super
end
end
end
end
end
...@@ -2,14 +2,22 @@ ...@@ -2,14 +2,22 @@
module EE module EE
module SystemHooksService module SystemHooksService
# override extend ::Gitlab::Utils::Override
private private
override :group_member_data
def group_member_data(model)
super.tap do |data|
data[:group_plan] = model.group.plan&.name
end
end
override :user_data
def user_data(model) def user_data(model)
data = super super.tap do |data|
data.merge!(email_opted_in_data(model)) if ::Gitlab.com? data.merge!(email_opted_in_data(model)) if ::Gitlab.com?
data end
end end
def email_opted_in_data(model) def email_opted_in_data(model)
......
...@@ -16,6 +16,7 @@ module EE ...@@ -16,6 +16,7 @@ module EE
private private
override :signup_params
def signup_params def signup_params
super + email_opted_in_params super + email_opted_in_params
end end
......
...@@ -12,9 +12,8 @@ module EE ...@@ -12,9 +12,8 @@ module EE
end end
end end
# rubocop: disable CodeReuse/ActiveRecord
def mirror_cleanup(user) def mirror_cleanup(user)
user_mirrors = ::Project.where(mirror_user: user) user_mirrors = ::Project.where(mirror_user: user) # rubocop: disable CodeReuse/ActiveRecord
user_mirrors.find_each do |mirror| user_mirrors.find_each do |mirror|
new_mirror_user = first_mirror_owner(user, mirror) new_mirror_user = first_mirror_owner(user, mirror)
...@@ -23,7 +22,6 @@ module EE ...@@ -23,7 +22,6 @@ module EE
::NotificationService.new.project_mirror_user_changed(new_mirror_user, user.name, mirror) ::NotificationService.new.project_mirror_user_changed(new_mirror_user, user.name, mirror)
end end
end end
# rubocop: enable CodeReuse/ActiveRecord
private private
......
# frozen_string_literal: true # frozen_string_literal: true
module Epics module Epics
class IssuePromoteService < Issuable::Clone::BaseService class IssuePromoteService < ::Issuable::Clone::BaseService
PromoteError = Class.new(StandardError) PromoteError = Class.new(StandardError)
def execute(issue) def execute(issue)
......
...@@ -15,11 +15,13 @@ module EE ...@@ -15,11 +15,13 @@ module EE
downstream_bridge_project_not_found: 'downstream project could not be found', downstream_bridge_project_not_found: 'downstream project could not be found',
insufficient_bridge_permissions: 'no permissions to trigger downstream pipeline' insufficient_bridge_permissions: 'no permissions to trigger downstream pipeline'
).freeze ).freeze
EE::Gitlab::Ci::Status::Build::Failed.private_constant :EE_REASONS EE::Gitlab::Ci::Status::Build::Failed.private_constant :EE_REASONS
end end
class_methods do class_methods do
extend ::Gitlab::Utils::Override
override :reasons
def reasons def reasons
EE_REASONS EE_REASONS
end end
......
...@@ -10,6 +10,7 @@ namespace :dev do ...@@ -10,6 +10,7 @@ namespace :dev do
desc "GitLab | Eager load application" desc "GitLab | Eager load application"
task load: :environment do task load: :environment do
Rails.configuration.eager_load = true
Rails.application.eager_load! Rails.application.eager_load!
end end
end end
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment