about summary refs log tree commit diff
path: root/app/policies/user_role_policy.rb
diff options
context:
space:
mode:
Diffstat (limited to 'app/policies/user_role_policy.rb')
-rw-r--r--app/policies/user_role_policy.rb19
1 files changed, 19 insertions, 0 deletions
diff --git a/app/policies/user_role_policy.rb b/app/policies/user_role_policy.rb
new file mode 100644
index 000000000..6144a0ec4
--- /dev/null
+++ b/app/policies/user_role_policy.rb
@@ -0,0 +1,19 @@
+# frozen_string_literal: true
+
+class UserRolePolicy < ApplicationPolicy
+  def index?
+    role.can?(:manage_roles)
+  end
+
+  def create?
+    role.can?(:manage_roles)
+  end
+
+  def update?
+    role.can?(:manage_roles) && (role.overrides?(record) || role.id == record.id)
+  end
+
+  def destroy?
+    !record.everyone? && role.can?(:manage_roles) && role.overrides?(record) && role.id != record.id
+  end
+end