1_settings.rb 24.7 KB
Newer Older
Kamil Trzciński's avatar
Kamil Trzciński committed
1
require_relative '../settings'
2 3 4

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

7 8 9
# backwards compatibility, we only have one host
if Settings.ldap['enabled'] || Rails.env.test?
  if Settings.ldap['host'].present?
10 11
    # We detected old LDAP configuration syntax. Update the config to make it
    # look like it was entered with the new syntax.
12
    server = Settings.ldap.except('sync_time')
13
    Settings.ldap['servers'] = {
14
      'main' => server
15
    }
16 17
  end

18
  Settings.ldap['servers'].each do |key, server|
19 20
    server = Settingslogic.new(server)

21
    server['label'] ||= 'LDAP'
22
    server['timeout'] ||= 10.seconds
23
    server['block_auto_created_users'] = false if server['block_auto_created_users'].nil?
24 25
    server['allow_username_or_email_login'] = false if server['allow_username_or_email_login'].nil?
    server['active_directory'] = true if server['active_directory'].nil?
26
    server['attributes'] = {} if server['attributes'].nil?
27
    server['lowercase_usernames'] = false if server['lowercase_usernames'].nil?
28
    server['provider_name'] ||= "ldap#{key}".downcase
29
    server['provider_class'] = OmniAuth::Utils.camelize(server['provider_name'])
30 31 32 33 34

    # For backwards compatibility
    server['encryption'] ||= server['method']
    server['encryption'] = 'simple_tls' if server['encryption'] == 'ssl'
    server['encryption'] = 'start_tls' if server['encryption'] == 'tls'
Michael Kozono's avatar
Michael Kozono committed
35

36 37 38 39 40
    # Certificate verification was added in 9.4.2, and defaulted to false for
    # backwards-compatibility.
    #
    # Since GitLab 10.0, verify_certificates defaults to true for security.
    server['verify_certificates'] = true if server['verify_certificates'].nil?
41 42

    Settings.ldap['servers'][key] = server
43 44
  end
end
45 46

Settings['omniauth'] ||= Settingslogic.new({})
47
Settings.omniauth['enabled'] = false if Settings.omniauth['enabled'].nil?
48
Settings.omniauth['auto_sign_in_with_provider'] = false if Settings.omniauth['auto_sign_in_with_provider'].nil?
49
Settings.omniauth['allow_single_sign_on'] = false if Settings.omniauth['allow_single_sign_on'].nil?
50
Settings.omniauth['external_providers'] = [] if Settings.omniauth['external_providers'].nil?
51 52
Settings.omniauth['block_auto_created_users'] = true if Settings.omniauth['block_auto_created_users'].nil?
Settings.omniauth['auto_link_ldap_user'] = false if Settings.omniauth['auto_link_ldap_user'].nil?
53
Settings.omniauth['auto_link_saml_user'] = false if Settings.omniauth['auto_link_saml_user'].nil?
54 55 56 57 58 59 60 61 62 63 64 65 66 67

Settings.omniauth['sync_profile_from_provider'] = false if Settings.omniauth['sync_profile_from_provider'].nil?
Settings.omniauth['sync_profile_attributes'] = ['email'] if Settings.omniauth['sync_profile_attributes'].nil?

# Handle backwards compatibility with merge request 11268
if Settings.omniauth['sync_email_from_provider']
  if Settings.omniauth['sync_profile_from_provider'].is_a?(Array)
    Settings.omniauth['sync_profile_from_provider'] |= [Settings.omniauth['sync_email_from_provider']]
  elsif !Settings.omniauth['sync_profile_from_provider']
    Settings.omniauth['sync_profile_from_provider'] = [Settings.omniauth['sync_email_from_provider']]
  end

  Settings.omniauth['sync_profile_attributes'] |= ['email'] unless Settings.omniauth['sync_profile_attributes'] == true
end
68

69
Settings.omniauth['providers'] ||= []
tduehr's avatar
tduehr committed
70 71 72 73
Settings.omniauth['cas3'] ||= Settingslogic.new({})
Settings.omniauth.cas3['session_duration'] ||= 8.hours
Settings.omniauth['session_tickets'] ||= Settingslogic.new({})
Settings.omniauth.session_tickets['cas3'] = 'ticket'
74

