sessions_controller.rb 871 B

12345678910111213141516171819202122232425262728
  1. #---
  2. # Excerpted from "Agile Web Development with Rails",
  3. # published by The Pragmatic Bookshelf.
  4. # Copyrights apply to this code. It may not be used to create training material,
  5. # courses, books, articles, and the like. Contact us if you are in doubt.
  6. # We make no guarantees that this code is fit for any purpose.
  7. # Visit http://www.pragmaticprogrammer.com/titles/rails4 for more book information.
  8. #---
  9. class SessionsController < ApplicationController
  10. skip_before_filter :authorize
  11. def new
  12. end
  13. def create
  14. user = User.find_by_name(params[:name])
  15. if user and user.authenticate(params[:password])
  16. session[:user_id] = user.id
  17. redirect_to admin_url
  18. else
  19. redirect_to login_url, alert: "Invalid user/password combination"
  20. end
  21. end
  22. def destroy
  23. session[:user_id] = nil
  24. redirect_to store_url, notice: "Logged out"
  25. end
  26. end