Rails 4/Devise/MongoDB: “Unpermitted parameters” using custom properties and strong parameters

前端 未结 4 1351
南方客
南方客 2021-01-02 19:36

Trying to add a nested custom attribute, Profile (a Mongoid document), to my devise User class. When the Devise registration form is submit

相关标签:
4条回答
  • 2021-01-02 20:09

    I used your code and it worked for me!

    Here is what I did

    class RegistrationsController < Devise::RegistrationsController
      skip_before_filter :verify_authenticity_token, :only => :create #, :if => Proc.new { |c| c.request.format == 'application/json' }
      respond_to :json, :html, :xml
    
      def create
        user = User.new(devise_registrations_permitted_parameters)
        if user.save
          render :json=> user.as_json(:auth_token=>user.authentication_token, :email=>user.email,:name => user.name), :status=>201
          return
        else
          warden.custom_failure!
          render :json=> user.errors, :status=>422
        end
      end
    
    
      protected                                                            
        def devise_registrations_permitted_parameters
          params.require(:user).permit(:name, :email, :password, :password_confirmation)
        end
    
    end
    
    0 讨论(0)
  • 2021-01-02 20:17

    I found a different method that allows all the devise overriding logic and code to reside in the application controller. This allows any and all custom params to be passed through for each devise action (sign in, sign up, update). I also add a parameter sanitizer for devise_invitable and handle that logic here (invite, accept_invitation). I've got custom params like avatar, avatar_cache, etc:

    #application_controller.rb
    
      before_filter :configure_permitted_parameters, if: :devise_controller?
    
    protected
      # There are just three actions in Devise that allows any set of parameters to be passed down to the model, 
      # therefore requiring sanitization. Their names and the permited parameters by default are:
    
      # sign_in (Devise::SessionsController#new) - Permits only the authentication keys (like email)
      # sign_up (Devise::RegistrationsController#create) - Permits authentication keys plus password and password_confirmation
      # account_update (Devise::RegistrationsController#update) - Permits authentication keys plus password, password_confirmation 
      # and current_password. More at https://github.com/plataformatec/devise#strong-parameters
    
      def configure_permitted_parameters
        devise_parameter_sanitizer.for(:accept_invitation) do |u|
          u.permit(:username,:validate_username, :password,:password_confirmation, :invitation_token)
        end
        devise_parameter_sanitizer.for(:invite) do |u|
          u.permit(:name,:comments)
        end
    
        devise_parameter_sanitizer.for(:sign_up) do |u|
          u.permit(:username,:password,:password_confirmation)
        end
        devise_parameter_sanitizer.for(:sign_in) do |u|
          u.permit(:username,:email,:password,:password_confirmation,:phone, :validate_username, :avatar_cache, :remove_avatar, :current_password,:remember_me)
        end
    
        devise_parameter_sanitizer.for(:account_update) do |u|
          u.permit(:username,:email,:password,:password_confirmation,:phone, :validate_username,:avatar, :avatar_cache, :remove_avatar, :current_password)
        end
      end
    

    Find and read more at https://github.com/plataformatec/devise#strong-parameters

    0 讨论(0)
  • I had the same issue when login, it says: Unpermitted parameters: password, remember_me. and because i have any controller that inheriting Devise::SessionsController, so i use my own parameter sanitizer.

    here is what i do:

    Create a file in '#{Rails.root}/lib' fold, my is hzsapa_parameter_sanitizer.rb and required in config/application.rb, then override devise_parameter_sanitizer method in application_controller.rb

    lib/hzsapa_parameter_sanitizer.rb

    class HzsapaParameterSanitizer < Devise::ParameterSanitizer
      def sign_in
        default_params.permit(auth_keys + [:password, :remember_me])
      end
    end
    

    You can override those method depends on your issue:

    def sign_in
      default_params.permit(auth_keys)
    end
    
    def sign_up
      default_params.permit(auth_keys + [:password, :password_confirmation])
    end
    
    def account_update
      default_params.permit(auth_keys + [:password, :password_confirmation,    :current_password])
    end
    

    config/application.rb

    require "hzsapa_parameter_sanitizer"
    

    app/application_controller.rb

    class ApplicationController < ActionController::Base
      # Prevent CSRF attacks by raising an exception.
      # For APIs, you may want to use :null_session instead.
      protect_from_forgery with: :exception
    
      def devise_parameter_sanitizer
        @devise_parameter_sanitizer ||= if defined?(ActionController::StrongParameters)
                                          HzsapaParameterSanitizer.new(resource_class, resource_name, params)
                                        else
                                          Devise::BaseSanitizer.new(resource_class, resource_name, params)
                                        end
      end
    end
    

    Edit: i just found the solution in devise README, you can follow it here

    0 讨论(0)
  • 2021-01-02 20:18

    I had the exact same issue and overriding sign_up_params did work for me

    def sign_up_params
       params.require(:user).permit(:email, :password, :password_confirmation, :other, :etc)
    end
    

    of course, the difference is in that mine are just scalar values, while you're trying to mass assign a relation... I guess that's where you should look for.

    By the way, the documentations is still inexistint in this topic (too new), and code commnents suggest to override devise_parameter_sanitizer, which isn't necessary.

    0 讨论(0)
提交回复
热议问题