scinote-web/config/application.rb
2023-02-13 11:32:18 +01:00

91 lines
2.7 KiB
Ruby

require_relative 'boot'
require 'rails'
%w(
active_record/railtie
active_storage/engine
action_controller/railtie
action_view/railtie
action_mailer/railtie
active_job/railtie
sprockets/railtie
).each do |railtie|
begin
require railtie
rescue LoadError
end
end
# Require the gems listed in Gemfile, including any gems
# you've limited to :test, :development, or :production.
Bundler.require(*Rails.groups)
module Scinote
class Application < Rails::Application
# Initialize configuration defaults for originally generated Rails version.
config.load_defaults 6.0
Rails.autoloaders.main.ignore(Rails.root.join('addons', '*', 'app', 'decorators'))
# config.add_autoload_paths_to_load_path = false
config.active_record.schema_format = :sql
# 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.
# Add rack-attack middleware for request rate limiting
config.middleware.use Rack::Attack
# Swap the Rack::MethodOverride with a wrapped middleware for WOPI handling
require_relative '../app/middlewares/wopi_method_override'
config.middleware.swap Rack::MethodOverride, WopiMethodOverride
# Load all model concerns, including subfolders
config.autoload_paths += Dir["#{Rails.root}/app/models/concerns/**/*.rb"]
config.i18n.load_path += Dir[Rails.root.join('config', 'locales', '**', '*.{rb,yml}')]
config.encoding = 'utf-8'
config.active_job.queue_adapter = :delayed_job
# Max uploaded file size in MB
config.x.file_max_size_mb = (ENV['FILE_MAX_SIZE_MB'] || 50).to_i
config.x.webhooks_enabled = ENV['ENABLE_WEBHOOKS'] == 'true'
# Logging
config.log_formatter = proc do |severity, datetime, progname, msg|
"[#{datetime}] #{severity}: #{msg}\n"
end
# SciNote Core Application version
VERSION = File.read(Rails.root.join('VERSION')).strip.freeze
# Doorkeeper overrides
config.to_prepare do
# Only Authorization endpoint
Doorkeeper::AuthorizationsController.layout 'sign_in_halt'
# Add Connected Device logging
Doorkeeper::TokensController.class_eval do
after_action :log_connected_device, only: :create
private
def log_connected_device
return if @authorize_response.is_a?(Doorkeeper::OAuth::ErrorResponse)
ConnectedDevice.from_request_headers(request.headers, @authorize_response&.token)
end
end
end
config.action_view.field_error_proc = Proc.new { |html_tag, instance|
"<div class=\"field_with_errors sci-input-container\">#{html_tag}</div>".html_safe
}
end
end