Bring devise initializer from spree_auth_devise and fix spree initializer details

This commit is contained in:
luisramos0
2019-07-05 22:45:59 +01:00
parent a413f22e12
commit 17448699f9
7 changed files with 177 additions and 21 deletions

View File

@@ -56,7 +56,7 @@ module Spree
# Introduces a registration step whenever the +registration_step+ preference is true.
def check_registration
return unless Spree::Auth::Config[:registration_step]
return unless AuthConfig[:registration_step]
return if spree_current_user or current_order.email
store_location
redirect_to spree.checkout_registration_path

View File

@@ -29,7 +29,7 @@ class Spree::UsersController < Spree::StoreController
if params[:user][:password].present?
# this logic needed b/c devise wants to log us out after password changes
user = Spree::User.reset_password_by_token(params[:user])
sign_in(@user, :event => :authentication, :bypass => !Spree::Auth::Config[:signout_after_password_change])
sign_in(@user, :event => :authentication, :bypass => !AuthConfig[:signout_after_password_change])
end
redirect_to spree.account_url, :notice => Spree.t(:account_updated)
else

View File

@@ -1,5 +1,146 @@
# Use this hook to configure devise mailer, warden hooks and so forth. The first
# four configuration values can also be set straight in your models.
Devise.setup do |config|
# ==> Mailer Configuration
# Configure the e-mail address which will be shown in DeviseMailer.
config.mailer_sender = 'please-change-me@config-initializers-devise.com'
# Configure the class responsible to send e-mails.
config.mailer = 'Spree::UserMailer'
# ==> ORM configuration
# Load and configure the ORM. Supports :active_record (default) and
# :mongoid (bson_ext recommended) by default. Other ORMs may be
# available as additional gems.
require 'devise/orm/active_record'
# ==> Configuration for any authentication mechanism
# Configure which keys are used when authenticating an user. By default is
# just :email. You can configure it to use [:username, :subdomain], so for
# authenticating an user, both parameters are required. Remember that those
# parameters are used only when authenticating and not when retrieving from
# session. If you need permissions, you should implement that in a before filter.
# config.authentication_keys = [ :email ]
# Tell if authentication through request.params is enabled. True by default.
# config.params_authenticatable = true
# Tell if authentication through HTTP Basic Auth is enabled. False by default.
config.http_authenticatable = true
# Set this to true to use Basic Auth for AJAX requests. True by default.
#config.http_authenticatable_on_xhr = false
# The realm used in Http Basic Authentication
config.http_authentication_realm = 'Spree Application'
# ==> Configuration for :database_authenticatable
# For bcrypt, this is the cost for hashing the password and defaults to 10. If
# using other encryptors, it sets how many times you want the password re-encrypted.
config.stretches = 20
# Setup a pepper to generate the encrypted password.
config.pepper = Rails.configuration.secret_token
# ==> Configuration for :confirmable
# The time you want to give your user to confirm his account. During this time
# he will be able to access your application without confirming. Default is nil.
# When confirm_within is zero, the user won't be able to sign in without confirming.
# You can use this to let your user access some features of your application
# without confirming the account, but blocking it after a certain period
# (ie 2 days).
# config.confirm_within = 2.days
# ==> Configuration for :rememberable
# The time the user will be remembered without asking for credentials again.
# config.remember_for = 2.weeks
# If true, a valid remember token can be re-used between multiple browsers.
# config.remember_across_browsers = true
# If true, extends the user's remember period when remembered via cookie.
# config.extend_remember_period = false
# ==> Configuration for :validatable
# Range for password length
# config.password_length = 6..20
# Regex to use to validate the email address
config.email_regexp = /^([\w\.%\+\-]+)@([\w\-]+\.)+([\w]{2,})$/i
# ==> Configuration for :timeoutable
# The time you want to timeout the user session without activity. After this
# time the user will be asked for credentials again.
# config.timeout_in = 10.minutes
# ==> Configuration for :lockable
# Defines which strategy will be used to lock an account.
# :failed_attempts = Locks an account after a number of failed attempts to sign in.
# :none = No lock strategy. You should handle locking by yourself.
# config.lock_strategy = :failed_attempts
# Defines which strategy will be used to unlock an account.
# :email = Sends an unlock link to the user email
# :time = Re-enables login after a certain amount of time (see :unlock_in below)
# :both = Enables both strategies
# :none = No unlock strategy. You should handle unlocking by yourself.
# config.unlock_strategy = :both
# Number of authentication tries before locking an account if lock_strategy
# is failed attempts.
# config.maximum_attempts = 20
# Time interval to unlock the account if :time is enabled as unlock_strategy.
# config.unlock_in = 1.hour
# ==> Configuration for :token_authenticatable
# Defines name of the authentication token params key
config.token_authentication_key = :auth_token
# ==> Scopes configuration
# Turn scoped views on. Before rendering 'sessions/new', it will first check for
# 'users/sessions/new'. It's turned off by default because it's slower if you
# are using only default views.
# config.scoped_views = true
# Configure the default scope given to Warden. By default it's the first
# devise role declared in your routes.
# Add a default scope to devise, to prevent it from checking
# whether other devise enabled models are signed into a session or not
config.default_scope = :spree_user
end
# Configure sign_out behavior.
# By default sign_out is scoped (i.e. /users/sign_out affects only :user scope).
# In case of sign_out_all_scopes set to true any logout action will sign out all active scopes.
# config.sign_out_all_scopes = false
# ==> Navigation configuration
# Lists the formats that should be treated as navigational. Formats like
# :html, should redirect to the sign in page when the user does not have
# access, but formats like :xml or :json, should return 401.
# If you have any extra navigational formats, like :iphone or :mobile, you
# should add them to the navigational formats lists. Default is [:html]
config.navigational_formats = [:html, :json, :xml]
# ==> Warden configuration
# If you want to use other strategies, that are not (yet) supported by Devise,
# you can configure them inside the config.warden block. The example below
# allows you to setup OAuth, using http://github.com/roman/warden_oauth
#
# config.warden do |manager|
# manager.oauth(:twitter) do |twitter|
# twitter.consumer_secret = <YOUR CONSUMER SECRET>
# twitter.consumer_key = <YOUR CONSUMER KEY>
# twitter.options :site => 'http://twitter.com'
# end
# manager.default_strategies(:scope => :user).unshift :twitter_oauth
# end
#
# Time interval you can reset your password with a reset password key.
# Don't put a too small interval or your users won't have the time to
# change their passwords.
config.reset_password_within = 6.hours
config.sign_out_via = :get
config.case_insensitive_keys = [:email]
end