75 76 77
# Fill out omniauth-gitlab settings. It is needed for easy set up GHE or GH by just specifying url.

github_default_url = "https://github.com"
78
github_settings = Settings.omniauth['providers'].find { |provider| provider["name"] == "github" }
79 80 81 82 83 84 85 86 87 88

if github_settings
  # For compatibility with old config files (before 7.8)
  # where people dont have url in github settings
  if github_settings['url'].blank?
    github_settings['url'] = github_default_url
  end

  github_settings["args"] ||= Settingslogic.new({})

Douwe Maan's avatar
Douwe Maan committed
89 90 91 92 93 94 95 96 97 98
  github_settings["args"]["client_options"] =
    if github_settings["url"].include?(github_default_url)
      OmniAuth::Strategies::GitHub.default_options[:client_options]
    else
      {
        "site"          => File.join(github_settings["url"], "api/v3"),
        "authorize_url" => File.join(github_settings["url"], "login/oauth/authorize"),
        "token_url"     => File.join(github_settings["url"], "login/oauth/access_token")
      }
    end
99
end
100

101
Settings['shared'] ||= Settingslogic.new({})
102
Settings.shared['path'] = Settings.absolute(Settings.shared['path'] || "shared")
103

104
Settings['issues_tracker'] ||= {}
105

106 107 108
#
# GitLab
#
109
Settings['gitlab'] ||= Settingslogic.new({})
110
Settings.gitlab['default_projects_limit'] ||= 100000
111
Settings.gitlab['default_branch_protection'] ||= 2
112
Settings.gitlab['default_can_create_group'] = true if Settings.gitlab['default_can_create_group'].nil?
113
Settings.gitlab['default_theme'] = Gitlab::Themes::APPLICATION_DEFAULT if Settings.gitlab['default_theme'].nil?
114
Settings.gitlab['host']       ||= ENV['GITLAB_HOST'] || 'localhost'
115
Settings.gitlab['ssh_host']   ||= Settings.gitlab.host
116
Settings.gitlab['https']        = false if Settings.gitlab['https'].nil?
117
Settings.gitlab['port']       ||= ENV['GITLAB_PORT'] || (Settings.gitlab.https ? 443 : 80)
118
Settings.gitlab['relative_url_root'] ||= ENV['RAILS_RELATIVE_URL_ROOT'] || ''
119
Settings.gitlab['protocol'] ||= Settings.gitlab.https ? "https" : "http"
120
Settings.gitlab['email_enabled'] ||= true if Settings.gitlab['email_enabled'].nil?
121 122 123
Settings.gitlab['email_from'] ||= ENV['GITLAB_EMAIL_FROM'] || "gitlab@#{Settings.gitlab.host}"
Settings.gitlab['email_display_name'] ||= ENV['GITLAB_EMAIL_DISPLAY_NAME'] || 'GitLab'
Settings.gitlab['email_reply_to'] ||= ENV['GITLAB_EMAIL_REPLY_TO'] || "noreply@#{Settings.gitlab.host}"
124
Settings.gitlab['email_subject_suffix'] ||= ENV['GITLAB_EMAIL_SUBJECT_SUFFIX'] || ""
125 126
Settings.gitlab['base_url']   ||= Settings.__send__(:build_base_gitlab_url)
Settings.gitlab['url']        ||= Settings.__send__(:build_gitlab_url)
127
Settings.gitlab['user']       ||= 'git'
128 129 130 131 132
Settings.gitlab['user_home']  ||= begin
  Etc.getpwnam(Settings.gitlab['user']).dir
rescue ArgumentError # no user configured
  '/home/' + Settings.gitlab['user']
