1_settings.rb 7.99 KB
Newer Older
1
class Settings < Settingslogic
2
  source ENV.fetch('GITLAB_CONFIG') { "#{Rails.root}/config/gitlab.yml" }
3
  namespace Rails.env
4 5

  class << self
6 7
    def gitlab_on_standard_port?
      gitlab.port.to_i == (gitlab.https ? 443 : 80)
8 9 10 11
    end

    private

12 13 14
    def build_gitlab_shell_ssh_path_prefix
      if gitlab_shell.ssh_port != 22
        "ssh://#{gitlab_shell.ssh_user}@#{gitlab_shell.ssh_host}:#{gitlab_shell.ssh_port}/"
15
      else
16
        "#{gitlab_shell.ssh_user}@#{gitlab_shell.ssh_host}:"
17 18 19 20
      end
    end

    def build_gitlab_url
21
      custom_port = gitlab_on_standard_port? ? nil : ":#{gitlab.port}"
22 23 24
      [ gitlab.protocol,
        "://",
        gitlab.host,
25 26
        custom_port,
        gitlab.relative_url_root
27 28
      ].join('')
    end
29

30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51
    # check that values in `current` (string or integer) is a contant in `modul`.
    def verify_constant_array(modul, current, default)
      values = default || []
      if !current.nil?
        values = []
        current.each do |constant|
          values.push(verify_constant(modul, constant, nil))
        end
        values.delete_if { |value| value.nil? }
      end
      values
    end

    # check that `current` (string or integer) is a contant in `modul`.
    def verify_constant(modul, current, default)
      constant = modul.constants.find{ |name| modul.const_get(name) == current }
      value = constant.nil? ? default : modul.const_get(constant)
      if current.is_a? String
        value = modul.const_get(current.upcase) rescue default
      end
      value
    end
52 53
  end
end
54 55 56 57


# Default settings
Settings['ldap'] ||= Settingslogic.new({})
58
Settings.ldap['enabled'] = false if Settings.ldap['enabled'].nil?
59

60 61 62 63
# backwards compatibility, we only have one host
if Settings.ldap['enabled'] || Rails.env.test?
  if Settings.ldap['host'].present?
    server = Settings.ldap.except('sync_time')
64 65 66 67
    server['provider_name'] = 'ldap'
    Settings.ldap['servers'] = {
      'ldap' => server
    }
68 69
  end

70
  Settings.ldap['servers'].each do |key, server|
71
    server['label'] ||= 'LDAP'
72 73
    server['allow_username_or_email_login'] = false if server['allow_username_or_email_login'].nil?
    server['active_directory'] = true if server['active_directory'].nil?
74
    server['provider_name'] ||= "ldap#{key}".downcase
75 76 77
    server['provider_class'] = OmniAuth::Utils.camelize(server['provider_name'])
  end
end
78 79

Settings['omniauth'] ||= Settingslogic.new({})
80
Settings.omniauth['enabled']      = false if Settings.omniauth['enabled'].nil?
81 82
Settings.omniauth['providers']  ||= []

83 84
Settings['issues_tracker']  ||= {}

85 86 87
#
# GitLab
#
88
Settings['gitlab'] ||= Settingslogic.new({})
89
Settings.gitlab['default_projects_limit'] ||= 10
90
Settings.gitlab['default_branch_protection'] ||= 2
91
Settings.gitlab['default_can_create_group'] = true if Settings.gitlab['default_can_create_group'].nil?
Izaak Alpert's avatar
Izaak Alpert committed
92
Settings.gitlab['default_theme'] = Gitlab::Theme::MARS if Settings.gitlab['default_theme'].nil?
93
Settings.gitlab['host']       ||= 'localhost'
94
Settings.gitlab['ssh_host']   ||= Settings.gitlab.host
95
Settings.gitlab['https']        = false if Settings.gitlab['https'].nil?
96
Settings.gitlab['port']       ||= Settings.gitlab.https ? 443 : 80
97
Settings.gitlab['relative_url_root'] ||= ENV['RAILS_RELATIVE_URL_ROOT'] || ''
98
Settings.gitlab['protocol']   ||= Settings.gitlab.https ? "https" : "http"
99
Settings.gitlab['email_enabled'] ||= true if Settings.gitlab['email_enabled'].nil?
100 101
Settings.gitlab['email_from'] ||= "gitlab@#{Settings.gitlab.host}"
Settings.gitlab['url']        ||= Settings.send(:build_gitlab_url)
102
Settings.gitlab['user']       ||= 'git'
103 104 105 106 107
Settings.gitlab['user_home']  ||= begin
  Etc.getpwnam(Settings.gitlab['user']).dir
rescue ArgumentError # no user configured
  '/home/' + Settings.gitlab['user']
