2016-01-16 2 views
6

J'essaie de permettre aux utilisateurs de changer leurs adresses e-mail qui utilisent des utilisations comme nom d'utilisateur unique. Même si la mise à jour ne donne aucune erreur, aucune modification n'est apportée à l'adresse e-mail de l'utilisateur dans la base de données.Devise modifier l'e-mail ne met pas à jour l'e-mail

Voici les parties pertinentes de code:

Forme:

<%= f.fields_for :user_account, @user.user_account do |user_account| %> 
<p>Edit email address for account: <%= @user.user_account.email %></p> 
<div class="field"> 
    <%= user_account.label :new_email %><br /> 
    <%= user_account.text_field :email, autocomplete: "off", value: nil %> 
</div> 
<div class="field"> 
    <%= user_account.label :password %> <i>(please confirm the password associated with this account)</i><br /> 
    <%= user_account.password_field :current_password, autocomplete: "off" %> 
</div> 
<%= hidden_field_tag 'form', 'email' %> 
<div class="actions"> 
    <%= user_account.submit "Edit" %> 
</div> 
contrôleur

:

def update 
respond_to do |format| 
if params[:form] == 'email' 
    if @user.user_account.valid_password?(params[:user][:user_account_attributes][:current_password]) 
     if @user.update(user_params) 
     format.html { redirect_to user_path(@user), :notice => 'your new email has been saved' } 
     format.json { render :show, status: :ok, location: @user } 
     else 
     format.html { render :edit } 
     format.json { render json: @user.errors, status: :unprocessable_entity } 
     end 
    else 
     format.html { redirect_to edit_email_path(@user), :notice => 'incorrect password (email)' } 
    end 
else ... 

la méthode user_params:

def user_params 
params.require(:user).permit(
    :first_name, :middle_initial, :last_name, 
    :linkedin, :website, :facebook, :video, :phone_number, 
    :address_1, :address_2, :city, :zip_code, 
    :image, :number, :years_practicing, :neighborhood, :biography, :price, :status, 
    user_employments_attributes: [:id, :user_id, :company, :position, :start_date, :end_date, :info, :_destroy], 
    user_educations_attributes: [:id, :user_id, :school, :degree_title, :start_date, :end_date, :info, :_destroy], 
    user_account_attributes: [:id, :user_id, :email, :password, :password_confirmation, :_destroy], 
    user_category_ids:[]) 
end 

modèle de compte utilisateur:

class UserAccount < ActiveRecord::Base 
    # Include default devise modules. Others available are: 
    # , :lockable, :timeoutable and :omniauthable 
    devise :database_authenticatable, :registerable, :confirmable, 
    :recoverable, :rememberable, :trackable, :validatable 
    belongs_to :user 
end 

Répondre

0

Je ne suis pas sûr, mais je pense que, dans votre modèle utilisateur devrait être

accepts_nested_attributes_for :user_account 
+0

Oui, déjà cela :( – chris

5

Ok, donc il se trouve que la nouvelle adresse e-mail a été en cours d'enregistrement Comme: unconfirmed_email, mais cela n'a pas changé les fonctionnalités du compte lié, puisque le compte avait toujours l'ancien email stocké comme: email.

donc je devais faire

user.confirmed_at = nil 
user.save(:validate => false) 

pour que l'e-mail de confirmation de l'utilisateur à être renvoyés et que le formulaire de connexion ne serait plus accepter l'ancien mot de passe.

+0

J'ai utilisé un appel à 'confirm()'. Même idée. –