end
133
Settings.gitlab['time_zone'] ||= nil
Dmitriy Zaporozhets's avatar
Dmitriy Zaporozhets committed
134
Settings.gitlab['signup_enabled'] ||= true if Settings.gitlab['signup_enabled'].nil?
135
Settings.gitlab['signin_enabled'] ||= true if Settings.gitlab['signin_enabled'].nil?
136
Settings.gitlab['restricted_visibility_levels'] = Settings.__send__(:verify_constant_array, Gitlab::VisibilityLevel, Settings.gitlab['restricted_visibility_levels'], [])
137
Settings.gitlab['username_changing_enabled'] = true if Settings.gitlab['username_changing_enabled'].nil?
138
Settings.gitlab['issue_closing_pattern'] = '((?:[Cc]los(?:e[sd]?|ing)|[Ff]ix(?:e[sd]|ing)?|[Rr]esolv(?:e[sd]?|ing)|[Ii]mplement(?:s|ed|ing)?)(:?) +(?:(?:issues? +)?%{issue_ref}(?:(?: *,? +and +| *, *)?)|([A-Z][A-Z0-9_]+-\d+))+)' if Settings.gitlab['issue_closing_pattern'].nil?
139
Settings.gitlab['default_projects_features'] ||= {}
140
Settings.gitlab['webhook_timeout'] ||= 10
141
Settings.gitlab['max_attachment_size'] ||= 10
142
Settings.gitlab['session_expire_delay'] ||= 10080
143 144 145
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?
146
Settings.gitlab.default_projects_features['snippets']           = true if Settings.gitlab.default_projects_features['snippets'].nil?
147 148
Settings.gitlab.default_projects_features['builds']             = true if Settings.gitlab.default_projects_features['builds'].nil?
Settings.gitlab.default_projects_features['container_registry'] = true if Settings.gitlab.default_projects_features['container_registry'].nil?
149
Settings.gitlab.default_projects_features['visibility_level']   = Settings.__send__(:verify_constant, Gitlab::VisibilityLevel, Settings.gitlab.default_projects_features['visibility_level'], Gitlab::VisibilityLevel::PRIVATE)
150
Settings.gitlab['domain_whitelist'] ||= []
151
Settings.gitlab['import_sources'] ||= Gitlab::ImportSources.values
152
Settings.gitlab['trusted_proxies'] ||= []
153
Settings.gitlab['no_todos_messages'] ||= YAML.load_file(Rails.root.join('config', 'no_todos_messages.yml'))
154
Settings.gitlab['usage_ping_enabled'] = true if Settings.gitlab['usage_ping_enabled'].nil?
155

Valery Sizov's avatar
Valery Sizov committed
156 157 158 159
#
# CI
#
Settings['gitlab_ci'] ||= Settingslogic.new({})
160 161 162
Settings.gitlab_ci['shared_runners_enabled'] = true if Settings.gitlab_ci['shared_runners_enabled'].nil?
Settings.gitlab_ci['all_broken_builds']     = true if Settings.gitlab_ci['all_broken_builds'].nil?
Settings.gitlab_ci['add_pusher']            = false if Settings.gitlab_ci['add_pusher'].nil?
163
Settings.gitlab_ci['builds_path']           = Settings.absolute(Settings.gitlab_ci['builds_path'] || "builds/")
164
Settings.gitlab_ci['url']                 ||= Settings.__send__(:build_gitlab_ci_url)
Valery Sizov's avatar
Valery Sizov committed
165

Douwe Maan's avatar
Douwe Maan committed
166 167 168
#
# Reply by email
#
169
Settings['incoming_email'] ||= Settingslogic.new({})
170
Settings.incoming_email['enabled'] = false if Settings.incoming_email['enabled'].nil?
Douwe Maan's avatar
Douwe Maan committed
171

