2016-08-24 12:49:21 +05:30
|
|
|
def storage_name_valid?(name)
|
|
|
|
!!(name =~ /\A[a-zA-Z0-9\-_]+\z/)
|
|
|
|
end
|
|
|
|
|
|
|
|
def storage_validation_error(message)
|
|
|
|
raise "#{message}. Please fix this in your gitlab.yml before starting GitLab."
|
|
|
|
end
|
|
|
|
|
2017-08-17 22:00:37 +05:30
|
|
|
def validate_storages_config
|
2016-08-24 12:49:21 +05:30
|
|
|
storage_validation_error('No repository storage path defined') if Gitlab.config.repositories.storages.empty?
|
|
|
|
|
2017-08-17 22:00:37 +05:30
|
|
|
Gitlab.config.repositories.storages.each do |name, repository_storage|
|
2016-08-24 12:49:21 +05:30
|
|
|
storage_validation_error("\"#{name}\" is not a valid storage name") unless storage_name_valid?(name)
|
|
|
|
|
2017-09-10 17:25:29 +05:30
|
|
|
%w(failure_count_threshold failure_reset_time storage_timeout).each do |setting|
|
|
|
|
# Falling back to the defaults is fine!
|
|
|
|
next if repository_storage[setting].nil?
|
|
|
|
|
|
|
|
unless repository_storage[setting].to_f > 0
|
|
|
|
storage_validation_error("`#{setting}` for storage `#{name}` needs to be greater than 0")
|
|
|
|
end
|
|
|
|
end
|
2017-08-17 22:00:37 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
validate_storages_config
|