I am trying to let users update their profile without entering their passwords provided that they're logged in. However, even though the user is logged in, I cannot make edits without a password being entered.
I get this error:
1 error prohibited this user from being saved:
Current password can't be blank
<h1>User profile home</h1>
<p><%= @user.inspect %></p>
<p><%= @user.first_name %></p>
<p><%= @user.last_name %></p>
<p><%= @user.bio %></p>
<h3>Edit profile</h3>
<%= form_for(resource, as: resource_name, url: registration_path(resource_name), html: { method: :put }) do |f| %>
<%= devise_error_messages! %>
<div class="field">
<%= f.label :email %><br />
<%= f.email_field :email, autofocus: true %>
</div>
<div class="field">
<%= f.label :bio %><br />
<%= f.text_area :bio %>
</div>
<div class="field">
<%= f.label :first_name %><br />
<%= f.text_field :first_name %>
</div>
<div class="field">
<%= f.label :last_name %><br />
<%= f.text_field :last_name %>
</div>
<div class="actions">
<%= f.submit "Update" %>
</div>
<% end %>
Updated Controller
class ProfilesController < Devise::RegistrationsController
include AuthenticationConcern
def home
user_id = params[:id]
check_user_route_access current_user, user_id
@user = User.find_by id: user_id
end
def update
super
end
protected
def update_resource(resource, params)
resource.update_without_password(params)
end
end