Kamil Trzcinski's avatar
Kamil Trzcinski committed
172 173 174 175 176
#
# Build Artifacts
#
Settings['artifacts'] ||= Settingslogic.new({})
Settings.artifacts['enabled']      = true if Settings.artifacts['enabled'].nil?
177 178 179 180
Settings.artifacts['storage_path'] = Settings.absolute(Settings.artifacts.values_at('path', 'storage_path').compact.first || File.join(Settings.shared['path'], "artifacts"))
# Settings.artifact['path'] is deprecated, use `storage_path` instead
Settings.artifacts['path']         = Settings.artifacts['storage_path']
Settings.artifacts['max_size'] ||= 100 # in megabytes
181 182 183
Settings.artifacts['object_store'] ||= Settingslogic.new({})
Settings.artifacts['object_store']['enabled'] = false if Settings.artifacts['object_store']['enabled'].nil?
Settings.artifacts['object_store']['remote_directory'] ||= nil
184
Settings.artifacts['object_store']['direct_upload'] = false if Settings.artifacts['object_store']['direct_upload'].nil?
185
Settings.artifacts['object_store']['background_upload'] = true if Settings.artifacts['object_store']['background_upload'].nil?
186
Settings.artifacts['object_store']['proxy_download'] = false if Settings.artifacts['object_store']['proxy_download'].nil?
187 188
# Convert upload connection settings to use string keys, to make Fog happy
Settings.artifacts['object_store']['connection']&.deep_stringify_keys!
Kamil Trzcinski's avatar
Kamil Trzcinski committed
189

190 191 192 193
#
# Registry
#
Settings['registry'] ||= Settingslogic.new({})
194 195
Settings.registry['enabled']       ||= false
Settings.registry['host']          ||= "example.com"
196
Settings.registry['port']          ||= nil
197 198 199
Settings.registry['api_url']       ||= "http://localhost:5000/"
Settings.registry['key']           ||= nil
Settings.registry['issuer']        ||= nil
Kamil Trzcinski's avatar
Kamil Trzcinski committed
200
Settings.registry['host_port']     ||= [Settings.registry['host'], Settings.registry['port']].compact.join(':')
201
Settings.registry['path']            = Settings.absolute(Settings.registry['path'] || File.join(Settings.shared['path'], 'registry'))
202

203
#
Kamil Trzcinski's avatar
Kamil Trzcinski committed
204
# Pages
205
#
Kamil Trzcinski's avatar
Kamil Trzcinski committed
206
Settings['pages'] ||= Settingslogic.new({})
207 208 209 210 211 212 213 214 215
Settings.pages['enabled']           = false if Settings.pages['enabled'].nil?
Settings.pages['path']              = Settings.absolute(Settings.pages['path'] || File.join(Settings.shared['path'], "pages"))
Settings.pages['https']             = false if Settings.pages['https'].nil?
Settings.pages['host']              ||= "example.com"
Settings.pages['port']              ||= Settings.pages.https ? 443 : 80
Settings.pages['protocol']          ||= Settings.pages.https ? "https" : "http"
Settings.pages['url']               ||= Settings.__send__(:build_pages_url)
Settings.pages['external_http']     ||= false unless Settings.pages['external_http'].present?
Settings.pages['external_https']    ||= false unless Settings.pages['external_https'].present?
216
Settings.pages['artifacts_server']  ||= Settings.pages['enabled'] if Settings.pages['artifacts_server'].nil?
Kamil Trzcinski's avatar
Kamil Trzcinski committed
217

218 219 220
Settings.pages['admin'] ||= Settingslogic.new({})
Settings.pages.admin['certificate'] ||= ''

Marin Jankovski's avatar
Marin Jankovski committed
221 222 223 224
#
# Git LFS
#
Settings['lfs'] ||= Settingslogic.new({})
Marin Jankovski's avatar
Marin Jankovski committed
225
Settings.lfs['enabled']      = true if Settings.lfs['enabled'].nil?
226
Settings.lfs['storage_path'] = Settings.absolute(Settings.lfs['storage_path'] || File.join(Settings.shared['path'], "lfs-objects"))
227
Settings.lfs['object_store'] ||= Settingslogic.new({})
228 229
Settings.lfs['object_store']['enabled'] = false if Settings.lfs['object_store']['enabled'].nil?
Settings.lfs['object_store']['remote_directory'] ||= nil
230
Settings.lfs['object_store']['direct_upload'] = false if Settings.lfs['object_store']['direct_upload'].nil?
231
Settings.lfs['object_store']['background_upload'] = true if Settings.lfs['object_store']['background_upload'].nil?
232
Settings.lfs['object_store']['proxy_download'] = false if Settings.lfs['object_store']['proxy_download'].nil?
233 234
# Convert upload connection settings to use string keys, to make Fog happy
Settings.lfs['object_store']['connection']&.deep_stringify_keys!
Marin Jankovski's avatar
Marin Jankovski committed
235

