Commit 8e3d2001 authored by Robert Speicher's avatar Robert Speicher

Merge branch 'move-model-prepends' into 'master'

Move EE prepend and include calls to the end of models

See merge request gitlab-org/gitlab-ee!8198
parents 1f26bb89 34836b9e
......@@ -6,8 +6,6 @@ class Appearance < ActiveRecord::Base
include ObjectStorage::BackgroundMove
include WithUploads
prepend EE::Appearance
cache_markdown_field :description
cache_markdown_field :new_project_guidelines
......@@ -31,3 +29,5 @@ class Appearance < ActiveRecord::Base
end
end
end
Appearance.prepend(EE::Appearance)
......@@ -7,8 +7,6 @@ class ApplicationSetting < ActiveRecord::Base
include IgnorableColumn
include ChronicDurationAttribute
prepend EE::ApplicationSetting
add_authentication_token_field :runners_registration_token
add_authentication_token_field :health_check_access_token
......@@ -489,3 +487,5 @@ class ApplicationSetting < ActiveRecord::Base
Gitlab::PerformanceBar.expire_allowed_user_ids_cache
end
end
ApplicationSetting.prepend(EE::ApplicationSetting)
# frozen_string_literal: true
class AuditEvent < ActiveRecord::Base
prepend EE::AuditEvent
serialize :details, Hash # rubocop:disable Cop/ActiveRecordSerialize
belongs_to :user, foreign_key: :author_id
......@@ -21,3 +19,5 @@ class AuditEvent < ActiveRecord::Base
self.user.name
end
end
AuditEvent.prepend(EE::AuditEvent)
......@@ -2,7 +2,6 @@
# Blob is a Rails-specific wrapper around Gitlab::Git::Blob, SnippetBlob and Ci::ArtifactBlob
class Blob < SimpleDelegator
prepend EE::Blob
include Presentable
include BlobLanguageFromGitAttributes
......@@ -250,3 +249,5 @@ class Blob < SimpleDelegator
classes.find { |viewer_class| viewer_class.can_render?(self, verify_binary: verify_binary) }
end
end
Blob.prepend(EE::Blob)
# frozen_string_literal: true
class Board < ActiveRecord::Base
prepend EE::Board
belongs_to :group
belongs_to :project
......@@ -35,3 +33,5 @@ class Board < ActiveRecord::Base
false
end
end
Board.prepend(EE::Board)
# frozen_string_literal: true
class BroadcastMessage < ActiveRecord::Base
prepend EE::BroadcastMessage
include CacheMarkdownField
include Sortable
......@@ -71,3 +70,5 @@ class BroadcastMessage < ActiveRecord::Base
Rails.cache.delete(CACHE_KEY)
end
end
BroadcastMessage.prepend(EE::BroadcastMessage)
......@@ -10,7 +10,6 @@ module Ci
include Importable
include Gitlab::Utils::StrongMemoize
include Deployable
prepend EE::Ci::Build
belongs_to :project, inverse_of: :builds
belongs_to :runner
......@@ -930,3 +929,5 @@ module Ci
end
end
end
Ci::Build.prepend(EE::Ci::Build)
......@@ -2,8 +2,6 @@
module Ci
class JobArtifact < ActiveRecord::Base
prepend EE::Ci::JobArtifact
include AfterCommitQueue
include ObjectStorage::BackgroundMove
extend Gitlab::Ci::Model
......@@ -192,3 +190,5 @@ module Ci
end
end
end
Ci::JobArtifact.prepend(EE::Ci::JobArtifact)
......@@ -8,8 +8,6 @@ module Ci
include RedisCacheable
include ChronicDurationAttribute
include FromUnion
prepend EE::Ci::Runner
enum access_level: {
not_protected: 0,
ref_protected: 1
......@@ -321,3 +319,5 @@ module Ci
end
end
end
Ci::Runner.prepend(EE::Ci::Runner)
......@@ -14,8 +14,6 @@ module Clusters
include ::Clusters::Concerns::ApplicationVersion
include ::Clusters::Concerns::ApplicationData
prepend EE::Clusters::Applications::Prometheus
default_value_for :version, VERSION
state_machine :status do
......@@ -79,3 +77,5 @@ module Clusters
end
end
end
Clusters::Applications::Prometheus.prepend(EE::Clusters::Applications::Prometheus)
......@@ -2,8 +2,6 @@
module Clusters
class Cluster < ActiveRecord::Base
prepend EE::Clusters::Cluster
include Presentable
include Gitlab::Utils::StrongMemoize
......@@ -174,3 +172,5 @@ module Clusters
end
end
end
Clusters::Cluster.prepend(EE::Clusters::Cluster)
......@@ -8,8 +8,6 @@ module Clusters
include EnumWithNil
include AfterCommitQueue
prepend EE::KubernetesService
RESERVED_NAMESPACES = %w(gitlab-managed-apps).freeze
self.table_name = 'cluster_platforms_kubernetes'
......@@ -240,3 +238,5 @@ module Clusters
end
end
end
Clusters::Platforms::Kubernetes.prepend(EE::KubernetesService)
......@@ -24,8 +24,6 @@ module Issuable
include CreatedAtFilterable
include UpdatedAtFilterable
prepend EE::Issuable
# This object is used to gather issuable meta data for displaying
# upvotes, downvotes, notes and closing merge requests count for issues and merge requests
# lists avoiding n+1 queries and improving performance.
......@@ -371,3 +369,8 @@ module Issuable
old_title != title
end
end
# We have to prepend into Issuable::ClassMethods, as otherwise the methods
# defined in EE::Issuable will available on Issuable, and not
# Issuable::ClassMethods (= what in turn is exposed to classes).
Issuable::ClassMethods.prepend(EE::Issuable)
......@@ -10,8 +10,6 @@
module Mentionable
extend ActiveSupport::Concern
prepend EE::Mentionable
class_methods do
# Indicate which attributes of the Mentionable to search for GFM references.
def attr_mentionable(attr, options = {})
......@@ -99,9 +97,9 @@ module Mentionable
# Allows heavy processing to be skipped
def matches_cross_reference_regex?
reference_pattern = if !project || project.default_issues_tracker?
ReferenceRegexes::DEFAULT_PATTERN
ReferenceRegexes.default_pattern
else
ReferenceRegexes::EXTERNAL_PATTERN
ReferenceRegexes.external_pattern
end
self.class.mentionable_attrs.any? do |attr, _|
......@@ -171,3 +169,5 @@ module Mentionable
{}
end
end
Mentionable.prepend(EE::Mentionable)
......@@ -2,7 +2,7 @@
module Mentionable
module ReferenceRegexes
prepend EE::Mentionable::ReferenceRegexes
extend Gitlab::Utils::StrongMemoize
def self.reference_pattern(link_patterns, issue_pattern)
Regexp.union(link_patterns,
......@@ -17,16 +17,22 @@ module Mentionable
]
end
DEFAULT_PATTERN = begin
issue_pattern = Issue.reference_pattern
link_patterns = Regexp.union([Issue, Commit, MergeRequest, Epic].map(&:link_reference_pattern).compact)
reference_pattern(link_patterns, issue_pattern)
def self.default_pattern
strong_memoize(:default_pattern) do
issue_pattern = Issue.reference_pattern
link_patterns = Regexp.union([Issue, Commit, MergeRequest, Epic].map(&:link_reference_pattern).compact)
reference_pattern(link_patterns, issue_pattern)
end
end
EXTERNAL_PATTERN = begin
issue_pattern = IssueTrackerService.reference_pattern
link_patterns = URI.regexp(%w(http https))
reference_pattern(link_patterns, issue_pattern)
def self.external_pattern
strong_memoize(:external_pattern) do
issue_pattern = IssueTrackerService.reference_pattern
link_patterns = URI.regexp(%w(http https))
reference_pattern(link_patterns, issue_pattern)
end
end
end
end
Mentionable::ReferenceRegexes.prepend(EE::Mentionable::ReferenceRegexes)
# frozen_string_literal: true
module Noteable
prepend EE::Noteable
# Names of all implementers of `Noteable` that support resolvable notes.
RESOLVABLE_TYPES = %w(MergeRequest).freeze
......@@ -104,3 +102,5 @@ module Noteable
)
end
end
Noteable.prepend(EE::Noteable)
......@@ -25,8 +25,6 @@
# users = issue.participants
module Participable
extend ActiveSupport::Concern
prepend EE::Participable
class_methods do
# Adds a list of participant attributes. Attributes can either be symbols or
# Procs.
......@@ -113,3 +111,5 @@ module Participable
end
end
end
Participable.prepend(EE::Participable)
......@@ -5,7 +5,7 @@ module PrometheusAdapter
included do
include ReactiveCaching
prepend EE::PrometheusAdapter
prepend EE::PrometheusAdapter # We can't prepend outside of this model due to the use of `included`, so this must stay here.
self.reactive_cache_key = ->(adapter) { [adapter.class.model_name.singular, adapter.id] }
self.reactive_cache_lease_timeout = 30.seconds
......
......@@ -67,3 +67,9 @@ module ProtectedRef
@ref_matcher ||= RefMatcher.new(self.name)
end
end
# Prepending a module into a concern doesn't work very well for class methods,
# since these are defined in a ClassMethods constant. As such, we prepend the
# module directly into ProtectedRef::ClassMethods, instead of prepending it into
# ProtectedRef.
ProtectedRef::ClassMethods.prepend(EE::ProtectedRef)
......@@ -2,9 +2,6 @@
module ProtectedRefAccess
extend ActiveSupport::Concern
include EE::ProtectedRefAccess::Scopes
prepend EE::ProtectedRefAccess
HUMAN_ACCESS_LEVELS = {
Gitlab::Access::MAINTAINER => "Maintainers".freeze,
Gitlab::Access::DEVELOPER => "Developers + Maintainers".freeze,
......@@ -53,3 +50,13 @@ module ProtectedRefAccess
project.team.max_member_access(user.id) >= access_level
end
end
ProtectedRefAccess.include(EE::ProtectedRefAccess::Scopes)
ProtectedRefAccess.prepend(EE::ProtectedRefAccess)
# When using `prepend` (or `include` for that matter), the `ClassMethods`
# constants are not merged. This means that `class_methods` in
# `EE::ProtectedRefAccess` would be ignored.
#
# To work around this, we prepend the `ClassMethods` constant manually.
ProtectedRefAccess::ClassMethods.prepend(EE::ProtectedRefAccess::ClassMethods)
......@@ -4,7 +4,7 @@
#
# A note of this type can be resolvable.
class DiscussionNote < Note
prepend EE::DiscussionNote
prepend EE::DiscussionNote # This prepend must stay here because the `validates` below depends on it.
# Names of all implementers of `Noteable` that support discussions.
def self.noteable_types
......
# frozen_string_literal: true
class Environment < ActiveRecord::Base
prepend EE::Environment
# Used to generate random suffixes for the slug
LETTERS = 'a'..'z'
NUMBERS = '0'..'9'
......@@ -250,3 +248,5 @@ class Environment < ActiveRecord::Base
(0..5).map { SUFFIX_CHARS.sample }.join
end
end
Environment.prepend(EE::Environment)
......@@ -3,8 +3,6 @@
# Placeholder class for model that is implemented in EE
# It reserves '&' as a reference prefix, but the table does not exists in CE
class Epic < ActiveRecord::Base
prepend EE::Epic
def self.link_reference_pattern
nil
end
......@@ -17,3 +15,5 @@ class Epic < ActiveRecord::Base
'&amp;'
end
end
Epic.prepend(EE::Epic)
......@@ -3,8 +3,6 @@
require 'carrierwave/orm/activerecord'
class Group < Namespace
prepend EE::Group
include Gitlab::ConfigHelper
include AfterCommitQueue
include AccessRequestable
......@@ -432,3 +430,5 @@ class Group < Namespace
errors.add(:visibility_level, "#{visibility} is not allowed since there are sub-groups with higher visibility.")
end
end
Group.prepend(EE::Group)
# frozen_string_literal: true
class Identity < ActiveRecord::Base
def self.uniqueness_scope
:provider
end
prepend EE::Identity
include Sortable
include CaseSensitivity
belongs_to :user
validates :provider, presence: true
validates :extern_uid, allow_blank: true, uniqueness: { scope: uniqueness_scope, case_sensitive: false }
validates :user_id, uniqueness: { scope: uniqueness_scope }
validates :extern_uid, allow_blank: true, uniqueness: { scope: UniquenessScopes.scopes, case_sensitive: false }
validates :user_id, uniqueness: { scope: UniquenessScopes.scopes }
before_save :ensure_normalized_extern_uid, if: :extern_uid_changed?
after_destroy :clear_user_synced_attributes, if: :user_synced_attributes_metadata_from_provider?
......@@ -52,3 +46,5 @@ class Identity < ActiveRecord::Base
user.user_synced_attributes_metadata&.destroy
end
end
Identity.prepend(EE::Identity)
# frozen_string_literal: true
class Identity < ActiveRecord::Base
# This module and method are defined in a separate file to allow EE to
# redefine the `scopes` method before it is used in the `Identity` model.
module UniquenessScopes
def self.scopes
[:provider]
end
end
end
Identity::UniquenessScopes.prepend(EE::Identity::UniquenessScopes)
# frozen_string_literal: true
class IssueAssignee < ActiveRecord::Base
prepend EE::IssueAssignee
belongs_to :issue
belongs_to :assignee, class_name: "User", foreign_key: :user_id
end
IssueAssignee.prepend(EE::IssueAssignee)
......@@ -7,7 +7,6 @@
#
# A note of this type is never resolvable.
class LegacyDiffNote < Note
prepend EE::LegacyDiffNote
include NoteOnDiff
serialize :st_diff # rubocop:disable Cop/ActiveRecordSerialize
......@@ -112,3 +111,5 @@ class LegacyDiffNote < Note
diffs.find { |d| d.new_path == self.diff.new_path }
end
end
LegacyDiffNote.prepend(EE::LegacyDiffNote)
# frozen_string_literal: true
class LfsObject < ActiveRecord::Base
prepend EE::LfsObject
include AfterCommitQueue
include ObjectStorage::BackgroundMove
......@@ -42,3 +41,5 @@ class LfsObject < ActiveRecord::Base
Digest::SHA256.file(path).hexdigest
end
end
LfsObject.prepend(EE::LfsObject)
# frozen_string_literal: true
class Namespace < ActiveRecord::Base
prepend EE::Namespace
include CacheMarkdownField
include Sortable
include Gitlab::ShellAdapter
......@@ -311,3 +310,5 @@ class Namespace < ActiveRecord::Base
end
end
end
Namespace.prepend(EE::Namespace)
......@@ -5,8 +5,6 @@
# A note of this type is never resolvable.
class Note < ActiveRecord::Base
extend ActiveModel::Naming
prepend EE::Note
include Participable
include Mentionable
include Awardable
......@@ -491,3 +489,5 @@ class Note < ActiveRecord::Base
system_note_metadata&.cross_reference_types&.include?(system_note_metadata&.action)
end
end
Note.prepend(EE::Note)
# frozen_string_literal: true
class NotificationSetting < ActiveRecord::Base
prepend EE::NotificationSetting
include IgnorableColumn
ignore_column :events
......@@ -88,3 +87,5 @@ class NotificationSetting < ActiveRecord::Base
respond_to?(event) && !!public_send(event) # rubocop:disable GitlabSecurity/PublicSend
end
end
NotificationSetting.prepend(EE::NotificationSetting)
# frozen_string_literal: true
class PersonalSnippet < Snippet
prepend EE::PersonalSnippet
include WithUploads
end
PersonalSnippet.prepend(EE::PersonalSnippet)
......@@ -33,8 +33,6 @@ class Project < ActiveRecord::Base
extend Gitlab::Cache::RequestCache
# EE specific modules
prepend EE::Project
extend Gitlab::ConfigHelper
BoardLimitExceeded = Class.new(StandardError)
......@@ -2212,3 +2210,5 @@ class Project < ActiveRecord::Base
@services_templates ||= Service.where(template: true)
end
end
Project.prepend(EE::Project)
......@@ -5,8 +5,6 @@ class ProjectImportState < ActiveRecord::Base
self.table_name = "project_mirror_data"
prepend EE::ProjectImportState
belongs_to :project, inverse_of: :import_state
validates :project, presence: true
......@@ -72,3 +70,5 @@ class ProjectImportState < ActiveRecord::Base
@errors = original_errors
end
end
ProjectImportState.prepend(EE::ProjectImportState)
......@@ -9,7 +9,7 @@ class IssueTrackerService < Service
# Override this method on services that uses different patterns
# This pattern does not support cross-project references
# The other code assumes that this pattern is a superset of all
# overridden patterns. See ReferenceRegexes::EXTERNAL_PATTERN
# overridden patterns. See ReferenceRegexes.external_pattern
def self.reference_pattern(only_long: false)
if only_long
/(\b[A-Z][A-Z0-9_]*-)(?<issue>\d+)/
......
......@@ -9,8 +9,6 @@ class KubernetesService < DeploymentService
include Gitlab::Kubernetes
include ReactiveCaching
prepend EE::KubernetesService
self.reactive_cache_key = ->(service) { [service.class.model_name.singular, service.project_id] }
# Namespace defaults to the project path, but can be overridden in case that
......@@ -254,3 +252,5 @@ class KubernetesService < DeploymentService
end
end
end
KubernetesService.prepend(EE::KubernetesService)
# frozen_string_literal: true
class SlackSlashCommandsService < SlashCommandsService
prepend EE::SlackSlashCommandsService
include TriggersHelper
def title
......@@ -29,3 +28,5 @@ class SlackSlashCommandsService < SlashCommandsService
Slack::Notifier::LinkFormatter.format(text) if text
end
end
SlackSlashCommandsService.prepend(EE::SlackSlashCommandsService)
# frozen_string_literal: true
class ProjectSnippet < Snippet
prepend EE::ProjectSnippet
belongs_to :project
belongs_to :author, class_name: "User"
......@@ -14,3 +12,5 @@ class ProjectSnippet < Snippet
participant :author
participant :notes_with_associations
end
ProjectSnippet.prepend(EE::ProjectSnippet)
......@@ -3,8 +3,6 @@
class ProjectTeam
include BulkMemberAccessLoad
prepend EE::ProjectTeam
attr_accessor :project
def initialize(project)
......@@ -194,3 +192,5 @@ class ProjectTeam
project.group
end
end
ProjectTeam.prepend(EE::ProjectTeam)
# frozen_string_literal: true
class PrometheusMetric < ActiveRecord::Base
prepend EE::PrometheusMetric
belongs_to :project, validate: true, inverse_of: :prometheus_metrics
enum group: {
......@@ -89,3 +87,5 @@ class PrometheusMetric < ActiveRecord::Base
end
end
end
PrometheusMetric.prepend(EE::PrometheusMetric)
......@@ -3,9 +3,6 @@
class ProtectedBranch < ActiveRecord::Base
include Gitlab::ShellAdapter
include ProtectedRef
prepend EE::ProtectedRef
prepend EE::ProtectedBranch
protected_ref_access_levels :merge, :push
def self.protected_ref_accessible_to?(ref, user, project:, action:, protected_refs: nil)
......@@ -31,3 +28,5 @@ class ProtectedBranch < ActiveRecord::Base
Gitlab::CurrentSettings.default_branch_protection == Gitlab::Access::PROTECTION_DEV_CAN_MERGE
end
end
ProtectedBranch.prepend(EE::ProtectedBranch)
......@@ -3,8 +3,6 @@
class ProtectedTag < ActiveRecord::Base
include Gitlab::ShellAdapter
include ProtectedRef
include EE::ProtectedRef
validates :name, uniqueness: { scope: :project_id }
protected_ref_access_levels :create
......
......@@ -3,8 +3,6 @@
class RemoteMirror < ActiveRecord::Base
include AfterCommitQueue
prepend EE::RemoteMirror
PROTECTED_BACKOFF_DELAY = 1.minute
UNPROTECTED_BACKOFF_DELAY = 5.minutes
......@@ -229,3 +227,5 @@ class RemoteMirror < ActiveRecord::Base
url_changed? || encrypted_credentials_changed?
end
end
RemoteMirror.prepend(EE::RemoteMirror)
......@@ -22,7 +22,6 @@ class Repository
include Gitlab::ShellAdapter
include Gitlab::RepositoryCacheAdapter
prepend EE::Repository
include Elastic::RepositoriesSearch
attr_accessor :full_path, :disk_path, :project, :is_wiki
......@@ -1088,3 +1087,5 @@ class Repository
Gitlab::Git::Repository.new(project.repository_storage, disk_path + '.git', Gitlab::GlRepository.gl_repository(project, is_wiki))
end
end
Repository.prepend(EE::Repository)
......@@ -3,7 +3,6 @@
# This model is not used yet, it will be used for:
# https://gitlab.com/gitlab-org/gitlab-ce/issues/48483
class ResourceLabelEvent < ActiveRecord::Base
prepend EE::ResourceLabelEvent
include Importable
include Gitlab::Utils::StrongMemoize
include CacheMarkdownField
......@@ -123,3 +122,5 @@ class ResourceLabelEvent < ActiveRecord::Base
issuable.project || issuable.group
end
end
ResourceLabelEvent.prepend(EE::ResourceLabelEvent)
......@@ -3,7 +3,6 @@
# To add new service you should build a class inherited from Service
# and implement a set of methods
class Service < ActiveRecord::Base
prepend EE::Service
include Sortable
include Importable
include ProjectServicesLoggable
......@@ -350,3 +349,5 @@ class Service < ActiveRecord::Base
activated? && !importing?
end
end
Service.prepend(EE::Service)
# frozen_string_literal: true
class SystemNoteMetadata < ActiveRecord::Base
prepend EE::SystemNoteMetadata
# These notes's action text might contain a reference that is external.
# We should always force a deep validation upon references that are found
# in this note type.
......@@ -34,3 +32,5 @@ class SystemNoteMetadata < ActiveRecord::Base
TYPES_WITH_CROSS_REFERENCES
end
end
SystemNoteMetadata.prepend(EE::SystemNoteMetadata)
# frozen_string_literal: true
class Todo < ActiveRecord::Base
prepend EE::Todo
include Sortable
include FromUnion
......@@ -192,3 +191,5 @@ class Todo < ActiveRecord::Base
project.repository.keep_around(self.commit_id)
end
end
Todo.prepend(EE::Todo)
# frozen_string_literal: true
class Upload < ActiveRecord::Base
prepend EE::Upload
# Upper limit for foreground checksum processing
CHECKSUM_THRESHOLD = 100.megabytes
......@@ -108,3 +106,5 @@ class Upload < ActiveRecord::Base
super&.to_sym
end
end
Upload.prepend(EE::Upload)
......@@ -4,17 +4,15 @@ module EE
module Issuable
extend ActiveSupport::Concern
class_methods do
def labels_hash
issue_labels = Hash.new { |h, k| h[k] = [] }
def labels_hash
issue_labels = Hash.new { |h, k| h[k] = [] }
relation = unscoped.where(id: self.select(:id)).eager_load(:labels)
relation.pluck(:id, 'labels.title').each do |issue_id, label|
issue_labels[issue_id] << label
end
issue_labels
relation = unscoped.where(id: self.select(:id)).eager_load(:labels)
relation.pluck(:id, 'labels.title').each do |issue_id, label|
issue_labels[issue_id] << label
end
issue_labels
end
end
end
module EE
module ProtectedRef
extend ActiveSupport::Concern
def protected_ref_access_levels(*types)
types.each do |type|
# We need to set `inverse_of` to make sure the `belongs_to`-object is set
# when creating children using `accepts_nested_attributes_for`.
#
# If we don't `protected_branch` or `protected_tag` would be empty and
# `project` cannot be delegated to it, which in turn would cause validations
# to fail.
has_many :"#{type}_access_levels", inverse_of: self.model_name.singular
class_methods do
def protected_ref_access_levels(*types)
types.each do |type|
# We need to set `inverse_of` to make sure the `belongs_to`-object is set
# when creating children using `accepts_nested_attributes_for`.
#
# If we don't `protected_branch` or `protected_tag` would be empty and
# `project` cannot be delegated to it, which in turn would cause validations
# to fail.
has_many :"#{type}_access_levels", inverse_of: self.model_name.singular
accepts_nested_attributes_for :"#{type}_access_levels", allow_destroy: true
accepts_nested_attributes_for :"#{type}_access_levels", allow_destroy: true
# Overwrite the validation for access levels
#
# EE Needs to allow more access levels in the relation:
# - 1 for each user/group
# - 1 with the `access_level` (Maintainer, Developer)
validates :"#{type}_access_levels", length: { is: 1 }, if: -> { false }
# Overwrite the validation for access levels
#
# EE Needs to allow more access levels in the relation:
# - 1 for each user/group
# - 1 with the `access_level` (Maintainer, Developer)
validates :"#{type}_access_levels", length: { is: 1 }, if: -> { false }
# Returns access levels that grant the specified access type to the given user / group.
access_level_class = const_get("#{type}_access_level".classify)
protected_type = self.model_name.singular
scope(
:"#{type}_access_by_user",
-> (user) do
access_level_class.joins(protected_type.to_sym)
.where("#{protected_type}_id" => self.ids)
.merge(access_level_class.by_user(user))
end
)
scope(
:"#{type}_access_by_group",
-> (group) do
access_level_class.joins(protected_type.to_sym)
.where("#{protected_type}_id" => self.ids)
.merge(access_level_class.by_group(group))
end
)
end
# Returns access levels that grant the specified access type to the given user / group.
access_level_class = const_get("#{type}_access_level".classify)
protected_type = self.model_name.singular
scope(
:"#{type}_access_by_user",
-> (user) do
access_level_class.joins(protected_type.to_sym)
.where("#{protected_type}_id" => self.ids)
.merge(access_level_class.by_user(user))
end
)
scope(
:"#{type}_access_by_group",
-> (group) do
access_level_class.joins(protected_type.to_sym)
.where("#{protected_type}_id" => self.ids)
.merge(access_level_class.by_group(group))
end
)
end
end
end
......
......@@ -5,17 +5,16 @@ module EE
prepended do
belongs_to :saml_provider
validates :secondary_extern_uid, allow_blank: true, uniqueness: { scope: uniqueness_scope, case_sensitive: false }
validates :secondary_extern_uid,
allow_blank: true,
uniqueness: {
scope: ::Identity::UniquenessScopes.scopes,
case_sensitive: false
}
scope :with_secondary_extern_uid, ->(provider, secondary_extern_uid) do
iwhere(secondary_extern_uid: normalize_uid(provider, secondary_extern_uid)).with_provider(provider)
end
end
class_methods do
def uniqueness_scope
[*super, :saml_provider_id]
end
end
end
end
# frozen_string_literal: true
module EE
module Identity
module UniquenessScopes
extend ActiveSupport::Concern
class_methods do
def scopes
[*super, :saml_provider_id]
end
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