Ich habe Rails API-Anwendung mit vielen zu vielen Beziehung zwischen Benutzern und Projekten obwohl Project_memberships Tabelle.Verschachtelte Attribute mit has_many durch Verknüpfung erstellen Objekt zweimal
Modelle:
class User < ActiveRecord::Base
has_many :project_memberships, dependent: :destroy
has_many :projects, -> { uniq }, through: :project_memberships
accepts_nested_attributes_for :project_memberships, allow_destroy: true
end
class Project < ActiveRecord::Base
has_many :project_memberships, dependent: :destroy
has_many :users, -> { uniq }, through: :project_memberships
end
class ProjectMembership < ActiveRecord::Base
belongs_to :user
belongs_to :project
validates :user, presence: true
validates :project, presence: true
end
Controller:
class UsersController < ApplicationController
expose(:user, attributes: :user_params)
respond_to :json
# removed unrelated actions
def update
user.update user_params
respond_with user
end
private
def user_params
params.require(:user).permit(
:first_name, :last_name,
project_memberships_attributes:
[:id, :project_id, :membership_starts_at, :_destroy]
)
end
end
Das Problem ist, dass, wenn ich senden PUT
Anfrage an http://localhost:3000/users/1
mit folgendem json:
{"user":{"project_memberships_attributes":[{"project_id": 1}]}
user.update user_params
erstellt 2 ProjectMembership-Datensätze mit denselben user_id
und project_id
.
SQL (0.3ms) INSERT INTO "project_memberships" ("project_id", "user_id", "created_at", "updated_at") VALUES ($1, $2, $3, $4) RETURNING "id" [["project_id", 1], ["user_id", 1], ["created_at", "2016-03-18 18:00:07.670012"], ["updated_at", "2016-03-18 18:00:07.670012"]]
SQL (0.2ms) INSERT INTO "project_memberships" ("project_id", "user_id", "created_at", "updated_at") VALUES ($1, $2, $3, $4) RETURNING "id" [["project_id", 1], ["user_id", 1], ["created_at", "2016-03-18 18:00:07.671644"], ["updated_at", "2016-03-18 18:00:07.671644"]]
(1.0ms) COMMIT
Btw zu zerstören und die Aktualisierung bereits Aufzeichnungen bestehenden durch id
in verschachtelte Attribute angeben korrekt funktioniert.
Als erstes würde ich prüfen, ob die 'config/routes.rb' richtig eingestellt sind, so dass dies die richtige Controller # Aktion ist, die aufgerufen wird. – jaysoifer
@ JonathanSoifer Ich habe 'binding.pry' vor und nach' user.update' gesetzt und die Ausführung gestoppt, also sind die Routen korrekt. Und SQL-Abfragen, die ich am Ende hinzugefügt habe, wurden dazwischen aufgerufen. –