Sha256: 080c261388f95137deb03fe43052f22a51b3da1c52feeaf7a5f4badc17ab9820

Contents?: true

Size: 1.39 KB

Versions: 4

Compression:

Stored size: 1.39 KB

Contents

class PasswordResetsController < ApplicationController

  before_action :load_user_using_perishable_token, :only => [:show, :update]
  skip_before_action :require_user
  respond_to :html
  layout 'user_sessions'

  def index

  end

  def create
    @user = SpudUser.find_by_email(params[:email])
    if @user
      @user.reset_perishable_token!
      CoreMailer.forgot_password_notification(@user, password_reset_url(@user.perishable_token)).deliver_later
      flash[:notice] = "Password reset instructions have been sent to your email"
      redirect_to login_path
    else
      flash.now[:error] = "No user was found with that email address"
      render 'index'
    end
  end

  def show
    
  end

  def update
    if params[:spud_user][:password].blank?
      @user.errors.add(:password, 'must not be blank')
    else
      @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_back_or_default(root_path)
        return
      end
    end
    render 'show'
  end

private

  def load_user_using_perishable_token
    @user = SpudUser.find_using_perishable_token(params[:id])
    unless @user
      flash[:error] = "Password reset token was invalid or expired"
      redirect_to login_path
    end
  end

end

Version data entries

4 entries across 4 versions & 1 rubygems

Version Path
tb_core-1.3.3 app/controllers/password_resets_controller.rb
tb_core-1.3.2 app/controllers/password_resets_controller.rb
tb_core-1.3.1 app/controllers/password_resets_controller.rb
tb_core-1.3.0 app/controllers/password_resets_controller.rb