Sha256: d8f46682a2b4ba185192e69d20d84ef9bfd56f715540525d60197285cb58e2d6

Contents?: true

Size: 1.44 KB

Versions: 1

Compression:

Stored size: 1.44 KB

Contents

class Spree::UsersController < Spree::StoreController
  skip_before_action :set_current_order, only: :show, raise: false
  prepend_before_action :load_object, only: [:show, :edit, :update]
  prepend_before_action :authorize_actions, only: :new

  include Spree::Core::ControllerHelpers

  def show
    @orders = @user.orders.complete.order('completed_at desc')
  end

  def create
    @user = Spree::User.new(user_params)
    if @user.save

      if current_order
        session[:guest_token] = nil
      end

      redirect_back_or_default(root_url)
    else
      render :new
    end
  end

  def update
    if @user.update_attributes(user_params)
      spree_current_user.reload

      if params[:user][:password].present?
        # this logic needed b/c devise wants to log us out after password changes
        unless Spree::Auth::Config[:signout_after_password_change]
          bypass_sign_in(@user)
        end
      end
      redirect_to spree.account_url, notice: I18n.t('spree.account_updated')
    else
      render :edit
    end
  end

  private
    def user_params
      params.require(:user).permit(Spree::PermittedAttributes.user_attributes | [:email])
    end

    def load_object
      @user ||= Spree::User.find_by(id: spree_current_user&.id)
      authorize! params[:action].to_sym, @user
    end

    def authorize_actions
      authorize! params[:action].to_sym, Spree::User.new
    end

    def accurate_title
      I18n.t('spree.my_account')
    end
end

Version data entries

1 entries across 1 versions & 1 rubygems

Version Path
solidus_auth_devise-2.2.0 lib/controllers/frontend/spree/users_controller.rb