summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorAndreas Brandl <abrandl@gitlab.com>2019-04-05 14:28:34 +0000
committerAndreas Brandl <abrandl@gitlab.com>2019-04-05 14:28:34 +0000
commit0cf23a7f50d51d91066cafc3d55bb846f7af3489 (patch)
treeaea2704199d2b5c8b9e2767ae42288637322743b /lib
parent6d25cd06acaa2f0f2c1cb422b613997c67eafc35 (diff)
parent46b1b9c1d61c269588bd3cd4203420608ddd7f0b (diff)
downloadgitlab-ce-0cf23a7f50d51d91066cafc3d55bb846f7af3489.tar.gz
Merge branch 'revert-3962b00b' into 'master'
Revert "Merge branch 'if-57131-external_auth_to_ce' into 'master'" See merge request gitlab-org/gitlab-ce!27051
Diffstat (limited to 'lib')
-rw-r--r--lib/api/entities.rb3
-rw-r--r--lib/api/helpers/projects_helpers.rb5
-rw-r--r--lib/api/settings.rb4
-rw-r--r--lib/gitlab/external_authorization.rb40
-rw-r--r--lib/gitlab/external_authorization/access.rb55
-rw-r--r--lib/gitlab/external_authorization/cache.rb62
-rw-r--r--lib/gitlab/external_authorization/client.rb63
-rw-r--r--lib/gitlab/external_authorization/config.rb47
-rw-r--r--lib/gitlab/external_authorization/logger.rb21
-rw-r--r--lib/gitlab/external_authorization/response.rb38
10 files changed, 3 insertions, 335 deletions
diff --git a/lib/api/entities.rb b/lib/api/entities.rb
index 079ee7f5ccc..2dd3120d3fc 100644
--- a/lib/api/entities.rb
+++ b/lib/api/entities.rb
@@ -277,7 +277,6 @@ module API
expose :statistics, using: 'API::Entities::ProjectStatistics', if: -> (project, options) {
options[:statistics] && Ability.allowed?(options[:current_user], :read_statistics, project)
}
- expose :external_authorization_classification_label
# rubocop: disable CodeReuse/ActiveRecord
def self.preload_relation(projects_relation, options = {})
@@ -1117,8 +1116,6 @@ module API
expose(:default_snippet_visibility) { |setting, _options| Gitlab::VisibilityLevel.string_level(setting.default_snippet_visibility) }
expose(:default_group_visibility) { |setting, _options| Gitlab::VisibilityLevel.string_level(setting.default_group_visibility) }
- expose(*::ApplicationSettingsHelper.external_authorization_service_attributes)
-
# support legacy names, can be removed in v5
expose :password_authentication_enabled_for_web, as: :password_authentication_enabled
expose :password_authentication_enabled_for_web, as: :signin_enabled
diff --git a/lib/api/helpers/projects_helpers.rb b/lib/api/helpers/projects_helpers.rb
index aaf32dafca4..7b858dc2e72 100644
--- a/lib/api/helpers/projects_helpers.rb
+++ b/lib/api/helpers/projects_helpers.rb
@@ -29,13 +29,13 @@ module API
optional :printing_merge_request_link_enabled, type: Boolean, desc: 'Show link to create/view merge request when pushing from the command line'
optional :merge_method, type: String, values: %w(ff rebase_merge merge), desc: 'The merge method used when merging merge requests'
optional :initialize_with_readme, type: Boolean, desc: "Initialize a project with a README.md"
- optional :external_authorization_classification_label, type: String, desc: 'The classification label for the project'
end
if Gitlab.ee?
params :optional_project_params_ee do
optional :repository_storage, type: String, desc: 'Which storage shard the repository is on. Available only to admins'
optional :approvals_before_merge, type: Integer, desc: 'How many approvers should approve merge request by default'
+ optional :external_authorization_classification_label, type: String, desc: 'The classification label for the project'
optional :mirror, type: Boolean, desc: 'Enables pull mirroring in a project'
optional :mirror_trigger_builds, type: Boolean, desc: 'Pull mirroring triggers builds'
end
@@ -72,8 +72,7 @@ module API
:tag_list,
:visibility,
:wiki_enabled,
- :avatar,
- :external_authorization_classification_label
+ :avatar
]
end
end
diff --git a/lib/api/settings.rb b/lib/api/settings.rb
index 120c5f4ccfc..d742c6c97c1 100644
--- a/lib/api/settings.rb
+++ b/lib/api/settings.rb
@@ -167,9 +167,7 @@ module API
optional :usage_ping_enabled, type: Boolean, desc: 'Every week GitLab will report license usage back to GitLab, Inc.'
end
- optional_attributes = [*::ApplicationSettingsHelper.visible_attributes,
- *::ApplicationSettingsHelper.external_authorization_service_attributes,
- :performance_bar_allowed_group_id]
+ optional_attributes = ::ApplicationSettingsHelper.visible_attributes << :performance_bar_allowed_group_id
if Gitlab.ee?
optional_attributes += EE::ApplicationSettingsHelper.possible_licensed_attributes
diff --git a/lib/gitlab/external_authorization.rb b/lib/gitlab/external_authorization.rb
deleted file mode 100644
index 25f8b7b3628..00000000000
--- a/lib/gitlab/external_authorization.rb
+++ /dev/null
@@ -1,40 +0,0 @@
-# frozen_string_literal: true
-
-module Gitlab
- module ExternalAuthorization
- extend ExternalAuthorization::Config
-
- RequestFailed = Class.new(StandardError)
-
- def self.access_allowed?(user, label, project_path = nil)
- return true unless perform_check?
- return false unless user
-
- access_for_user_to_label(user, label, project_path).has_access?
- end
-
- def self.rejection_reason(user, label)
- return unless enabled?
- return unless user
-
- access_for_user_to_label(user, label, nil).reason
- end
-
- def self.access_for_user_to_label(user, label, project_path)
- if RequestStore.active?
- RequestStore.fetch("external_authorisation:user-#{user.id}:label-#{label}") do
- load_access(user, label, project_path)
- end
- else
- load_access(user, label, project_path)
- end
- end
-
- def self.load_access(user, label, project_path)
- access = ::Gitlab::ExternalAuthorization::Access.new(user, label).load!
- ::Gitlab::ExternalAuthorization::Logger.log_access(access, project_path)
-
- access
- end
- end
-end
diff --git a/lib/gitlab/external_authorization/access.rb b/lib/gitlab/external_authorization/access.rb
deleted file mode 100644
index e111c41fcc2..00000000000
--- a/lib/gitlab/external_authorization/access.rb
+++ /dev/null
@@ -1,55 +0,0 @@
-# frozen_string_literal: true
-
-module Gitlab
- module ExternalAuthorization
- class Access
- attr_reader :user,
- :reason,
- :loaded_at,
- :label,
- :load_type
-
- def initialize(user, label)
- @user, @label = user, label
- end
-
- def loaded?
- loaded_at && (loaded_at > ExternalAuthorization::Cache::VALIDITY_TIME.ago)
- end
-
- def has_access?
- @access
- end
-
- def load!
- load_from_cache
- load_from_service unless loaded?
- self
- end
-
- private
-
- def load_from_cache
- @load_type = :cache
- @access, @reason, @loaded_at = cache.load
- end
-
- def load_from_service
- @load_type = :request
- response = Client.new(@user, @label).request_access
- @access = response.successful?
- @reason = response.reason
- @loaded_at = Time.now
- cache.store(@access, @reason, @loaded_at) if response.valid?
- rescue ::Gitlab::ExternalAuthorization::RequestFailed => e
- @access = false
- @reason = e.message
- @loaded_at = Time.now
- end
-
- def cache
- @cache ||= ExternalAuthorization::Cache.new(@user, @label)
- end
- end
- end
-end
diff --git a/lib/gitlab/external_authorization/cache.rb b/lib/gitlab/external_authorization/cache.rb
deleted file mode 100644
index acdc028b4dc..00000000000
--- a/lib/gitlab/external_authorization/cache.rb
+++ /dev/null
@@ -1,62 +0,0 @@
-# frozen_string_literal: true
-
-module Gitlab
- module ExternalAuthorization
- class Cache
- VALIDITY_TIME = 6.hours
-
- def initialize(user, label)
- @user, @label = user, label
- end
-
- def load
- @access, @reason, @refreshed_at = ::Gitlab::Redis::Cache.with do |redis|
- redis.hmget(cache_key, :access, :reason, :refreshed_at)
- end
-
- [access, reason, refreshed_at]
- end
-
- def store(new_access, new_reason, new_refreshed_at)
- ::Gitlab::Redis::Cache.with do |redis|
- redis.pipelined do
- redis.mapped_hmset(
- cache_key,
- {
- access: new_access.to_s,
- reason: new_reason.to_s,
- refreshed_at: new_refreshed_at.to_s
- }
- )
-
- redis.expire(cache_key, VALIDITY_TIME)
- end
- end
- end
-
- private
-
- def access
- ::Gitlab::Utils.to_boolean(@access)
- end
-
- def reason
- # `nil` if the cached value was an empty string
- return unless @reason.present?
-
- @reason
- end
-
- def refreshed_at
- # Don't try to parse a time if there was no cache
- return unless @refreshed_at.present?
-
- Time.parse(@refreshed_at)
- end
-
- def cache_key
- "external_authorization:user-#{@user.id}:label-#{@label}"
- end
- end
- end
-end
diff --git a/lib/gitlab/external_authorization/client.rb b/lib/gitlab/external_authorization/client.rb
deleted file mode 100644
index 60aab2e7044..00000000000
--- a/lib/gitlab/external_authorization/client.rb
+++ /dev/null
@@ -1,63 +0,0 @@
-# frozen_string_literal: true
-
-Excon.defaults[:ssl_verify_peer] = false
-
-module Gitlab
- module ExternalAuthorization
- class Client
- include ExternalAuthorization::Config
-
- REQUEST_HEADERS = {
- 'Content-Type' => 'application/json',
- 'Accept' => 'application/json'
- }.freeze
-
- def initialize(user, label)
- @user, @label = user, label
- end
-
- def request_access
- response = Excon.post(
- service_url,
- post_params
- )
- ::Gitlab::ExternalAuthorization::Response.new(response)
- rescue Excon::Error => e
- raise ::Gitlab::ExternalAuthorization::RequestFailed.new(e)
- end
-
- private
-
- def post_params
- params = { headers: REQUEST_HEADERS,
- body: body.to_json,
- connect_timeout: timeout,
- read_timeout: timeout,
- write_timeout: timeout }
-
- if has_tls?
- params[:client_cert_data] = client_cert
- params[:client_key_data] = client_key
- params[:client_key_pass] = client_key_pass
- end
-
- params
- end
-
- def body
- @body ||= begin
- body = {
- user_identifier: @user.email,
- project_classification_label: @label
- }
-
- if @user.ldap_identity
- body[:user_ldap_dn] = @user.ldap_identity.extern_uid
- end
-
- body
- end
- end
- end
- end
-end
diff --git a/lib/gitlab/external_authorization/config.rb b/lib/gitlab/external_authorization/config.rb
deleted file mode 100644
index 8654a8c1e2e..00000000000
--- a/lib/gitlab/external_authorization/config.rb
+++ /dev/null
@@ -1,47 +0,0 @@
-# frozen_string_literal: true
-
-module Gitlab
- module ExternalAuthorization
- module Config
- extend self
-
- def timeout
- application_settings.external_authorization_service_timeout
- end
-
- def service_url
- application_settings.external_authorization_service_url
- end
-
- def enabled?
- application_settings.external_authorization_service_enabled
- end
-
- def perform_check?
- enabled? && service_url.present?
- end
-
- def client_cert
- application_settings.external_auth_client_cert
- end
-
- def client_key
- application_settings.external_auth_client_key
- end
-
- def client_key_pass
- application_settings.external_auth_client_key_pass
- end
-
- def has_tls?
- client_cert.present? && client_key.present?
- end
-
- private
-
- def application_settings
- ::Gitlab::CurrentSettings.current_application_settings
- end
- end
- end
-end
diff --git a/lib/gitlab/external_authorization/logger.rb b/lib/gitlab/external_authorization/logger.rb
deleted file mode 100644
index 61246cd870e..00000000000
--- a/lib/gitlab/external_authorization/logger.rb
+++ /dev/null
@@ -1,21 +0,0 @@
-# frozen_string_literal: true
-
-module Gitlab
- module ExternalAuthorization
- class Logger < ::Gitlab::Logger
- def self.log_access(access, project_path)
- status = access.has_access? ? "GRANTED" : "DENIED"
- message = ["#{status} #{access.user.email} access to '#{access.label}'"]
-
- message << "(#{project_path})" if project_path.present?
- message << "- #{access.load_type} #{access.loaded_at}" if access.load_type == :cache
-
- info(message.join(' '))
- end
-
- def self.file_name_noext
- 'external-policy-access-control'
- end
- end
- end
-end
diff --git a/lib/gitlab/external_authorization/response.rb b/lib/gitlab/external_authorization/response.rb
deleted file mode 100644
index 4f3fe5882db..00000000000
--- a/lib/gitlab/external_authorization/response.rb
+++ /dev/null
@@ -1,38 +0,0 @@
-# frozen_string_literal: true
-
-module Gitlab
- module ExternalAuthorization
- class Response
- include ::Gitlab::Utils::StrongMemoize
-
- def initialize(excon_response)
- @excon_response = excon_response
- end
-
- def valid?
- @excon_response && [200, 401, 403].include?(@excon_response.status)
- end
-
- def successful?
- valid? && @excon_response.status == 200
- end
-
- def reason
- parsed_response['reason'] if parsed_response
- end
-
- private
-
- def parsed_response
- strong_memoize(:parsed_response) { parse_response! }
- end
-
- def parse_response!
- JSON.parse(@excon_response.body)
- rescue JSON::JSONError
- # The JSON response is optional, so don't fail when it's missing
- nil
- end
- end
- end
-end