100 lines
3.4 KiB
Ruby
100 lines
3.4 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
module Gitlab
|
|
module CurrentSettings
|
|
class << self
|
|
def signup_disabled?
|
|
!signup_enabled?
|
|
end
|
|
|
|
def signup_limited?
|
|
domain_allowlist.present? || email_restrictions_enabled? || require_admin_approval_after_user_signup? || user_default_external?
|
|
end
|
|
|
|
def current_application_settings
|
|
Gitlab::SafeRequestStore.fetch(:current_application_settings) { ensure_application_settings! }
|
|
end
|
|
|
|
def current_application_settings?
|
|
Gitlab::SafeRequestStore.exist?(:current_application_settings) || ::ApplicationSetting.current.present?
|
|
end
|
|
|
|
def expire_current_application_settings
|
|
::ApplicationSetting.expire
|
|
Gitlab::SafeRequestStore.delete(:current_application_settings)
|
|
end
|
|
|
|
def clear_in_memory_application_settings!
|
|
@in_memory_application_settings = nil
|
|
end
|
|
|
|
def method_missing(name, *args, **kwargs, &block)
|
|
current_application_settings.send(name, *args, **kwargs, &block) # rubocop:disable GitlabSecurity/PublicSend
|
|
end
|
|
|
|
def respond_to_missing?(name, include_private = false)
|
|
current_application_settings.respond_to?(name, include_private) || super
|
|
end
|
|
|
|
private
|
|
|
|
def ensure_application_settings!
|
|
cached_application_settings || uncached_application_settings
|
|
end
|
|
|
|
def cached_application_settings
|
|
return in_memory_application_settings if ENV['IN_MEMORY_APPLICATION_SETTINGS'] == 'true'
|
|
|
|
begin
|
|
::ApplicationSetting.cached
|
|
rescue StandardError
|
|
# In case Redis isn't running
|
|
# or the Redis UNIX socket file is not available
|
|
# or the DB is not running (we use migrations in the cache key)
|
|
end
|
|
end
|
|
|
|
def uncached_application_settings
|
|
return fake_application_settings if Gitlab::Runtime.rake? && !connect_to_db?
|
|
|
|
current_settings = ::ApplicationSetting.current
|
|
# If there are pending migrations, it's possible there are columns that
|
|
# need to be added to the application settings. To prevent Rake tasks
|
|
# and other callers from failing, use any loaded settings and return
|
|
# defaults for missing columns.
|
|
if Gitlab::Runtime.rake? && ::ApplicationSetting.connection.migration_context.needs_migration?
|
|
db_attributes = current_settings&.attributes || {}
|
|
fake_application_settings(db_attributes)
|
|
elsif current_settings.present?
|
|
current_settings
|
|
else
|
|
::ApplicationSetting.create_from_defaults
|
|
end
|
|
rescue ::ApplicationSetting::Recursion
|
|
in_memory_application_settings
|
|
end
|
|
|
|
def fake_application_settings(attributes = {})
|
|
Gitlab::FakeApplicationSettings.new(::ApplicationSetting.defaults.merge(attributes || {}))
|
|
end
|
|
|
|
def in_memory_application_settings
|
|
@in_memory_application_settings ||= ::ApplicationSetting.build_from_defaults
|
|
end
|
|
|
|
def connect_to_db?
|
|
# When the DBMS is not available, an exception (e.g. PG::ConnectionBad) is raised
|
|
active_db_connection = begin
|
|
::ApplicationSetting.connection.active?
|
|
rescue StandardError
|
|
false
|
|
end
|
|
|
|
active_db_connection &&
|
|
ApplicationSetting.database.cached_table_exists?
|
|
rescue ActiveRecord::NoDatabaseError
|
|
false
|
|
end
|
|
end
|
|
end
|
|
end
|