BigW Consortium Gitlab

6_validations.rb 1.84 KB
Newer Older
1 2 3 4 5
def storage_name_valid?(name)
  !!(name =~ /\A[a-zA-Z0-9\-_]+\z/)
end

def find_parent_path(name, path)
6
  parent = Pathname.new(path).realpath.parent
7 8
  Gitlab.config.repositories.storages.detect do |n, rs|
    name != n && Pathname.new(rs['path']).realpath == parent
9 10 11
  end
end

12
def storage_validation_error(message)
13 14 15
  raise "#{message}. Please fix this in your gitlab.yml before starting GitLab."
end

16
def validate_storages_config
17
  storage_validation_error('No repository storage path defined') if Gitlab.config.repositories.storages.empty?
18

19
  Gitlab.config.repositories.storages.each do |name, repository_storage|
20
    storage_validation_error("\"#{name}\" is not a valid storage name") unless storage_name_valid?(name)
21

22
    if repository_storage.is_a?(String)
23
      raise "#{name} is not a valid storage, because it has no `path` key. " \
24
        "It may be configured as:\n\n#{name}:\n  path: #{repository_storage}\n\n" \
25 26
        "For source installations, update your config/gitlab.yml Refer to gitlab.yml.example for an updated example.\n\n" \
        "If you're using the Gitlab Development Kit, you can update your configuration running `gdk reconfigure`.\n"
27 28 29 30 31
    end

    if !repository_storage.is_a?(Hash) || repository_storage['path'].nil?
      storage_validation_error("#{name} is not a valid storage, because it has no `path` key. Refer to gitlab.yml.example for an updated example")
    end
32 33
  end
end
34

35 36
def validate_storages_paths
  Gitlab.config.repositories.storages.each do |name, repository_storage|
37
    parent_name, _parent_path = find_parent_path(name, repository_storage['path'])
38 39 40
    if parent_name
      storage_validation_error("#{name} is a nested path of #{parent_name}. Nested paths are not supported for repository storages")
    end
41 42
  end
end
43

44 45
validate_storages_config
validate_storages_paths unless Rails.env.test? || ENV['SKIP_STORAGE_VALIDATION'] == 'true'