Autenticación con Devise
Devise es una gema que facilita la implementación de la autenticación en nuestras aplicaciones.
Los pasos para configurar Devise son los siguientes:
    1.
    Agregar la gema al Gemfile:
    1
    gem 'devise'
    Copied!
    2.
    Ejecuta bundle install para instalarla.
    3.
    Ejecuta el generador de Devise:
    1
    $ rails generate devise:install
    Copied!
    4.
    El siguiente paso es crear el modelo de o de los usuarios de la aplicación, generalmente User:
    1
    $ rails generate devise User
    Copied!
    5.
    Ejecuta rails db:migrate para correr las migraciones.

Rutas que crea Devise

Asumiendo que el usuario es User, Devise crea, entre otras, las siguientes rutas:
Ruta
Descripción
GET /users/sign_up
Formulario de registro
POST /users
Registrarse
GET /users/sign_in
Formulario de login
POST /users/sign_in
Login
DELETE /users/sign_out
Salir
Para ver el listado completo ejecuta rails routes. Las demás rutas son, en su mayoría, para el manejo de contraseñas (recuperar, cambiar, etc).

Filtros y helpers de controlador

Devise crea algunos métodos de ayuda y filtros para que puedas manejar la autenticación en tu aplicación.
Asumiendo que tu usuario se llama User, el filtro que puedes agregar sobre los controladores que quieres proteger es el siguiente:
1
before_action :authenticate_user!
Copied!
Los métodos de ayuda a los que vas a tener acceso en los controladores y vistas son los siguientes:
Método
Descripción
user_signed_in?
Retorna true si el usuario está autenticado, false de lo contrario
current_user
Retorna el usuario que está autenticado o nil
user_session
Retorna la sesión del usuario

El modelo de usuario

Asumiendo que al usuario lo llamaste User al generarlo, el modelo que genera Devise es el siguiente:
1
class User < ApplicationRecord
2
# Include default devise modules. Others available are:
3
# :confirmable, :lockable, :timeoutable and :omniauthable
4
devise :database_authenticatable, :registerable,
5
:recoverable, :rememberable, :trackable, :validatable
6
end
Copied!
Este es un modelo normal pero utiliza el método devise que recibe una serie de módulos que puedes activar o desactivar.
Los módulos que vienen activados son los siguientes:
Módulo
Descripción
database_authenticatable
Los usuarios se van a poder autenticar con un nombre de usuario y contraseña almacenado en la base de datos.
registereable
Los usuarios van a poder registrarse, actualizar y eliminar su perfil.
recoverable
Los usuarios van a poder recuperar su contraseña
rememberable
Habilita la opción "Recordarme" en el login
trackable
Habilita el seguimiento al usuario (de dónde se autenticó, cuantas veces, de qué IP, etc.)
validatable
Valida el email y el password

Modificando las vistas

Por defecto no vas a ver vistas ni controladores de Devise en tu aplicación. Sin embargo, si quieres modificarlos puedes decirle a Devise que los genere.
Para generar las vistas utiliza el siguiente comando:
1
$ rails generate devise:views
Copied!
Para generar los controladores utiliza el siguiente comando:
1
$ rails generate devise:controllers users
Copied!
Luego incorpora el controlador que quieras sobreescribir en config/routes.rb de la siguiente manera:
1
devise_for :users, :controllers => { registrations: 'users/registrations' }
Copied!
De esta forma puedes modificar las vistas y cambiar funcionalidad de Devise.
Last modified 11mo ago