2016-01-16 9 views
6

Próbuję zezwolić użytkownikom na zmianę ich adresów e-mail, które wykorzystują jako unikalną nazwę użytkownika. Mimo że aktualizacja nie zawiera błędów, nie wprowadzono żadnych zmian w adresie e-mail użytkownika w bazie danych.Deweloper zmiany wersji nie aktualizuje wiadomości e-mail

tutaj są odpowiednie porcje kodu:

Postać:

<%= 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> 

kontrolera:

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 ... 

sposób 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 
Model konto

użytkownik:

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 

Odpowiedz

0

Nie jestem pewien, ale myślę, że w modelu użytkownika nie powinno być

accepts_nested_attributes_for :user_account 
+0

Tak, już to :( – chris

5

Ok, więc okazuje się, że nowy adres e-mail został zapisywane as: unconfirmed_email, ale nie zmieniło to żadnej funkcji połączonego konta, ponieważ konto nadal zawierało stary e-mail jako: email.

Zatem musiałem zrobić

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

Aby potwierdzeniu użytkownik może być złe i tak, że formularz logowania nie będzie już akceptować stare hasło.

+0

Użyłem wywołania 'confirm()' .Ty sam pomysł. –