summaryrefslogtreecommitdiff
path: root/app/policies/personal_access_token_policy.rb
diff options
context:
space:
mode:
Diffstat (limited to 'app/policies/personal_access_token_policy.rb')
-rw-r--r--app/policies/personal_access_token_policy.rb10
1 files changed, 10 insertions, 0 deletions
diff --git a/app/policies/personal_access_token_policy.rb b/app/policies/personal_access_token_policy.rb
new file mode 100644
index 00000000000..1e5404b7822
--- /dev/null
+++ b/app/policies/personal_access_token_policy.rb
@@ -0,0 +1,10 @@
+# frozen_string_literal: true
+
+class PersonalAccessTokenPolicy < BasePolicy
+ condition(:is_owner) { user && subject.user_id == user.id }
+
+ rule { (is_owner | admin) & ~blocked }.policy do
+ enable :read_token
+ enable :revoke_token
+ end
+end