+# 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
+
Config.setup do |config|
# Name of the constant exposing loaded settings
config.const_name = "Settings"
# Load environment variables from the `ENV` object and override any settings defined in files.
#
- # config.use_env = false
+ config.use_env = true
# Define ENV variable prefix deciding which variables to load into config.
#
- # config.env_prefix = 'Settings'
+ config.env_prefix = "OPENSTREETMAP"
# What string to use as level separator for settings loaded from ENV variables. Default value of '.' works well
# with Heroku, but you might want to change it for example for '__' to easy override settings from command line, where
# using dots in variable names might not be allowed (eg. Bash).
#
- # config.env_separator = '.'
+ config.env_separator = "_"
# Ability to process variables names:
# * nil - no change
# * :downcase - convert to lower case
#
- # config.env_converter = :downcase
+ config.env_converter = :downcase
# Parse numeric values as integers instead of strings.
#
# Validate presence and type of specific config values. Check https://github.com/dry-rb/dry-validation for details.
#
- # config.schema do
- # required(:name).filled
- # required(:age).maybe(:int?)
- # required(:email).filled(format?: EMAIL_REGEX)
- # end
+ config.schema do
+ required(:api_version).filled(:str?)
+ required(:max_request_area).filled(:number?)
+ required(:max_note_request_area).filled(:number?)
+ required(:tracepoints_per_page).filled(:int?)
+ required(:max_number_of_way_nodes).filled(:int?)
+ required(:api_timeout).filled(:int?)
+ required(:imagery_blacklist).maybe(:array?)
+ required(:status).filled(:str?, :included_in? => ALLOWED_STATUS)
+ end
end