Sha256: c496d3645daee1517b59e902204cf01ddc6e8e930aa06df8924dc8cb098f1344

Contents?: true

Size: 1.87 KB

Versions: 14

Compression:

Stored size: 1.87 KB

Contents

module Casein
  class PasswordResetsController < Casein::CaseinController
  
    unloadable
  
    skip_before_filter :authorise
    before_filter :load_user_using_perishable_token, :only => [:edit, :update]

    layout 'casein_auth'
    
    def create
      users = Casein::User.where(:email => params[:recover_email]).all

      if users.length > 0
        users.each do |user|
          user.send_password_reset_instructions
        end

        if users.length > 1
          flash[:notice] = "Multiple accounts were found. Emails have been sent to " + params[:recover_email] + " with instructions on how to reset your passwords"
        else
          flash[:notice] = "An email has been sent to " + params[:recover_email] + " with instructions on how to reset your password"
        end
      else
        flash[:warning] = "There is no user with that email"
      end

      redirect_to new_casein_user_session_url
    end

    def edit
      render
    end

    def update
      
      if params[:casein_user][:password].empty? || params[:casein_user][:password_confirmation].empty?
        flash.now[:warning] = "A field has been left empty"
      else
      
        @reset_user.password = params[:casein_user][:password]
        @reset_user.password_confirmation = params[:casein_user][:password_confirmation]
      
        if @reset_user.save
          flash[:notice] = "Password successfully updated"
          redirect_to new_casein_user_session_url
          return
        end
      end
      
      render :action => :edit
    end

  private
    
    def load_user_using_perishable_token
      
      @reset_user = Casein::User.find_using_perishable_token params[:token]
      
      unless @reset_user
        flash[:warning] = "Your account could not be located. Try to copy and paste the URL directly from the email."
        redirect_to new_casein_user_session_url
      end
    end
  end
end

Version data entries

14 entries across 14 versions & 1 rubygems

Version Path
casein-4.0.0 app/controllers/casein/password_resets_controller.rb
casein-4.0.0.beta1 app/controllers/casein/password_resets_controller.rb
casein-3.1.11 app/controllers/casein/password_resets_controller.rb
casein-3.1.10 app/controllers/casein/password_resets_controller.rb
casein-3.1.9 app/controllers/casein/password_resets_controller.rb
casein-3.1.8 app/controllers/casein/password_resets_controller.rb
casein-3.1.7 app/controllers/casein/password_resets_controller.rb
casein-3.1.6 app/controllers/casein/password_resets_controller.rb
casein-3.1.5 app/controllers/casein/password_resets_controller.rb
casein-3.1.4 app/controllers/casein/password_resets_controller.rb
casein-3.1.3 app/controllers/casein/password_resets_controller.rb
casein-3.1.2 app/controllers/casein/password_resets_controller.rb
casein-3.1.1 app/controllers/casein/password_resets_controller.rb
casein-3.1.0 app/controllers/casein/password_resets_controller.rb