236 237 238 239 240 241
#
# Uploads
#
Settings['uploads'] ||= Settingslogic.new({})
Settings.uploads['storage_path'] = Settings.absolute(Settings.uploads['storage_path'] || 'public')
Settings.uploads['base_dir'] = Settings.uploads['base_dir'] || 'uploads/-/system'
242
Settings.uploads['object_store'] ||= Settingslogic.new({})
243 244
Settings.uploads['object_store']['enabled'] = false if Settings.uploads['object_store']['enabled'].nil?
Settings.uploads['object_store']['remote_directory'] ||= 'uploads'
245
Settings.uploads['object_store']['direct_upload'] = false if Settings.uploads['object_store']['direct_upload'].nil?
246
Settings.uploads['object_store']['background_upload'] = true if Settings.uploads['object_store']['background_upload'].nil?
247
Settings.uploads['object_store']['proxy_download'] = false if Settings.uploads['object_store']['proxy_download'].nil?
248 249
# Convert upload connection settings to use string keys, to make Fog happy
Settings.uploads['object_store']['connection']&.deep_stringify_keys!
250

251 252 253 254
#
# Mattermost
#
Settings['mattermost'] ||= Settingslogic.new({})
Kamil Trzcinski's avatar
Kamil Trzcinski committed
255 256
Settings.mattermost['enabled'] = false if Settings.mattermost['enabled'].nil?
Settings.mattermost['host'] = nil unless Settings.mattermost.enabled
257

258 259 260
#
# Gravatar
#
261
Settings['gravatar'] ||= Settingslogic.new({})
262
Settings.gravatar['enabled']      = true if Settings.gravatar['enabled'].nil?
263
Settings.gravatar['plain_url']  ||= 'https://www.gravatar.com/avatar/%{hash}?s=%{size}&d=identicon'
264
Settings.gravatar['ssl_url']    ||= 'https://secure.gravatar.com/avatar/%{hash}?s=%{size}&d=identicon'
265
Settings.gravatar['host']         = Settings.host_without_www(Settings.gravatar['plain_url'])
266

