将设计认证纳入已有的用户结构中?

Kev*_*vin 7 authentication passwords rubygems ruby-on-rails devise

我有一个功能齐全的身份验证系统,其用户表有超过50列.它很简单,但它使用salt进行散列加密,使用电子邮件而不是用户名,并且还有两种不同类型的用户和管理员.

我希望将Devise身份验证合并到我的应用程序中,以增强电子邮件验证,忘记密码,记住我的令牌等额外部分......我只是想看看是否有人在收集时遇到任何建议或问题设计一个已经存在的用户结构.我的用户模型中的基本字段是:

  t.string    :first_name, :null => false
  t.string    :last_name, :null => false
  t.string    :email, :null => false
  t.string    :hashed_password
  t.string    :salt
  t.boolean   :is_userA, :default => false
  t.boolean   :is_userB, :default => false
  t.boolean   :is_admin, :default => false
  t.boolean :active, :default => true
  t.timestamps
Run Code Online (Sandbox Code Playgroud)

为了便于参考,这里是迁移的Devise字段:

  t.database_authenticatable :null => false
  t.confirmable
  t.recoverable
  t.rememberable
  t.trackable

  add_index "users", ["confirmation_token"], :name => "index_users_on_confirmation_token", :unique => true
  add_index "users", ["email"], :name => "index_users_on_email", :unique => true
  add_index "users", ["reset_password_token"], :name => "index_users_on_reset_password_token", :unique => true
Run Code Online (Sandbox Code Playgroud)

最终会变成架构中的这些实际字段:

t.string   "email",                               :default => "", :null => false
t.string   "encrypted_password",   :limit => 128, :default => "", :null => false
t.string   "password_salt",                       :default => "", :null => false
t.string   "confirmation_token"
t.datetime "confirmed_at"
t.datetime "confirmation_sent_at"
t.string   "reset_password_token"
t.string   "remember_token"
t.datetime "remember_created_at"
t.integer  "sign_in_count",                       :default => 0
t.datetime "current_sign_in_at"
t.datetime "last_sign_in_at"
t.string   "current_sign_in_ip"
t.string   "last_sign_in_ip"
t.datetime "created_at"
t.datetime "updated_at"
Run Code Online (Sandbox Code Playgroud)

你们推荐什么?我只是从迁移中删除电子邮件,hashed_pa​​ssword和salt并放入5 Devise迁移字段,一切都会好或我还需要做其他事情吗?

编辑:

我自己开始尝试这个并且已经遇到了一些问题.我将上面显示的设计迁移字段添加到我现有的用户模型中,现在当我运行我的种子文件时,它给了我这个Postgresql错误:

ERROR: duplicate key value violates unique constraint "index_users_on_email"
Run Code Online (Sandbox Code Playgroud)

我的种子档案:

initial_usersA = User.create!(
[
{
    :first_name => "John", 
    :last_name => "Doe",
    :email => "johndoe@gmail.com",
    :is_userA => true,
    :is_userB => false,
            :is_admin => true,
    :password => "password",
    :password_confirmation => "password"
},
{
    :first_name => "Jane", 
    :last_name => "Smith",
    :email => "janesmith@gmail.com",
    :is_userA => true,
    :is_userB => false,
            :is_admin => true,
    :password => "password",
    :password_confirmation => "password"
}
Run Code Online (Sandbox Code Playgroud)

用户模型:

devise :registerable, :authenticatable, :recoverable,
     :rememberable, :trackable, :validatable
attr_accessor :password_confirmation, :email, :password
Run Code Online (Sandbox Code Playgroud)

堆栈跟踪显示电子邮件由于某种原因显然没有被其他变量输入...尽管种子文件中的其他内容都显示在实际查询中,但是电子邮件是''由于某种原因,即使它是明确定义的

Nad*_*der 0

我会删除电子邮件架构中的 :default => "" 。devise 默认对电子邮件施加唯一约束,因此您不希望默认为空字符串