View File

@@ -42,11 +42,16 @@ Spree.config do |config|
config.s3_protocol = ENV.fetch('S3_PROTOCOL', 'https')
end
# Initialize authentication
require 'spree/authentication_helpers'
ApplicationController.send :include, Spree::AuthenticationHelpers
# Spree 2.0 recommends explicitly setting this here when using spree_auth_devise
Spree.user_class = 'Spree::User'
AuthConfig = Spree::AuthConfiguration.new
# Don't log users out when setting a new password
Spree::Auth::Config[:signout_after_password_change] = false
AuthConfig[:signout_after_password_change] = false
# TODO Work out why this is necessary
# Seems like classes within OFN module become 'uninitialized' when server reloads

View File

@@ -1,16 +0,0 @@
# `spree_auth_devise` gem decorators get loaded in a `to_prepare` callback
# referring to Spree classes that have not been loaded yet
#
# When this initializer is loaded we're sure that those Spree classes have been
# loaded and we load again the `spree_auth_devise` decorators to effectively
# apply them.
#
# Give a look at `if defined?(Spree::Admin::BaseController)` in the following file
# to get an example:
# https://github.com/openfoodfoundation/spree_auth_devise/blob/spree-upgrade-intermediate/app/controllers/spree/admin/admin_controller_decorator.rb#L1
#
# TODO: remove this hack once we get to Spree 3.0
gem_dir = Gem::Specification.find_by_name("spree_auth_devise").gem_dir
Dir.glob(File.join(gem_dir, 'app/**/*_decorator*.rb')) do |c|
load c
end

View File

@@ -0,0 +1,26 @@
module Spree
module AuthenticationHelpers
def self.included(receiver)
receiver.send :helper_method, :spree_current_user
receiver.send :helper_method, :spree_login_path
receiver.send :helper_method, :spree_signup_path
receiver.send :helper_method, :spree_logout_path
end
def spree_current_user
current_spree_user
end
def spree_login_path
spree.login_path
end
def spree_signup_path
spree.signup_path
end
def spree_logout_path
spree.logout_path
end
end
end

View File

@@ -128,7 +128,7 @@ RSpec.configure do |config|
spree_config.auto_capture = true
end
Spree::Auth::Config[:signout_after_password_change] = false
AuthConfig[:signout_after_password_change] = false
Spree::Api::Config[:requires_authentication] = true
end