2016-05-15 4 views
1

Я пытаюсь сделать то, что, по моему мнению, должно быть простым: сделайте простое редактирование в одном текстовом поле с действием обновления по умолчанию. Но он просто не работает, несмотря на множество попыток и изменений.Вложенный ресурс не обновляется

Там нет ошибок и сообщение вспышки отвечает успешно, но информация не сохраняется в базу данных на всех:

routes.rb

resources :interviews do 
    resources :invitations do 
    put :accept 
    end 
end 

просмотры/приглашения/edit.html.haml

= simple_form_for [@interview, @invitation] do |f| 
    = f.error_notification 
    = f.input :testing 
    = f.submit 'Edit Invitstion', :class => 'button small' 

контроллеры/invitations_controller.rb

def update 
    @invitation = Invitation.find(params[:id]) 
    @interview = Interview.find(params[:interview_id]) 

    @invitation.update_attributes(invitation_params) 

    if @invitation.update_attributes(invitation_params) 
    redirect_to edit_interview_invitation_path(@interview, @invitation), notice: "Your profile has been successfully updated." 
    else 
    render action: "edit" 
    end 
end 

private 

def invitation_params 
    params.permit(:user_id, :interview_id, :invitation_id, :session_time, :workflow_state, :testing) 
end 

А вот журнал:

Started PATCH "/interviews/3/invitations/7" for ::1 at 2016-05-15 19:01:52 +0800 
Processing by InvitationsController#update as HTML 
    Parameters: {"utf8"=>"✓", "authenticity_token"=>"o0U5t0yPN0aE2er+DWK0uxqRGyp4ywfdSrEfvwiSQ3UUaOnr3Fd0raFs1IUqVzizKoqxRU0DDpmvysntB9fdhQ==", "invitation"=>{"interview_id"=>"3", "workflow_state"=>"invited", "session_time"=>"", "testing"=>"testtesttest"}, "commit"=>"Edit Invitstion", "interview_id"=>"3", "id"=>"7"} 
    User Load (0.3ms) SELECT "users".* FROM "users" WHERE "users"."id" = $1 ORDER BY "users"."id" ASC LIMIT 1 [["id", 7]] 
    Invitation Load (0.2ms) SELECT "invitations".* FROM "invitations" WHERE "invitations"."id" = $1 LIMIT 1 [["id", 7]] 
    Role Load (0.2ms) SELECT "roles".* FROM "roles" WHERE "roles"."id" = $1 LIMIT 1 [["id", 3]] 
    Interview Load (0.2ms) SELECT "interviews".* FROM "interviews" WHERE "interviews"."id" = $1 ORDER BY created_at DESC LIMIT 1 [["id", 3]] 
    CACHE (0.0ms) SELECT "invitations".* FROM "invitations" WHERE "invitations"."id" = $1 LIMIT 1 [["id", "7"]] 
    CACHE (0.0ms) SELECT "interviews".* FROM "interviews" WHERE "interviews"."id" = $1 ORDER BY created_at DESC LIMIT 1 [["id", "3"]] 
Unpermitted parameters: utf8, _method, authenticity_token, invitation, commit, id 
    (0.1ms) BEGIN 
    Invitation Exists (0.4ms) SELECT 1 AS one FROM "invitations" WHERE ("invitations"."user_id" = 3 AND "invitations"."id" != 7 AND "invitations"."interview_id" = 3) LIMIT 1 
    (0.1ms) COMMIT 
Redirected to http://localhost:3000/interviews/3/invitations/7/edit 
Completed 302 Found in 12ms (ActiveRecord: 1.6ms) 


Started GET "/interviews/3/invitations/7/edit" for ::1 at 2016-05-15 19:01:52 +0800 
Processing by InvitationsController#edit as HTML 
    Parameters: {"interview_id"=>"3", "id"=>"7"} 
    User Load (0.2ms) SELECT "users".* FROM "users" WHERE "users"."id" = $1 ORDER BY "users"."id" ASC LIMIT 1 [["id", 7]] 
    Invitation Load (0.3ms) SELECT "invitations".* FROM "invitations" WHERE "invitations"."id" = $1 LIMIT 1 [["id", 7]] 
    Role Load (0.2ms) SELECT "roles".* FROM "roles" WHERE "roles"."id" = $1 LIMIT 1 [["id", 3]] 
    Interview Load (0.2ms) SELECT "interviews".* FROM "interviews" WHERE "interviews"."id" = $1 ORDER BY created_at DESC LIMIT 1 [["id", 3]] 
    Rendered invitations/edit.html.haml within layouts/application (6.1ms) 
Completed 200 OK in 48ms (Views: 39.1ms | ActiveRecord: 1.6ms) 
+0

Есть причина, почему вы звоните @ invitation.update_attributes (invitation_params) дважды? – Bustikiller

+0

@Bustikiller Я просто взломал, чтобы попытаться посмотреть, не вызвало ли это что-то, связанное с этим. Решение Энтони было правильным, так что я уже очистил весь этот другой мусор :) –

+0

Отлично! Просто хотел убедиться, что вы не пропустили эту деталь;) – Bustikiller

ответ

0

Проверьте формат вашего объекта Params в журналах. Ваши параметры приглашения передаются в пределах ключа params["invitation"], но вы переименовываете и обновляете свой объект на основе параметров в корневом параметре хэша.

отметить также, что ваши журналы сообщают, что вы пытаетесь обновить приглашение с неразрешенных Params:

Самовольных параметрами: utf8, _method, authenticity_token, приглашение, совершал, Ид

Вы можете исправить это просто обновить свой invitation_params использовать params[:invitation], а не params так:

def invitation_params 
    params.require(:invitation).permit(:user_id, :interview_id, :invitation_id, :session_time, :workflow_state, :testing) 
end 

Кроме того, вы можете рассмотреть вопрос об увеличении ошибки, если вы пытаетесь обновить параметр, который не включен в белый список, чтобы предотвратить подобные проблемы в будущем.

В вашей конфигурации рельсов:

config.action_controller.action_on_unpermitted_parameters = :raise 
+0

Смешно. Я потратил около 5 часов на то, чтобы взломать эти разные вещи, и я видел эту часть '.require (: invite)' в местах с множеством мест, но не понимал, что это было значительным. Исправлены вещи сразу - спасибо! –

+0

Да, я тоже был сожжен этим несколько раз. Я считаю, что всегда лучше установить 'config.action_controller.action_on_unpermitted_parameters =: raise' только для хорошей меры. –

Смежные вопросы