summaryrefslogtreecommitdiff
path: root/app/services/personal_access_tokens/revoke_service.rb
diff options
context:
space:
mode:
Diffstat (limited to 'app/services/personal_access_tokens/revoke_service.rb')
-rw-r--r--app/services/personal_access_tokens/revoke_service.rb36
1 files changed, 36 insertions, 0 deletions
diff --git a/app/services/personal_access_tokens/revoke_service.rb b/app/services/personal_access_tokens/revoke_service.rb
new file mode 100644
index 00000000000..16ba42bd317
--- /dev/null
+++ b/app/services/personal_access_tokens/revoke_service.rb
@@ -0,0 +1,36 @@
+# frozen_string_literal: true
+
+module PersonalAccessTokens
+ class RevokeService
+ attr_reader :token, :current_user
+
+ def initialize(current_user = nil, params = { token: nil })
+ @current_user = current_user
+ @token = params[:token]
+ end
+
+ def execute
+ return ServiceResponse.error(message: 'Not permitted to revoke') unless revocation_permitted?
+
+ if token.revoke!
+ ServiceResponse.success(message: success_message)
+ else
+ ServiceResponse.error(message: error_message)
+ end
+ end
+
+ private
+
+ def error_message
+ _("Could not revoke personal access token %{personal_access_token_name}.") % { personal_access_token_name: token.name }
+ end
+
+ def success_message
+ _("Revoked personal access token %{personal_access_token_name}!") % { personal_access_token_name: token.name }
+ end
+
+ def revocation_permitted?
+ Ability.allowed?(current_user, :revoke_token, token)
+ end
+ end
+end