267 268 269 270
#
# Cron Jobs
#
Settings['cron_jobs'] ||= Settingslogic.new({})
271 272 273
Settings.cron_jobs['stuck_ci_jobs_worker'] ||= Settingslogic.new({})
Settings.cron_jobs['stuck_ci_jobs_worker']['cron'] ||= '0 * * * *'
Settings.cron_jobs['stuck_ci_jobs_worker']['job_class'] = 'StuckCiJobsWorker'
274
Settings.cron_jobs['pipeline_schedule_worker'] ||= Settingslogic.new({})
275
Settings.cron_jobs['pipeline_schedule_worker']['cron'] ||= '19 * * * *'
276
Settings.cron_jobs['pipeline_schedule_worker']['job_class'] = 'PipelineScheduleWorker'
277
Settings.cron_jobs['expire_build_artifacts_worker'] ||= Settingslogic.new({})
278
Settings.cron_jobs['expire_build_artifacts_worker']['cron'] ||= '50 * * * *'
279
Settings.cron_jobs['expire_build_artifacts_worker']['job_class'] = 'ExpireBuildArtifactsWorker'
280 281
Settings.cron_jobs['repository_check_worker'] ||= Settingslogic.new({})
Settings.cron_jobs['repository_check_worker']['cron'] ||= '20 * * * *'
282
Settings.cron_jobs['repository_check_worker']['job_class'] = 'RepositoryCheck::BatchWorker'
Jacob Vosmaer's avatar
Jacob Vosmaer committed
283
Settings.cron_jobs['admin_email_worker'] ||= Settingslogic.new({})
284
Settings.cron_jobs['admin_email_worker']['cron'] ||= '0 0 * * 0'
Jacob Vosmaer's avatar
Jacob Vosmaer committed
285
Settings.cron_jobs['admin_email_worker']['job_class'] = 'AdminEmailWorker'
286 287 288
Settings.cron_jobs['repository_archive_cache_worker'] ||= Settingslogic.new({})
Settings.cron_jobs['repository_archive_cache_worker']['cron'] ||= '0 * * * *'
Settings.cron_jobs['repository_archive_cache_worker']['job_class'] = 'RepositoryArchiveCacheWorker'
289 290 291
Settings.cron_jobs['import_export_project_cleanup_worker'] ||= Settingslogic.new({})
Settings.cron_jobs['import_export_project_cleanup_worker']['cron'] ||= '0 * * * *'
Settings.cron_jobs['import_export_project_cleanup_worker']['job_class'] = 'ImportExportProjectCleanupWorker'
292 293 294
Settings.cron_jobs['requests_profiles_worker'] ||= Settingslogic.new({})
Settings.cron_jobs['requests_profiles_worker']['cron'] ||= '0 0 * * *'
Settings.cron_jobs['requests_profiles_worker']['job_class'] = 'RequestsProfilesWorker'
295 296 297
Settings.cron_jobs['remove_expired_members_worker'] ||= Settingslogic.new({})
Settings.cron_jobs['remove_expired_members_worker']['cron'] ||= '10 0 * * *'
Settings.cron_jobs['remove_expired_members_worker']['job_class'] = 'RemoveExpiredMembersWorker'
Douwe Maan's avatar
Douwe Maan committed
298 299 300
Settings.cron_jobs['remove_expired_group_links_worker'] ||= Settingslogic.new({})
Settings.cron_jobs['remove_expired_group_links_worker']['cron'] ||= '10 0 * * *'
Settings.cron_jobs['remove_expired_group_links_worker']['job_class'] = 'RemoveExpiredGroupLinksWorker'
301
Settings.cron_jobs['prune_old_events_worker'] ||= Settingslogic.new({})
302
Settings.cron_jobs['prune_old_events_worker']['cron'] ||= '0 */6 * * *'
303
Settings.cron_jobs['prune_old_events_worker']['job_class'] = 'PruneOldEventsWorker'
304

305 306 307
Settings.cron_jobs['trending_projects_worker'] ||= Settingslogic.new({})
Settings.cron_jobs['trending_projects_worker']['cron'] = '0 1 * * *'
Settings.cron_jobs['trending_projects_worker']['job_class'] = 'TrendingProjectsWorker'
308 309 310
Settings.cron_jobs['remove_unreferenced_lfs_objects_worker'] ||= Settingslogic.new({})
Settings.cron_jobs['remove_unreferenced_lfs_objects_worker']['cron'] ||= '20 0 * * *'
Settings.cron_jobs['remove_unreferenced_lfs_objects_worker']['job_class'] = 'RemoveUnreferencedLfsObjectsWorker'
311 312 313
Settings.cron_jobs['stuck_import_jobs_worker'] ||= Settingslogic.new({})
Settings.cron_jobs['stuck_import_jobs_worker']['cron'] ||= '15 * * * *'
Settings.cron_jobs['stuck_import_jobs_worker']['job_class'] = 'StuckImportJobsWorker'
314
Settings.cron_jobs['gitlab_usage_ping_worker'] ||= Settingslogic.new({})
315
Settings.cron_jobs['gitlab_usage_ping_worker']['cron'] ||= Settings.__send__(:cron_for_usage_ping)
316
Settings.cron_jobs['gitlab_usage_ping_worker']['job_class'] = 'GitlabUsagePingWorker'
317

318 319 320 321
Settings.cron_jobs['schedule_update_user_activity_worker'] ||= Settingslogic.new({})
Settings.cron_jobs['schedule_update_user_activity_worker']['cron'] ||= '30 0 * * *'
Settings.cron_jobs['schedule_update_user_activity_worker']['job_class'] = 'ScheduleUpdateUserActivityWorker'

