Rolify表错误(用户添加角色:admin时出现未知键错误)

15

我正在尝试设置rolify gem,但在控制台中给用户分配角色时遇到问题。

这是我的错误:

2.2.1 :007 > user.add_role :admin
ArgumentError: Unknown key: :optional.

我正在使用devise、cancancan和rolify。同时,我还在使用Koudoku gem来支持订阅付款。我怀疑这个错误可能是因为我的“subscriptions”表也有一个“user_id”列所引起的。我是否可以做些什么来纠正这个问题?
以下是我的模式。
create_table "subscriptions", force: :cascade do |t|
t.string   "stripe_id"
t.integer  "plan_id"
t.string   "last_four"
t.integer  "coupon_id"
t.string   "card_type"
t.float    "current_price"
t.integer  "user_id"
t.datetime "created_at",    null: false
t.datetime "updated_at",    null: false
end

create_table "users", force: :cascade do |t|
t.string   "email",                  default: "", null: false
t.string   "encrypted_password",     default: "", null: false
t.string   "reset_password_token"
t.datetime "reset_password_sent_at"
t.datetime "remember_created_at"
t.integer  "sign_in_count",          default: 0,  null: false
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",                          null: false
t.datetime "updated_at",                          null: false
t.string   "first_name"
t.string   "string"
t.string   "last_name"
end

 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

create_table "users_roles", id: false, force: :cascade do |t|
t.integer "user_id"
t.integer "role_id"
end

add_index "users_roles", ["user_id", "role_id"], name:   "index_users_roles_on_user_id_and_role_id"

end

谢谢。
1个回答

40

Rolify角色生成器使用以下代码生成Role模型:

class Role < ActiveRecord::Base


has_and_belongs_to_many :users, :join_table => :users_roles

  belongs_to :resource,
             :polymorphic => true,
             :optional => true

  validates :resource_type,
            :inclusion => { :in => Rolify.resource_types },
            :allow_nil => true

  scopify
end

在Rails版本5及以上,支持:optional => true参数。要避免这个问题,只需从Role model中删除该行即可。以下是最终代码供参考:

class Role < ActiveRecord::Base
  has_and_belongs_to_many :users, :join_table => :users_roles

  belongs_to :resource,
             :polymorphic => true

  validates :resource_type,
            :inclusion => { :in => Rolify.resource_types },
            :allow_nil => true

  scopify
end

3
谢谢!这是一颗非常好的宝石,但我很失望这种事情不能直接解决,特别是有这么多应用程序使用Rails版本<5。 - user2490003

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接