こんにちは、私は、特定のユーザーがアクセスできるリソースを制限する Ruby on Rails の認証ライブラリである CanCanCan gem を使用しています。ただし、ユーザーがサインアップすると、「管理者」や「禁止」を含むすべてのオプションが表示されます。これらの 2 つのチェックボックスを非表示にして、「顧客」と「シッター」を残します。どうすればいいですか?
user.rb
class User < ActiveRecord::Base
ROLES = %i[admin sitter customer banned]
def roles=(roles)
roles = [*roles].map { |r| r.to_sym }
self.roles_mask = (roles & ROLES).map { |r| 2**ROLES.index(r) }.inject(0, :+)
end
def roles
ROLES.reject do |r|
((roles_mask.to_i || 0) & 2**ROLES.index(r)).zero?
end
end
def has_role?(role)
roles.include?(role)
end
edit.html.erb
<% for role in User::ROLES %>
<%= check_box_tag "user[roles][#{role}]", role, @user.roles.include?(role), {:name => "user[roles][]"}%>
<%= label_tag "user_roles_#{role}", role.to_s.humanize %><br />
<% end %>
<%= hidden_field_tag "user[roles][]", "" %>
</div>
</div>