322 323 324 325
Settings.cron_jobs['remove_old_web_hook_logs_worker'] ||= Settingslogic.new({})
Settings.cron_jobs['remove_old_web_hook_logs_worker']['cron'] ||= '40 0 * * *'
Settings.cron_jobs['remove_old_web_hook_logs_worker']['job_class'] = 'RemoveOldWebHookLogsWorker'

326 327 328 329
Settings.cron_jobs['stuck_merge_jobs_worker'] ||= Settingslogic.new({})
Settings.cron_jobs['stuck_merge_jobs_worker']['cron'] ||= '0 */2 * * *'
Settings.cron_jobs['stuck_merge_jobs_worker']['job_class'] = 'StuckMergeJobsWorker'

330 331 332 333
Settings.cron_jobs['pages_domain_verification_cron_worker'] ||= Settingslogic.new({})
Settings.cron_jobs['pages_domain_verification_cron_worker']['cron'] ||= '*/15 * * * *'
Settings.cron_jobs['pages_domain_verification_cron_worker']['job_class'] = 'PagesDomainVerificationCronWorker'

334 335 336
Settings.cron_jobs['issue_due_scheduler_worker'] ||= Settingslogic.new({})
Settings.cron_jobs['issue_due_scheduler_worker']['cron'] ||= '50 00 * * *'
Settings.cron_jobs['issue_due_scheduler_worker']['job_class'] = 'IssueDueSchedulerWorker'
337

338 339 340 341 342 343
#
# Sidekiq
#
Settings['sidekiq'] ||= Settingslogic.new({})
Settings['sidekiq']['log_format'] ||= 'default'

344 345 346 347
#
# GitLab Shell
#
Settings['gitlab_shell'] ||= Settingslogic.new({})
348 349
Settings.gitlab_shell['path']           = Settings.absolute(Settings.gitlab_shell['path'] || Settings.gitlab['user_home'] + '/gitlab-shell/')
Settings.gitlab_shell['hooks_path']     = Settings.absolute(Settings.gitlab_shell['hooks_path'] || Settings.gitlab['user_home'] + '/gitlab-shell/hooks/')
350
Settings.gitlab_shell['secret_file'] ||= Rails.root.join('.gitlab_shell_secret')
351 352
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?
353
Settings.gitlab_shell['ssh_host']     ||= Settings.gitlab.ssh_host
354 355 356
Settings.gitlab_shell['ssh_port']     ||= 22
Settings.gitlab_shell['ssh_user']     ||= Settings.gitlab.user
Settings.gitlab_shell['owner_group']  ||= Settings.gitlab.user
357
Settings.gitlab_shell['ssh_path_prefix'] ||= Settings.__send__(:build_gitlab_shell_ssh_path_prefix)
358
Settings.gitlab_shell['git_timeout'] ||= 10800
359

360 361 362 363 364 365
#
# Workhorse
#
Settings['workhorse'] ||= Settingslogic.new({})
Settings.workhorse['secret_file'] ||= Rails.root.join('.gitlab_workhorse_secret')

366 367 368 369 370
#
# Repositories
#
Settings['repositories'] ||= Settingslogic.new({})
Settings.repositories['storages'] ||= {}
371 372 373 374 375 376 377
unless Settings.repositories.storages['default']
  Settings.repositories.storages['default'] ||= {}
  # We set the path only if the default storage doesn't exist, in case it exists
  # but follows the pre-9.0 configuration structure. `6_validations.rb` initializer
  # will validate all storages and throw a relevant error to the user if necessary.
  Settings.repositories.storages['default']['path'] ||= Settings.gitlab['user_home'] + '/repositories/'
end
378

379
Settings.repositories.storages.each do |key, storage|
380
  Settings.repositories.storages[key] = Gitlab::GitalyClient::StorageSettings.new(storage)
381 382
end

