Sign in with devise

What is authentication?

  • Registration
  • Login
  • Change Password
  • Forgot Password

Gem'ing up the works

gem 'devise'
$ bundle install

First step is to add Devise to your Gemfile

And the run bundle install, of course...

But we're not done just yet...

Installing Devise

$ rails g devise:install

In your Terminal/Command Prompt run:

So just like that devise is installed, right?

Devise a model

We need to tell Devise, in our database, where to store all this fun authentication stuff: email, user_name, password.

$ rails g devise User

Don't forget get to rake db:migrate!

+

=

What'd that do?

You can now go in your app's code and find a model (user.rb), that will look like this:

class User < ActiveRecord::Base

  # Include default devise modules. Others available are:

  # :confirmable, :lockable, :timeoutable and :omniauthable

  devise :database_authenticatable, :registerable,

  :recoverable, :rememberable, :trackable, :validatable

end

Welcome, user

<h1>Welcome#index</h1>

<p>Find me in app/views/welcome/index.html.erb</p>



<% if user_signed_in? %>

  <%= link_to "Sign out",destroy_user_session_path, method: :delete, class: "button" %>

<% else %>

  <%= link_to "Sign in",new_user_session_path %>

<% end %>

Set up your root page so that it allows you to sign in, or knows that you're already signed in.

who's signed in anyway?

You now have access to the Class 'current_user'.

<h1>Welcome#index</h1>

<p>Find me in app/views/welcome/index.html.erb</p>



<% if user_signed_in? %>

  Hello, <%= current_user.email %>!<br />

  <%= link_to "Sign out",destroy_user_session_path, method: :delete, class: "button" %>

<% else %>

  <%= link_to "Sign in",new_user_session_path %>

<% end %>

Devise views

We can customize the sign-in/sign-up forms.

 

First we need to create the views for Devise.

$ rails g devise:views

 A new folder has been created, under 'views', called 'devise', and there's a whole bunch of stuff in there!

 

Does this user have a name?

Devise gives you Email and Password, but wouldn't it be great to have Name, too?

 

We can add attributes to the User just as we would to any Resource.

$ rails g migration AddNameToUsers name:string

And there's one more thing we can't forget to run...

application controller finally becomes useful!

Since we have no User controller, we'll need the help of the Application controller...

  #add the following lines:

  before_action :configure_permitted_parameters, if: :devise_controller?



  protected



  def configure_permitted_parameters

    devise_parameter_sanitizer.for(:sign_up) { |u| u.permit({ roles: [] }, :email, :password,
    :password_confirmation, :name) }

    devise_parameter_sanitizer.for(:account_update) { |u| u.permit(:email, :password, 
    :password_confirmation, :current_password, :name) }

  end

Change your view

We need to also add fields to our devise/registration views (edit & new), so a name can be entered.


  <div><%= f.label :name %><br />
    <%= f.text_field :name, autofocus: true %>
  </div>

autofocus: true means that field will be automatically selected when the page is loaded. I moved this attribute from the e-mail field.

Sign In With Devise

By argroch

Sign In With Devise

User authentication on your Rails app is no sweat with the Devise gem.

  • 1,167