Добавление дополнительного поля и проверки для создания представления/модели в приложении Rails

Я создал по умолчанию devise с помощью:

rails generate devise:views

Затем я добавил поле username в форму views/devise/registrations/new.html.erb.

В настоящее время выполняется только проверка email и password. Как проверить наличие и уникальность поля username? Нужно ли добавить что-то в модель User?

Ответы

Ответ 1

Я использовал оба руководства, упомянутые в других ответах, Railscast # 210 и Devise Wiki. Однако, насколько я могу судить, они явно не говорят, как проверить наличие и/или уникальность поля имени пользователя.

Если вы добавили имя пользователя с простой миграцией -

rails generate migration addUsernameToUser username:string

Затем разработчик не делает ничего особенного с этим полем, поэтому вам нужно добавить проверки для проверки и уникальности самостоятельно в модели User.

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

Однако, если вы посмотрите на RailsCast # 209, есть пример миграции, используемой для создания модели User.

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  

Обратите внимание, что электронная почта пользователей определяется как уникальная. Возможно, если бы имя пользователя было добавлено с использованием этого же синтаксиса, тогда разработка магии позаботится о наличии и уникальности.

Ответ 2

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? }

Я использую две строки, поэтому, если username пусто, я получаю только одну ошибку.

Ответ 3

Я думаю, эта ссылка также будет полезной для понимания части валидации Devise

Ответ 4

Если кому-то интересно, как получить логин для проверки имени пользователя, если оно пустое или чтобы пользователи не могли иметь одно и то же имя пользователя. Я потратил немало часы, пытаясь понять это, и в неде мне нужно было только добавить:

validates_uniqueness_of :username, case_sensitive: false
validates_presence_of :username

в ваш файл user.rb в приложении /models/

Вот документы... https://api.rubyonrails.org/classes/ActiveRecord/Validations/ClassMethods.html

Это теперь выбрасывает ошибки, которые мне нужны. Я чувствую себя идиотом, потому что сначала я нашел uniquness_of, потом вернулся и провел часы, пытаясь выяснить, как проверить наличие пустого поля, а затем обнаружил, что оно находится в той же документации, что и другие... Я нуб.

Теперь разберемся, как изменить сообщения об ошибках, поскольку их нет в devise.en.yml