Sha256: 80d3f23f16003b8ea402745f86fc90c1c8ce74c3fe5f2ea4861179e3a6624b74

Contents?: true

Size: 1.33 KB

Versions: 30

Compression:

Stored size: 1.33 KB

Contents

# This controller handles the login/logout function of the site.  
class SessionsController < ApplicationController
  # Be sure to include AuthenticationSystem in Application Controller instead
  include AuthenticatedSystem

  # render new.rhtml
  def new
  end

  def create
    logout_keeping_session!
    user = User.authenticate(params[:login], params[:password])
    if user
      # Protects against session fixation attacks, causes request forgery
      # protection if user resubmits an earlier form using back
      # button. Uncomment if you understand the tradeoffs.
      # reset_session
      self.current_user = user
      new_cookie_flag = (params[:remember_me] == "1")
      handle_remember_cookie! new_cookie_flag
      redirect_back_or_default(root_path)
      flash[:notice] = "Logged in successfully"
    else
      note_failed_signin
      @login       = params[:login]
      @remember_me = params[:remember_me]
      render :action => 'new'
    end
  end

  def destroy
    logout_killing_session!
    flash[:notice] = "You have been logged out."
    redirect_back_or_default(root_path)
  end

protected
  # Track failed login attempts
  def note_failed_signin
    flash[:error] = "Couldn't log you in as '#{params[:login]}'"
    logger.warn "Failed login for '#{params[:login]}' from #{request.remote_ip} at #{Time.now.utc}"
  end
end

Version data entries

30 entries across 30 versions & 1 rubygems

Version Path
tournament-5.0.0 webgui/app/controllers/sessions_controller.rb
tournament-4.2.0 webgui/app/controllers/sessions_controller.rb
tournament-4.0.2 webgui/app/controllers/sessions_controller.rb
tournament-4.0.0 webgui/app/controllers/sessions_controller.rb
tournament-3.3.3 webgui/app/controllers/sessions_controller.rb
tournament-3.3.2 webgui/app/controllers/sessions_controller.rb
tournament-3.3.1 webgui/app/controllers/sessions_controller.rb
tournament-3.3.0 webgui/app/controllers/sessions_controller.rb
tournament-3.2.2 webgui/app/controllers/sessions_controller.rb
tournament-3.2.1 webgui/app/controllers/sessions_controller.rb
tournament-3.2.0 webgui/app/controllers/sessions_controller.rb
tournament-3.1.1 webgui/app/controllers/sessions_controller.rb
tournament-3.1.0 webgui/app/controllers/sessions_controller.rb
tournament-3.0.3 webgui/app/controllers/sessions_controller.rb
tournament-3.0.2 webgui/app/controllers/sessions_controller.rb
tournament-3.0.1 webgui/app/controllers/sessions_controller.rb
tournament-3.0.0 webgui/app/controllers/sessions_controller.rb
tournament-2.1.0 webgui/app/controllers/sessions_controller.rb
tournament-2.2.1 webgui/app/controllers/sessions_controller.rb
tournament-2.1.1 webgui/app/controllers/sessions_controller.rb