end
108
Settings.gitlab['time_zone']  ||= nil
Dmitriy Zaporozhets's avatar
Dmitriy Zaporozhets committed
109
Settings.gitlab['signup_enabled'] ||= true if Settings.gitlab['signup_enabled'].nil?
110
Settings.gitlab['signin_enabled'] ||= true if Settings.gitlab['signin_enabled'].nil?
111
Settings.gitlab['restricted_visibility_levels'] = Settings.send(:verify_constant_array, Gitlab::VisibilityLevel, Settings.gitlab['restricted_visibility_levels'], [])
112
Settings.gitlab['username_changing_enabled'] = true if Settings.gitlab['username_changing_enabled'].nil?
113
Settings.gitlab['issue_closing_pattern'] = '((?:[Cc]los(?:e[sd]|ing)|[Ff]ix(?:e[sd]|ing)?) +(?:(?:issues? +)?#\d+(?:(?:, *| +and +)?))+)' if Settings.gitlab['issue_closing_pattern'].nil?
114
Settings.gitlab['default_projects_features'] ||= {}
115
Settings.gitlab['webhook_timeout'] ||= 10
116 117 118
Settings.gitlab.default_projects_features['issues']         = true if Settings.gitlab.default_projects_features['issues'].nil?
Settings.gitlab.default_projects_features['merge_requests'] = true if Settings.gitlab.default_projects_features['merge_requests'].nil?
Settings.gitlab.default_projects_features['wiki']           = true if Settings.gitlab.default_projects_features['wiki'].nil?
119
Settings.gitlab.default_projects_features['snippets']       = false if Settings.gitlab.default_projects_features['snippets'].nil?
120
Settings.gitlab.default_projects_features['visibility_level']    = Settings.send(:verify_constant, Gitlab::VisibilityLevel, Settings.gitlab.default_projects_features['visibility_level'], Gitlab::VisibilityLevel::PRIVATE)
121
Settings.gitlab['repository_downloads_path'] = File.absolute_path(Settings.gitlab['repository_downloads_path'] || 'tmp/repositories', Rails.root)
122

123 124 125
#
# Gravatar
#
126
Settings['gravatar'] ||= Settingslogic.new({})
127
Settings.gravatar['enabled']      = true if Settings.gravatar['enabled'].nil?
128 129
Settings.gravatar['plain_url']  ||= 'http://www.gravatar.com/avatar/%{hash}?s=%{size}&d=identicon'
Settings.gravatar['ssl_url']    ||= 'https://secure.gravatar.com/avatar/%{hash}?s=%{size}&d=identicon'
130

131 132 133 134
#
# GitLab Shell
#
Settings['gitlab_shell'] ||= Settingslogic.new({})
135
Settings.gitlab_shell['path']         ||= Settings.gitlab['user_home'] + '/gitlab-shell/'
136
Settings.gitlab_shell['hooks_path']   ||= Settings.gitlab['user_home'] + '/gitlab-shell/hooks/'
137 138
Settings.gitlab_shell['receive_pack']   = true if Settings.gitlab_shell['receive_pack'].nil?
Settings.gitlab_shell['upload_pack']    = true if Settings.gitlab_shell['upload_pack'].nil?
139
Settings.gitlab_shell['repos_path']   ||= Settings.gitlab['user_home'] + '/repositories/'
140
Settings.gitlab_shell['ssh_host']     ||= Settings.gitlab.ssh_host
141 142 143 144
Settings.gitlab_shell['ssh_port']     ||= 22
Settings.gitlab_shell['ssh_user']     ||= Settings.gitlab.user
Settings.gitlab_shell['owner_group']  ||= Settings.gitlab.user
Settings.gitlab_shell['ssh_path_prefix'] ||= Settings.send(:build_gitlab_shell_ssh_path_prefix)
145

146 147 148
#
# Backup
#
149
Settings['backup'] ||= Settingslogic.new({})
150 151
Settings.backup['keep_time']  ||= 0
Settings.backup['path']         = File.expand_path(Settings.backup['path'] || "tmp/backups/", Rails.root)
152 153 154 155 156
Settings.backup['upload'] ||= Settingslogic.new({'remote_directory' => nil, 'connection' => nil})
# Convert upload connection settings to use symbol keys, to make Fog happy
if Settings.backup['upload']['connection']
  Settings.backup['upload']['connection'] = Hash[Settings.backup['upload']['connection'].map { |k, v| [k.to_sym, v] }]
end
157

158 159 160
#
# Git
#
161
Settings['git'] ||= Settingslogic.new({})
162
Settings.git['max_size']  ||= 20971520 # 20.megabytes
163
Settings.git['bin_path']  ||= '/usr/bin/git'
164
Settings.git['timeout']   ||= 10
165

166
Settings['satellites'] ||= Settingslogic.new({})
Riyad Preukschas's avatar
Riyad Preukschas committed
167
Settings.satellites['path'] = File.expand_path(Settings.satellites['path'] || "tmp/repo_satellites/", Rails.root)
168
Settings.satellites['timeout'] ||= 30
169 170 171 172 173

#
# Extra customization
#
Settings['extra'] ||= Settingslogic.new({})
174

175 176 177 178 179
#
# Rack::Attack settings
#
Settings['rack_attack'] ||= Settingslogic.new({})
Settings.rack_attack['git_basic_auth'] ||= Settingslogic.new({})
180
Settings.rack_attack.git_basic_auth['ip_whitelist'] ||= %w{127.0.0.1}
181 182 183 184
Settings.rack_attack.git_basic_auth['maxretry'] ||= 10
Settings.rack_attack.git_basic_auth['findtime'] ||= 1.minute
Settings.rack_attack.git_basic_auth['bantime'] ||= 1.hour

185 186 187 188 189
#
# Testing settings
#
if Rails.env.test?
  Settings.gitlab['default_projects_limit']   = 42
190
  Settings.gitlab['default_can_create_group'] = true
191 192
  Settings.gitlab['default_can_create_team']  = false
end