mirror of
https://github.com/openfoodfoundation/openfoodnetwork
synced 2026-03-17 04:34:24 +00:00
Bring devise initializer from spree_auth_devise and fix spree initializer details
This commit is contained in:
@@ -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
|
||||
|
||||
@@ -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
|
||||
|
||||
@@ -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
|
||||
|
||||
@@ -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
|
||||
|
||||
@@ -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
|
||||
26
lib/spree/authentication_helpers.rb
Normal file
26
lib/spree/authentication_helpers.rb
Normal 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
|
||||
@@ -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
|
||||
|
||||
|
||||
Reference in New Issue
Block a user