]> git.openstreetmap.org Git - rails.git/blobdiff - config/initializers/config.rb
Merge remote-tracking branch 'upstream/pull/4667'
[rails.git] / config / initializers / config.rb
index 80997e0dc90ac455f018fcf88bc7603cf09141ad..f36e6ac1ac4f0686dc401f928c552fe1695478b4 100644 (file)
@@ -1,12 +1,31 @@
+# Guard against deployments with old-style application.yml configurations
+# Otherwise, admins might not be aware that they are now silently ignored
+# and major problems could occur
+# rubocop:disable Rails/Output, Rails/Exit
+if Rails.root.join("config/application.yml").exist?
+  puts "The config/application.yml file is no longer supported."
+  puts ""
+  puts "Default settings are now found in config/settings.yml and you"
+  puts "can override these in config/settings.local.yml."
+  puts ""
+  puts "To prevent unexpected behaviour, please copy any custom"
+  puts "settings to config/settings.local.yml and then remove"
+  puts "your config/application.yml file."
+  exit!
+end
+# rubocop:enable Rails/Output, Rails/Exit
+
 # Allowed status values
-ALLOWED_STATUS ||= [
-  "online",            # online and operating normally
-  "api_readonly",      # site online but API in read-only mode
-  "api_offline",       # site online but API offline
-  "database_readonly", # database and site in read-only mode
-  "database_offline",  # database offline with site in emergency mode
-  "gpx_offline"        # gpx storage offline
-].freeze
+unless Object.const_defined?(:ALLOWED_STATUS)
+  ALLOWED_STATUS = [
+    "online",            # online and operating normally
+    "api_readonly",      # site online but API in read-only mode
+    "api_offline",       # site online but API offline
+    "database_readonly", # database and site in read-only mode
+    "database_offline",  # database offline with site in emergency mode
+    "gpx_offline"        # gpx storage offline
+  ].freeze
+end
 
 Config.setup do |config|
   # Name of the constant exposing loaded settings
@@ -57,8 +76,15 @@ Config.setup do |config|
     required(:max_note_request_area).filled(:number?)
     required(:tracepoints_per_page).filled(:int?)
     required(:max_number_of_way_nodes).filled(:int?)
+    required(:max_number_of_relation_members).filled(:int?)
+    required(:max_issues_count).filled(:int?)
     required(:api_timeout).filled(:int?)
+    required(:user_account_deletion_delay).maybe(:number?)
     required(:imagery_blacklist).maybe(:array?)
     required(:status).filled(:str?, :included_in? => ALLOWED_STATUS)
+    required(:avatar_storage).filled(:str?)
+    required(:trace_file_storage).filled(:str?)
+    required(:trace_image_storage).filled(:str?)
+    required(:trace_icon_storage).filled(:str?)
   end
 end