我已将 Rolify gem 添加到我的项目中并成功初始化它。我面临一个奇怪的问题?
用户对象具有用户和管理员角色。
[1] pry(#<API::V1::PostPolicy>)> current_user.roles
=> [#<API::V1::Role:0x007fb70602be48
id: "19810121-ea16-4d86-b36c-475fad0f7dec",
name: "user",
resource_id: nil,
resource_type: nil,
created_at: Thu, 02 Apr 2015 02:05:27 UTC +00:00,
updated_at: Thu, 02 Apr 2015 02:05:27 UTC +00:00>,
#<API::V1::Role:0x007fb705ee6858
id: "a51c59e2-9dd0-4838-b159-1af11f7db15d",
name: "admin",
resource_id: nil,
resource_type: nil,
created_at: Thu, 02 Apr 2015 02:05:27 UTC +00:00,
updated_at: Thu, 02 Apr 2015 02:05:27 UTC +00:00>]
当我查询管理员角色时,我看到了一个奇怪的行为。
[2] pry(#<API::V1::PostPolicy>)> current_user.has_role? :admin
=> false
我正在尝试使用 Pundit 和 Rolify 执行策略,上述输出来自策略测试。
五
更新
我正在使用带有 rolify 的 UUID。rolify 的迁移如下。
class RolifyCreateAPIV1Roles < ActiveRecord::Migration
def change
create_table :api_v1_roles, id: :uuid do |t|
t.string :name
t.uuid :resource_id
t.string :resource_type
t.timestamps
end
create_table(:api_v1_users_api_v1_roles, :id => false) do |t|
t.uuid :user_id
t.uuid :role_id
end
add_index(:api_v1_roles, :name)
add_index(:api_v1_roles, [ :name, :resource_type, :resource_id ])
add_index(:api_v1_users_api_v1_roles, [ :user_id, :role_id ])
end
end