383 384 385 386 387 388 389
#
# The repository_downloads_path is used to remove outdated repository
# archives, if someone has it configured incorrectly, and it points
# to the path where repositories are stored this can cause some
# data-integrity issue. In this case, we sets it to the default
# repository_downloads_path value.
#
390
repositories_storages          = Settings.repositories.storages.values
391
repository_downloads_path      = Settings.gitlab['repository_downloads_path'].to_s.gsub(%r{/$}, '')
392 393
repository_downloads_full_path = File.expand_path(repository_downloads_path, Settings.gitlab['user_home'])

394 395 396 397
Gitlab::GitalyClient::StorageSettings.allow_disk_access do
  if repository_downloads_path.blank? || repositories_storages.any? { |rs| [repository_downloads_path, repository_downloads_full_path].include?(rs.legacy_disk_path.gsub(%r{/$}, '')) }
    Settings.gitlab['repository_downloads_path'] = File.join(Settings.shared['path'], 'cache/archive')
  end
398 399
end

400 401 402
#
# Backup
#
403
Settings['backup'] ||= Settingslogic.new({})
404
Settings.backup['keep_time']  ||= 0
405
Settings.backup['pg_schema']    = nil
406
Settings.backup['path']         = Settings.absolute(Settings.backup['path'] || "tmp/backups/")
407
Settings.backup['archive_permissions'] ||= 0600
408
Settings.backup['upload'] ||= Settingslogic.new({ 'remote_directory' => nil, 'connection' => nil })
409
Settings.backup['upload']['multipart_chunk_size'] ||= 104857600
410
Settings.backup['upload']['encryption'] ||= nil
411
Settings.backup['upload']['storage_class'] ||= nil
412

413 414 415
#
# Git
#
416
Settings['git'] ||= Settingslogic.new({})
417
Settings.git['bin_path'] ||= '/usr/bin/git'
418

419 420 421
# Important: keep the satellites.path setting until GitLab 9.0 at
# least. This setting is fed to 'rm -rf' in
# db/migrate/20151023144219_remove_satellites.rb
422
Settings['satellites'] ||= Settingslogic.new({})
423
Settings.satellites['path'] = Settings.absolute(Settings.satellites['path'] || "tmp/repo_satellites/")
424 425 426 427 428

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

430 431 432 433 434
#
# Rack::Attack settings
#
Settings['rack_attack'] ||= Settingslogic.new({})
Settings.rack_attack['git_basic_auth'] ||= Settingslogic.new({})
435
Settings.rack_attack.git_basic_auth['enabled'] = true if Settings.rack_attack.git_basic_auth['enabled'].nil?
436
Settings.rack_attack.git_basic_auth['ip_whitelist'] ||= %w{127.0.0.1}
437 438 439 440
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

441 442 443 444 445
#
# Gitaly
#
Settings['gitaly'] ||= Settingslogic.new({})

446 447 448 449 450 451 452 453 454
#
# Webpack settings
#
Settings['webpack'] ||= Settingslogic.new({})
Settings.webpack['dev_server'] ||= Settingslogic.new({})
Settings.webpack.dev_server['enabled'] ||= false
Settings.webpack.dev_server['host']    ||= 'localhost'
Settings.webpack.dev_server['port']    ||= 3808

455
#
456
# Monitoring settings
457
#
458
Settings['monitoring'] ||= Settingslogic.new({})
459
Settings.monitoring['ip_whitelist'] ||= ['127.0.0.1/8']
460
Settings.monitoring['unicorn_sampler_interval'] ||= 10
461
Settings.monitoring['ruby_sampler_interval'] ||= 60
462 463 464 465
Settings.monitoring['sidekiq_exporter'] ||= Settingslogic.new({})
Settings.monitoring.sidekiq_exporter['enabled'] ||= false
Settings.monitoring.sidekiq_exporter['address'] ||= 'localhost'
Settings.monitoring.sidekiq_exporter['port'] ||= 3807
466

467 468 469 470 471
#
# Testing settings
#
if Rails.env.test?
  Settings.gitlab['default_projects_limit']   = 42
472
  Settings.gitlab['default_can_create_group'] = true
473
  Settings.gitlab['default_can_create_team']  = false
Robert Speicher's avatar
Robert Speicher committed
474
end