metamaps/metamaps

View on GitHub
config/application.rb

Summary

Maintainability
A
0 mins
Test Coverage
# frozen_string_literal: true

require_relative 'boot'

require 'csv'
require 'rails/all'

Bundler.require(*Rails.groups)

module Metamaps
  class Application < Rails::Application
    # Settings in config/environments/* take precedence over those specified here.
    # Application configuration should go into files in config/initializers
    # -- all .rb files in that directory are automatically loaded.
    #
    config.active_job.queue_adapter = if ENV['ACTIVE_JOB_FRAMEWORK'] == 'sucker_punch'
                                        :sucker_punch
                                      else
                                        :delayed_job
                                      end

    # Custom directories with classes and modules you want to be autoloadable.
    config.autoload_paths << Rails.root.join('app', 'decorators', 'services')

    # Configure the default encoding used in templates for Ruby 1.9.
    config.encoding = 'utf-8'

    config.to_prepare do
      Doorkeeper::ApplicationsController.layout 'application'
      Doorkeeper::AuthorizationsController.layout 'application'
      Doorkeeper::AuthorizedApplicationsController.layout 'application'
      Doorkeeper::ApplicationController.helper ApplicationHelper
    end

    config.middleware.use Rack::Attack

    # Configure sensitive parameters which will be filtered from the log file.
    config.filter_parameters += [:password]

    # Enable the asset pipeline
    config.assets.initialize_on_precompile = false

    # Version of your assets, change this if you want to expire all your assets
    config.assets.version = '2.0'

    config.generators do |g|
      g.test_framework :rspec
    end

    # pundit errors return 403 FORBIDDEN
    config.action_dispatch.rescue_responses['Pundit::NotAuthorizedError'] = :forbidden

    # S3 file storage
    config.paperclip_defaults = {
      storage: :s3,
      s3_protocol: 'https',
      s3_region: ENV['S3_REGION'],
      s3_credentials: {
        bucket: ENV['S3_BUCKET_NAME'],
        access_key_id: ENV['AWS_ACCESS_KEY_ID'],
        secret_access_key: ENV['AWS_SECRET_ACCESS_KEY']
      }
    }
  end
end