Sha256: 171a0eeea0e6697794389b35214a292870c603767af3af49a16bd2bdab8334f6

Contents?: true

Size: 1.48 KB

Versions: 3

Compression:

Stored size: 1.48 KB

Contents

class Admin::PasswordResetsController < Admin::ApplicationController

  before_action :load_user_using_perishable_token, :only => [:show, :update]
  skip_before_action :require_user, :require_admin_user
  layout 'admin/login'

  def index

  end

  def create
    @user = SpudUser.find_by_email(params[:email])
    if @user
      @user.reset_perishable_token!
      CoreMailer.forgot_password_notification(@user, admin_password_reset_url(@user.perishable_token)).deliver
      flash[:notice] = "Instructions to reset your password have been emailed to you. " +
      "Please check your email."
      redirect_to admin_login_path
    else
      flash.now[:error] = "No user was found with that email address"
      render 'index'
    end
  end

  def show

  end

  def update
    @user.password = params[:spud_user][:password]
    @user.password_confirmation = params[:spud_user][:password_confirmation]
    if @user.save
      SpudUserSession.create(@user)
      flash[:notice] = "Password successfully updated"
      redirect_to admin_login_path
    else
      render 'show'
    end
  end

private

  def load_user_using_perishable_token
    @user = SpudUser.find_using_perishable_token(params[:id])
    unless @user
      flash[:notice] = "We're sorry, but we could not locate your account. " +
      "If you are having issues try copying and pasting the URL " +
      "from your email into your browser or restarting the " +
      "reset password process."
      redirect_to admin_login_path
    end
  end
end

Version data entries

3 entries across 3 versions & 1 rubygems

Version Path
tb_core-1.3.0.beta2 app/controllers/admin/password_resets_controller.rb
tb_core-1.3.0.beta1 app/controllers/admin/password_resets_controller.rb
tb_core-1.2.8 app/controllers/admin/password_resets_controller.rb