2013-07-26 7 views
12

ho questo a mio avviso, che è una casella di controllo multiselectparametri forti non accettare serie

Modello

class User < ActiveRecord::Base 
    has_many :user_roles, :dependent => :destroy 
    accepts_nested_attributes_for :user_roles, :allow_destroy => true 
    has_many :roles, :through => :user_roles 
end 

vista

<%= check_box_tag 'user[role_ids][]', role.id, user.blank? ? nil : user.roles.include?(role) ,id: dom_id(role)%> 

i parametri forti per questo è scritto come

def user 
    params.require(:user).permit(:first_name,{:role_ids => []}) 
    end 

Ma su Crea dice

Processing by Admin::UsersController#create as HTML 
    Parameters: {"utf8"=>"✓", "authenticity_token"=>"+y8iWya5KIILqS0embEUEZuClycXq0O9Q4pA+MnbM0g=", "user"=>{"first_name"=>"", "last_name"=>"", "email"=>"[email protected]", "language"=>"en", "access_level_id"=>"1", "role_ids"=>["", "1", "", "5", "", "", ""], "password"=>"[FILTERED]", "password_confirmation"=>"[FILTERED]"}, "commit"=>"Create user"} 

Unpermitted parameters: role_ids 
Unpermitted parameters: role_ids 
Unpermitted parameters: role_ids 
Unpermitted parameters: role_ids 

Qualsiasi indizio perché è non accettare la matrice di role_ids che è venuta dalla forma?

risposta

7

me Rispondere, ho capito di lavoro non direttamente, ma il metodo seguito dalla Strong Parameters issues discussion mi ha aiutato a convertire un parametro normale ad uno whitelist.

def user_params 
    params.require(:user).permit(:first_name).tap do |whitelisted| 
    whitelisted[:role_ids] = params[:user][:role_ids] 
    end 
end 
8

Questo dovrebbe funzionare

params.require(:user).permit(:first_name, :role_ids => []) 
+1

bene ho provato questo modo troppo .. non ha funzionato .. – AnkitG

+0

incollare il metodo create pls – Benj

+0

creato un GIST [qui] (https://gist.github.com/ankit8898/6088035). Si prega di dare un'occhiata – AnkitG

21

Vedere le guide Strong Parameters documentation regarding nested attributes.

Il formato corretto è:

params.permit(:name, {:roles => []}, ...) 

AnkitG's solution ha lavorato per me in Rails 4 utilizzando il Role Model gioiello per il mio modello utente. implementazione del mio controller utente _params ha finito per assomigliare:

def user_params 
    # Bug with permit for nested arrays... @see https://stackoverflow.com/a/17880288/2631472 
    params.require(:user).permit(:first_name, :last_name, :middle_name).tap do |whitelisted| 
    whitelisted[:roles] = params[:user][:roles] 
    end 
end 

+0

Ha funzionato per me. Grazie! –