Sha256: 50cba85e76c9c3d2ad1b97bcc7d452c4ec42e20d70b6a8e75c3854228a65b5f8
Contents?: true
Size: 1.19 KB
Versions: 1
Compression:
Stored size: 1.19 KB
Contents
class SessionsController < ApplicationController before_action :set_session, only: :destroy skip_before_action :authenticate, only: %i[ new create ] def index @sessions = Current.<%= singular_table_name %>.sessions.order(created_at: :desc) end def new @<%= singular_table_name %> = <%= class_name %>.new end def create @<%= singular_table_name %> = <%= class_name %>.find_by_email(params[:email]) if @<%= singular_table_name %> && @<%= singular_table_name %>.authenticate(params[:password]) session = @<%= singular_table_name %>.sessions.create!(session_params) cookies.signed.permanent[:session_token] = { value: session.id, httponly: true } redirect_to root_path, notice: "Signed in successfully" else redirect_to sign_in_path(email_hint: params[:email]), alert: "That email or password is incorrect" end end def destroy @session.destroy redirect_to sessions_path, notice: "That session has been logged out" end private def set_session @session = Current.<%= singular_table_name %>.sessions.find(params[:id]) end def session_params { user_agent: request.user_agent, ip_address: request.remote_ip } end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
authentication-zero-2.2.8 | lib/generators/authentication/templates/controllers/html/sessions_controller.rb.tt |