diff options
| author | sadbeast <sadbeast@sadbeast.com> | 2024-01-31 17:47:56 -0800 | 
|---|---|---|
| committer | sadbeast <sadbeast@sadbeast.com> | 2024-01-31 17:47:56 -0800 | 
| commit | 332ec93366315fa1ed7b4acd7a3407c96e8ddfa7 (patch) | |
| tree | 6ae553317f12a7a6a29c849c8805ffab96436dc2 /config | |
| download | td-main.tar.gz td-main.tar.bz2 | |
Diffstat (limited to 'config')
| -rw-r--r-- | config/application.rb | 28 | ||||
| -rw-r--r-- | config/boot.rb | 4 | ||||
| -rw-r--r-- | config/cable.yml | 10 | ||||
| -rw-r--r-- | config/credentials.yml.enc | 1 | ||||
| -rw-r--r-- | config/database.yml | 88 | ||||
| -rw-r--r-- | config/environment.rb | 5 | ||||
| -rw-r--r-- | config/environments/development.rb | 79 | ||||
| -rw-r--r-- | config/environments/production.rb | 98 | ||||
| -rw-r--r-- | config/environments/test.rb | 64 | ||||
| -rw-r--r-- | config/importmap.rb | 7 | ||||
| -rw-r--r-- | config/initializers/assets.rb | 12 | ||||
| -rw-r--r-- | config/initializers/content_security_policy.rb | 25 | ||||
| -rw-r--r-- | config/initializers/filter_parameter_logging.rb | 8 | ||||
| -rw-r--r-- | config/initializers/inflections.rb | 16 | ||||
| -rw-r--r-- | config/initializers/permissions_policy.rb | 13 | ||||
| -rw-r--r-- | config/initializers/rodauth.rb | 3 | ||||
| -rw-r--r-- | config/locales/en.yml | 31 | ||||
| -rw-r--r-- | config/routes.rb | 12 | ||||
| -rw-r--r-- | config/storage.yml | 34 | 
19 files changed, 538 insertions, 0 deletions
| diff --git a/config/application.rb b/config/application.rb new file mode 100644 index 0000000..0a4d44d --- /dev/null +++ b/config/application.rb @@ -0,0 +1,28 @@ +require_relative "boot" + +require "rails/all" + +# Require the gems listed in Gemfile, including any gems +# you've limited to :test, :development, or :production. +Bundler.require(*Rails.groups) + +module Teamdraft +  class Application < Rails::Application +    # Initialize configuration defaults for originally generated Rails version. +    config.load_defaults 7.1 + +    # Please, add to the `ignore` list any other `lib` subdirectories that do +    # not contain `.rb` files, or that should not be reloaded or eager loaded. +    # Common ones are `templates`, `generators`, or `middleware`, for example. +    config.autoload_lib(ignore: %w(assets tasks)) + +    # Configuration for the application, engines, and railties goes here. +    # +    # These settings can be overridden in specific environments using the files +    # in config/environments, which are processed later. +    # +    # config.time_zone = "Central Time (US & Canada)" +    # config.eager_load_paths << Rails.root.join("extras") +    config.active_record.schema_format = :sql +  end +end diff --git a/config/boot.rb b/config/boot.rb new file mode 100644 index 0000000..988a5dd --- /dev/null +++ b/config/boot.rb @@ -0,0 +1,4 @@ +ENV["BUNDLE_GEMFILE"] ||= File.expand_path("../Gemfile", __dir__) + +require "bundler/setup" # Set up gems listed in the Gemfile. +require "bootsnap/setup" # Speed up boot time by caching expensive operations. diff --git a/config/cable.yml b/config/cable.yml new file mode 100644 index 0000000..ef9da8a --- /dev/null +++ b/config/cable.yml @@ -0,0 +1,10 @@ +development: +  adapter: async + +test: +  adapter: test + +production: +  adapter: redis +  url: <%= ENV.fetch("REDIS_URL") { "redis://localhost:6379/1" } %> +  channel_prefix: teamdraft_production diff --git a/config/credentials.yml.enc b/config/credentials.yml.enc new file mode 100644 index 0000000..59f0119 --- /dev/null +++ b/config/credentials.yml.enc @@ -0,0 +1 @@ +dvaGG+w18b3mMPYsFbGZb5sAmAnJ18svQcasHEtQc8sQ/7xwRskiO7qvCyKWCsbN/7KNcZmQVyTalt9Z/I538Mdmh8J0Aw3eo5f5g+a5gKqW1tI3T4ELObOmnag/xlTwJg1eSMJFjyes5fAoSuCqXX1tKM7sgLriOMl/ftirXmd9djpRKurklAH+eT8KU1J9vmFAuCo+tePxGFvo0ELjhF2D046j2juMoAbR0qOYU/RdiFqgx8yYYtqjE3uYzrCSferOHtAdrZn+ICY+9txzeKjxvh8Q6HA+pQEe0iRWWT3oZtK30iChDIYfFoukWA55ChGwcSe6cPe0M6qqkUAH2WPpvtlQXQVxN84wUzhHLX2rp2St/WMCBB9KGeC9nUkxN02tiLGmaPdOsUEvkHncQ9QWXpPr--gEBOGXKSt6idrN+T--sIIV/OpvW93v1wBWYYiWCQ==
\ No newline at end of file diff --git a/config/database.yml b/config/database.yml new file mode 100644 index 0000000..921a8dd --- /dev/null +++ b/config/database.yml @@ -0,0 +1,88 @@ +# PostgreSQL. Versions 9.3 and up are supported. +# +# Install the pg driver: +#   gem install pg +# On macOS with Homebrew: +#   gem install pg -- --with-pg-config=/usr/local/bin/pg_config +# On Windows: +#   gem install pg +#       Choose the win32 build. +#       Install PostgreSQL and put its /bin directory on your path. +# +# Configure Using Gemfile +# gem "pg" +# +default: &default +  adapter: postgresql +  encoding: unicode +  # For details on connection pooling, see Rails configuration guide +  # https://guides.rubyonrails.org/configuring.html#database-pooling +  pool: <%= ENV.fetch("RAILS_MAX_THREADS") { 5 } %> +  username: teamdraft_website +  schema_search_path: 'teamdraft,public' +  host: <%= ENV["TEAMDRAFT_DATABASE_HOST"] %> + +development: +  <<: *default +  database: teamdraft +  username: teamdraft + +  # The specified database role being used to connect to PostgreSQL. +  # To create additional roles in PostgreSQL see `$ createuser --help`. +  # When left blank, PostgreSQL will use the default role. This is +  # the same name as the operating system user running Rails. +  #username: teamdraft + +  # The password associated with the PostgreSQL role (username). +  #password: + +  # Connect on a TCP socket. Omitted by default since the client uses a +  # domain socket that doesn't need configuration. Windows does not have +  # domain sockets, so uncomment these lines. +  #host: localhost + +  # The TCP port the server listens on. Defaults to 5432. +  # If your server runs on a different port number, change accordingly. +  #port: 5432 + +  # Schema search path. The server defaults to $user,public +  #schema_search_path: myapp,sharedapp,public + +  # Minimum log levels, in increasing order: +  #   debug5, debug4, debug3, debug2, debug1, +  #   log, notice, warning, error, fatal, and panic +  # Defaults to warning. +  #min_messages: notice + +# Warning: The database defined as "test" will be erased and +# re-generated from your development database when you run "rake". +# Do not set this db to the same as development or production. +test: +  <<: *default +  database: teamdraft_test + +# As with config/credentials.yml, you never want to store sensitive information, +# like your database password, in your source code. If your source code is +# ever seen by anyone, they now have access to your database. +# +# Instead, provide the password or a full connection URL as an environment +# variable when you boot the app. For example: +# +#   DATABASE_URL="postgres://myuser:mypass@localhost/somedatabase" +# +# If the connection URL is provided in the special DATABASE_URL environment +# variable, Rails will automatically merge its configuration values on top of +# the values provided in this file. Alternatively, you can specify a connection +# URL environment variable explicitly: +# +#   production: +#     url: <%= ENV["MY_APP_DATABASE_URL"] %> +# +# Read https://guides.rubyonrails.org/configuring.html#configuring-a-database +# for a full overview on how database connection configuration can be specified. +# +production: +  <<: *default +  database: teamdraft +  username: teamdraft_website +  password: <%= ENV["TEAMDRAFT_DATABASE_PASSWORD"] %> diff --git a/config/environment.rb b/config/environment.rb new file mode 100644 index 0000000..cac5315 --- /dev/null +++ b/config/environment.rb @@ -0,0 +1,5 @@ +# Load the Rails application. +require_relative "application" + +# Initialize the Rails application. +Rails.application.initialize! diff --git a/config/environments/development.rb b/config/environments/development.rb new file mode 100644 index 0000000..ec43c00 --- /dev/null +++ b/config/environments/development.rb @@ -0,0 +1,79 @@ +require "active_support/core_ext/integer/time" + +Rails.application.configure do +  # Settings specified here will take precedence over those in config/application.rb. + +  # In the development environment your application's code is reloaded any time +  # it changes. This slows down response time but is perfect for development +  # since you don't have to restart the web server when you make code changes. +  config.enable_reloading = true + +  # Do not eager load code on boot. +  config.eager_load = false + +  # Show full error reports. +  config.consider_all_requests_local = true + +  # Enable server timing +  config.server_timing = true + +  # Enable/disable caching. By default caching is disabled. +  # Run rails dev:cache to toggle caching. +  if Rails.root.join("tmp/caching-dev.txt").exist? +    config.action_controller.perform_caching = true +    config.action_controller.enable_fragment_cache_logging = true + +    config.cache_store = :memory_store +    config.public_file_server.headers = { +      "Cache-Control" => "public, max-age=#{2.days.to_i}" +    } +  else +    config.action_controller.perform_caching = false + +    config.cache_store = :null_store +  end + +  # Store uploaded files on the local file system (see config/storage.yml for options). +  config.active_storage.service = :local + +  # Don't care if the mailer can't send. +  config.action_mailer.raise_delivery_errors = false + +  config.action_mailer.perform_caching = false + +  # Print deprecation notices to the Rails logger. +  config.active_support.deprecation = :log + +  # Raise exceptions for disallowed deprecations. +  config.active_support.disallowed_deprecation = :raise + +  # Tell Active Support which deprecation messages to disallow. +  config.active_support.disallowed_deprecation_warnings = [] + +  # Raise an error on page load if there are pending migrations. +  config.active_record.migration_error = :page_load + +  # Highlight code that triggered database queries in logs. +  config.active_record.verbose_query_logs = true + +  # Highlight code that enqueued background job in logs. +  config.active_job.verbose_enqueue_logs = true + +  # Suppress logger output for asset requests. +  config.assets.quiet = true + +  # Generate source maps +  config.assets.debug = true + +  # Raises error for missing translations. +  # config.i18n.raise_on_missing_translations = true + +  # Annotate rendered view with file names. +  # config.action_view.annotate_rendered_view_with_filenames = true + +  # Uncomment if you wish to allow Action Cable access from any origin. +  # config.action_cable.disable_request_forgery_protection = true + +  # Raise error when a before_action's only/except options reference missing actions +  config.action_controller.raise_on_missing_callback_actions = true +end diff --git a/config/environments/production.rb b/config/environments/production.rb new file mode 100644 index 0000000..d1bf876 --- /dev/null +++ b/config/environments/production.rb @@ -0,0 +1,98 @@ +require "active_support/core_ext/integer/time" + +Rails.application.configure do +  # Settings specified here will take precedence over those in config/application.rb. + +  # Code is not reloaded between requests. +  config.enable_reloading = false + +  # Eager load code on boot. This eager loads most of Rails and +  # your application in memory, allowing both threaded web servers +  # and those relying on copy on write to perform better. +  # Rake tasks automatically ignore this option for performance. +  config.eager_load = true + +  # Full error reports are disabled and caching is turned on. +  config.consider_all_requests_local = false +  config.action_controller.perform_caching = true + +  # Ensures that a master key has been made available in ENV["RAILS_MASTER_KEY"], config/master.key, or an environment +  # key such as config/credentials/production.key. This key is used to decrypt credentials (and other encrypted files). +  # config.require_master_key = true + +  # Disable serving static files from `public/`, relying on NGINX/Apache to do so instead. +  # config.public_file_server.enabled = false + +  # Compress CSS using a preprocessor. +  # config.assets.css_compressor = :sass + +  # Do not fall back to assets pipeline if a precompiled asset is missed. +  config.assets.compile = false + +  # Enable serving of images, stylesheets, and JavaScripts from an asset server. +  # config.asset_host = "http://assets.example.com" + +  # Specifies the header that your server uses for sending files. +  # config.action_dispatch.x_sendfile_header = "X-Sendfile" # for Apache +  # config.action_dispatch.x_sendfile_header = "X-Accel-Redirect" # for NGINX + +  # Store uploaded files on the local file system (see config/storage.yml for options). +  config.active_storage.service = :local + +  # Mount Action Cable outside main process or domain. +  # config.action_cable.mount_path = nil +  # config.action_cable.url = "wss://example.com/cable" +  # config.action_cable.allowed_request_origins = [ "http://example.com", /http:\/\/example.*/ ] + +  # Assume all access to the app is happening through a SSL-terminating reverse proxy. +  # Can be used together with config.force_ssl for Strict-Transport-Security and secure cookies. +  # config.assume_ssl = true + +  # Force all access to the app over SSL, use Strict-Transport-Security, and use secure cookies. +  # config.force_ssl = true + +  # Log to STDOUT by default +  config.logger = ActiveSupport::Logger.new(STDOUT) +    .tap  { |logger| logger.formatter = ::Logger::Formatter.new } +    .then { |logger| ActiveSupport::TaggedLogging.new(logger) } + +  # Prepend all log lines with the following tags. +  config.log_tags = [ :request_id ] + +  # "info" includes generic and useful information about system operation, but avoids logging too much +  # information to avoid inadvertent exposure of personally identifiable information (PII). If you +  # want to log everything, set the level to "debug". +  config.log_level = ENV.fetch("RAILS_LOG_LEVEL", "info") + +  # Use a different cache store in production. +  # config.cache_store = :mem_cache_store + +  # Use a real queuing backend for Active Job (and separate queues per environment). +  # config.active_job.queue_adapter = :resque +  # config.active_job.queue_name_prefix = "teamdraft_production" + +  config.action_mailer.perform_caching = false + +  # Ignore bad email addresses and do not raise email delivery errors. +  # Set this to true and configure the email server for immediate delivery to raise delivery errors. +  # config.action_mailer.raise_delivery_errors = false + +  # Enable locale fallbacks for I18n (makes lookups for any locale fall back to +  # the I18n.default_locale when a translation cannot be found). +  config.i18n.fallbacks = true + +  # Don't log any deprecations. +  config.active_support.report_deprecations = false + +  # Do not dump schema after migrations. +  config.active_record.dump_schema_after_migration = false + +  # Enable DNS rebinding protection and other `Host` header attacks. +  # config.hosts = [ +  #   "example.com",     # Allow requests from example.com +  #   /.*\.example\.com/ # Allow requests from subdomains like `www.example.com` +  # ] +  config.hosts = ["teamdraft.sadbeast.com"] +  # Skip DNS rebinding protection for the default health check endpoint. +  # config.host_authorization = { exclude: ->(request) { request.path == "/up" } } +end diff --git a/config/environments/test.rb b/config/environments/test.rb new file mode 100644 index 0000000..adbb4a6 --- /dev/null +++ b/config/environments/test.rb @@ -0,0 +1,64 @@ +require "active_support/core_ext/integer/time" + +# The test environment is used exclusively to run your application's +# test suite. You never need to work with it otherwise. Remember that +# your test database is "scratch space" for the test suite and is wiped +# and recreated between test runs. Don't rely on the data there! + +Rails.application.configure do +  # Settings specified here will take precedence over those in config/application.rb. + +  # While tests run files are not watched, reloading is not necessary. +  config.enable_reloading = false + +  # Eager loading loads your entire application. When running a single test locally, +  # this is usually not necessary, and can slow down your test suite. However, it's +  # recommended that you enable it in continuous integration systems to ensure eager +  # loading is working properly before deploying your code. +  config.eager_load = ENV["CI"].present? + +  # Configure public file server for tests with Cache-Control for performance. +  config.public_file_server.enabled = true +  config.public_file_server.headers = { +    "Cache-Control" => "public, max-age=#{1.hour.to_i}" +  } + +  # Show full error reports and disable caching. +  config.consider_all_requests_local = true +  config.action_controller.perform_caching = false +  config.cache_store = :null_store + +  # Render exception templates for rescuable exceptions and raise for other exceptions. +  config.action_dispatch.show_exceptions = :rescuable + +  # Disable request forgery protection in test environment. +  config.action_controller.allow_forgery_protection = false + +  # Store uploaded files on the local file system in a temporary directory. +  config.active_storage.service = :test + +  config.action_mailer.perform_caching = false + +  # Tell Action Mailer not to deliver emails to the real world. +  # The :test delivery method accumulates sent emails in the +  # ActionMailer::Base.deliveries array. +  config.action_mailer.delivery_method = :test + +  # Print deprecation notices to the stderr. +  config.active_support.deprecation = :stderr + +  # Raise exceptions for disallowed deprecations. +  config.active_support.disallowed_deprecation = :raise + +  # Tell Active Support which deprecation messages to disallow. +  config.active_support.disallowed_deprecation_warnings = [] + +  # Raises error for missing translations. +  # config.i18n.raise_on_missing_translations = true + +  # Annotate rendered view with file names. +  # config.action_view.annotate_rendered_view_with_filenames = true + +  # Raise error when a before_action's only/except options reference missing actions +  config.action_controller.raise_on_missing_callback_actions = true +end diff --git a/config/importmap.rb b/config/importmap.rb new file mode 100644 index 0000000..bc060ed --- /dev/null +++ b/config/importmap.rb @@ -0,0 +1,7 @@ +# Pin npm packages by running ./bin/importmap + +pin "application" +pin "@hotwired/turbo-rails", to: "turbo.min.js", preload: true +pin "@hotwired/stimulus", to: "stimulus.min.js" +pin "@hotwired/stimulus-loading", to: "stimulus-loading.js" +pin_all_from "app/javascript/controllers", under: "controllers" diff --git a/config/initializers/assets.rb b/config/initializers/assets.rb new file mode 100644 index 0000000..2eeef96 --- /dev/null +++ b/config/initializers/assets.rb @@ -0,0 +1,12 @@ +# Be sure to restart your server when you modify this file. + +# Version of your assets, change this if you want to expire all your assets. +Rails.application.config.assets.version = "1.0" + +# Add additional assets to the asset load path. +# Rails.application.config.assets.paths << Emoji.images_path + +# Precompile additional assets. +# application.js, application.css, and all non-JS/CSS in the app/assets +# folder are already added. +# Rails.application.config.assets.precompile += %w( admin.js admin.css ) diff --git a/config/initializers/content_security_policy.rb b/config/initializers/content_security_policy.rb new file mode 100644 index 0000000..b3076b3 --- /dev/null +++ b/config/initializers/content_security_policy.rb @@ -0,0 +1,25 @@ +# Be sure to restart your server when you modify this file. + +# Define an application-wide content security policy. +# See the Securing Rails Applications Guide for more information: +# https://guides.rubyonrails.org/security.html#content-security-policy-header + +# Rails.application.configure do +#   config.content_security_policy do |policy| +#     policy.default_src :self, :https +#     policy.font_src    :self, :https, :data +#     policy.img_src     :self, :https, :data +#     policy.object_src  :none +#     policy.script_src  :self, :https +#     policy.style_src   :self, :https +#     # Specify URI for violation reports +#     # policy.report_uri "/csp-violation-report-endpoint" +#   end +# +#   # Generate session nonces for permitted importmap, inline scripts, and inline styles. +#   config.content_security_policy_nonce_generator = ->(request) { request.session.id.to_s } +#   config.content_security_policy_nonce_directives = %w(script-src style-src) +# +#   # Report violations without enforcing the policy. +#   # config.content_security_policy_report_only = true +# end diff --git a/config/initializers/filter_parameter_logging.rb b/config/initializers/filter_parameter_logging.rb new file mode 100644 index 0000000..c2d89e2 --- /dev/null +++ b/config/initializers/filter_parameter_logging.rb @@ -0,0 +1,8 @@ +# Be sure to restart your server when you modify this file. + +# Configure parameters to be partially matched (e.g. passw matches password) and filtered from the log file. +# Use this to limit dissemination of sensitive information. +# See the ActiveSupport::ParameterFilter documentation for supported notations and behaviors. +Rails.application.config.filter_parameters += [ +  :passw, :secret, :token, :_key, :crypt, :salt, :certificate, :otp, :ssn +] diff --git a/config/initializers/inflections.rb b/config/initializers/inflections.rb new file mode 100644 index 0000000..3860f65 --- /dev/null +++ b/config/initializers/inflections.rb @@ -0,0 +1,16 @@ +# Be sure to restart your server when you modify this file. + +# Add new inflection rules using the following format. Inflections +# are locale specific, and you may define rules for as many different +# locales as you wish. All of these examples are active by default: +# ActiveSupport::Inflector.inflections(:en) do |inflect| +#   inflect.plural /^(ox)$/i, "\\1en" +#   inflect.singular /^(ox)en/i, "\\1" +#   inflect.irregular "person", "people" +#   inflect.uncountable %w( fish sheep ) +# end + +# These inflection rules are supported but not enabled by default: +# ActiveSupport::Inflector.inflections(:en) do |inflect| +#   inflect.acronym "RESTful" +# end diff --git a/config/initializers/permissions_policy.rb b/config/initializers/permissions_policy.rb new file mode 100644 index 0000000..7db3b95 --- /dev/null +++ b/config/initializers/permissions_policy.rb @@ -0,0 +1,13 @@ +# Be sure to restart your server when you modify this file. + +# Define an application-wide HTTP permissions policy. For further +# information see: https://developers.google.com/web/updates/2018/06/feature-policy + +# Rails.application.config.permissions_policy do |policy| +#   policy.camera      :none +#   policy.gyroscope   :none +#   policy.microphone  :none +#   policy.usb         :none +#   policy.fullscreen  :self +#   policy.payment     :self, "https://secure.example.com" +# end diff --git a/config/initializers/rodauth.rb b/config/initializers/rodauth.rb new file mode 100644 index 0000000..a832109 --- /dev/null +++ b/config/initializers/rodauth.rb @@ -0,0 +1,3 @@ +Rodauth::Rails.configure do |config| +  config.app = "RodauthApp" +end diff --git a/config/locales/en.yml b/config/locales/en.yml new file mode 100644 index 0000000..6c349ae --- /dev/null +++ b/config/locales/en.yml @@ -0,0 +1,31 @@ +# Files in the config/locales directory are used for internationalization and +# are automatically loaded by Rails. If you want to use locales other than +# English, add the necessary files in this directory. +# +# To use the locales, use `I18n.t`: +# +#     I18n.t "hello" +# +# In views, this is aliased to just `t`: +# +#     <%= t("hello") %> +# +# To use a different locale, set it with `I18n.locale`: +# +#     I18n.locale = :es +# +# This would use the information in config/locales/es.yml. +# +# To learn more about the API, please read the Rails Internationalization guide +# at https://guides.rubyonrails.org/i18n.html. +# +# Be aware that YAML interprets the following case-insensitive strings as +# booleans: `true`, `false`, `on`, `off`, `yes`, `no`. Therefore, these strings +# must be quoted to be interpreted as strings. For example: +# +#     en: +#       "yes": yup +#       enabled: "ON" + +en: +  hello: "Hello world" diff --git a/config/routes.rb b/config/routes.rb new file mode 100644 index 0000000..8acf3fa --- /dev/null +++ b/config/routes.rb @@ -0,0 +1,12 @@ +Rails.application.routes.draw do +  # Define your application routes per the DSL in https://guides.rubyonrails.org/routing.html +  get "leagues", to: "leagues#index", as: "leagues" +  get "leagues/:id", to: "leagues#show", as: "league" + +  # Reveal health status on /up that returns 200 if the app boots with no exceptions, otherwise 500. +  # Can be used by load balancers and uptime monitors to verify that the app is live. +  get "up" => "rails/health#show", as: :rails_health_check + +  # Defines the root path route ("/") +  root "leagues#index" +end diff --git a/config/storage.yml b/config/storage.yml new file mode 100644 index 0000000..4942ab6 --- /dev/null +++ b/config/storage.yml @@ -0,0 +1,34 @@ +test: +  service: Disk +  root: <%= Rails.root.join("tmp/storage") %> + +local: +  service: Disk +  root: <%= Rails.root.join("storage") %> + +# Use bin/rails credentials:edit to set the AWS secrets (as aws:access_key_id|secret_access_key) +# amazon: +#   service: S3 +#   access_key_id: <%= Rails.application.credentials.dig(:aws, :access_key_id) %> +#   secret_access_key: <%= Rails.application.credentials.dig(:aws, :secret_access_key) %> +#   region: us-east-1 +#   bucket: your_own_bucket-<%= Rails.env %> + +# Remember not to checkin your GCS keyfile to a repository +# google: +#   service: GCS +#   project: your_project +#   credentials: <%= Rails.root.join("path/to/gcs.keyfile") %> +#   bucket: your_own_bucket-<%= Rails.env %> + +# Use bin/rails credentials:edit to set the Azure Storage secret (as azure_storage:storage_access_key) +# microsoft: +#   service: AzureStorage +#   storage_account_name: your_account_name +#   storage_access_key: <%= Rails.application.credentials.dig(:azure_storage, :storage_access_key) %> +#   container: your_container_name-<%= Rails.env %> + +# mirror: +#   service: Mirror +#   primary: local +#   mirrors: [ amazon, google, microsoft ] |