123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354 |
- require 'devise/rails/routes'
- require 'devise/rails/warden_compat'
- module Devise
- class Engine < ::Rails::Engine
- config.devise = Devise
- # Initialize Warden and copy its configurations.
- config.app_middleware.use Warden::Manager do |config|
- Devise.warden_config = config
- end
- # Force routes to be loaded if we are doing any eager load.
- config.before_eager_load { |app| app.reload_routes! }
- initializer "devise.url_helpers" do
- Devise.include_helpers(Devise::Controllers)
- end
- initializer "devise.omniauth" do |app|
- Devise.omniauth_configs.each do |provider, config|
- app.middleware.use config.strategy_class, *config.args do |strategy|
- config.strategy = strategy
- end
- end
- if Devise.omniauth_configs.any?
- Devise.include_helpers(Devise::OmniAuth)
- end
- end
- initializer "devise.mongoid_version_warning" do
- if defined?(Mongoid)
- require 'mongoid/version'
- if Mongoid::VERSION.to_f < 2.1
- puts "\n[DEVISE] Please note that Mongoid versions prior to 2.1 handle dirty model " \
- "object attributes in such a way that the Devise `validatable` module will not apply " \
- "its usual uniqueness and format validations for the email field. It is recommended " \
- "that you upgrade to Mongoid 2.1+ for this and other fixes, but if for some reason you " \
- "are unable to do so, you should add these validations manually.\n"
- end
- end
- end
- initializer "devise.fix_routes_proxy_missing_respond_to_bug" do
- # We can get rid of this once we support only Rails > 3.2
- ActionDispatch::Routing::RoutesProxy.class_eval do
- def respond_to?(method, include_private = false)
- super || routes.url_helpers.respond_to?(method)
- end
- end
- end
- end
- end
|