web-dev-qa-db-ja.com

Rails appのDeviseビュー/モデルに追加のフィールドと検証を追加する

デフォルトの devise ビューを次のように生成しました:

Rails generate devise:views

次に、usernameフィールドをviews/devise/registrations/new.html.erbフォームに追加しました。

現在、emailpasswordの検証のみが行われます。 usernameフィールドの存在と一意性を検証するにはどうすればよいですか? Userモデルに何かを追加する必要がありますか?

17
jkvor

他の回答で言及されているチュートリアルの両方を使用しました Railscast#21Devise Wiki 。ただし、私が知る限り、ユーザー名フィールドの存在や一意性を検証する方法を明示的に述べていません。

簡単な移行でユーザー名を追加した場合-

Rails generate migration addUsernameToUser username:string

次に、deviseはそのフィールドに対して特別なことを何も行わないため、ユーザーモデルに検証と一意性のチェックを自分で追加する必要があります。

class User < ActiveRecord::Base
...
  validates_presence_of :username
  validates_uniqueness_of :username

ただし、RailsCast#209を見ると、ユーザーモデルの作成に使用される移行の例があります。

class DeviseCreateUsers < ActiveRecord::Migration  
  def self.up  
    create_table(:users) do |t|  
      t.database_authenticatable :null => false  
      # t.confirmable  
      t.recoverable  
      t.rememberable  
      t.trackable  
      # t.lockable :lock_strategy => :failed_attempts, :unlock_strategy => :both  

      t.timestamps  
    end  

    add_index :users, :email,                :unique => true  
    # add_index :users, :confirmation_token,   :unique => true  
    add_index :users, :reset_password_token, :unique => true  
    # add_index :users, :unlock_token,         :unique => true  
  end  

  def self.down  
    drop_table :users  
  end  
end  

ここで、ユーザーの電子メールは一意として定義されていることに注意してください。おそらく、これと同じ構文を使用してユーザー名が追加された場合、デバイスの魔法が存在感と一意性を処理します。

20
lashleigh

Rails 4と強力なパラメーター

上記に加えて、次の方法でビューを生成する必要がありました。

$ Rails g devise:views

次に、devise.rbに次を追加します。

config.scoped_views = true

最後に、sign_upに対して許可されるパラメーターを以下のように構成します。

class ApplicationController < ActionController::Base

  before_filter :configure_permitted_parameters, if: :devise_controller?

  protected

    def configure_permitted_parameters
      devise_parameter_sanitizer.for(:sign_up) do |u|
        u.permit :username, :email, :password, :password_confirmation
      end
    end
end

これはDevise Docで説明されています

また、usernameの検証は次のとおりです。

validates :username, presence: true
validates :username, uniqueness: true, if: -> { self.username.present? }

私は2行を使用しているので、usernameが空白の場合、エラーは1つだけ発生します。

14
ecoologic

ログインを取得してユーザー名が空白かどうかを確認したり、ユーザーが同じユーザー名を持つことができないことを確認したりする方法を誰かが疑問に思っている場合。私はこれを理解しようとかなりの時間を費やしました、そして、私は追加する必要がありました:

validates_uniqueness_of :username, case_sensitive: false
validates_presence_of :username

app/models /のuser.rbファイルに

ここにドキュメントがあります... https://api.rubyonrails.org/classes/ActiveRecord/Validations/ClassMethods.html

これで、必要なエラーがスローされます。私は最初にuniquness_ofを見つけ、次に戻って何時間もかけて空白のフィールドをチェックする方法を見つけ、それが他のフィールドと同じドキュメントにあることを見つけたので、ばかみたいに感じます...私は初心者です。

次に、エラーメッセージがdevise.en.ymlにないため、エラーメッセージを変更する方法を理解します。

0
Curtis M