2020-05-24 23:13:21 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
module Projects
|
|
|
|
module Settings
|
|
|
|
class AccessTokensController < Projects::ApplicationController
|
|
|
|
include ProjectsHelper
|
|
|
|
|
|
|
|
before_action :check_feature_availability
|
|
|
|
|
2021-01-03 14:25:43 +05:30
|
|
|
feature_category :authentication_and_authorization
|
|
|
|
|
2020-05-24 23:13:21 +05:30
|
|
|
def index
|
|
|
|
@project_access_token = PersonalAccessToken.new
|
|
|
|
set_index_vars
|
|
|
|
end
|
|
|
|
|
|
|
|
def create
|
|
|
|
token_response = ResourceAccessTokens::CreateService.new(current_user, @project, create_params).execute
|
|
|
|
|
|
|
|
if token_response.success?
|
|
|
|
@project_access_token = token_response.payload[:access_token]
|
|
|
|
PersonalAccessToken.redis_store!(key_identity, @project_access_token.token)
|
|
|
|
|
|
|
|
redirect_to namespace_project_settings_access_tokens_path, notice: _("Your new project access token has been created.")
|
|
|
|
else
|
|
|
|
render :index
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def revoke
|
|
|
|
@project_access_token = finder.find(params[:id])
|
|
|
|
revoked_response = ResourceAccessTokens::RevokeService.new(current_user, @project, @project_access_token).execute
|
|
|
|
|
|
|
|
if revoked_response.success?
|
|
|
|
flash[:notice] = _("Revoked project access token %{project_access_token_name}!") % { project_access_token_name: @project_access_token.name }
|
|
|
|
else
|
|
|
|
flash[:alert] = _("Could not revoke project access token %{project_access_token_name}.") % { project_access_token_name: @project_access_token.name }
|
|
|
|
end
|
|
|
|
|
|
|
|
redirect_to namespace_project_settings_access_tokens_path
|
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
def check_feature_availability
|
|
|
|
render_404 unless project_access_token_available?(@project)
|
|
|
|
end
|
|
|
|
|
|
|
|
def create_params
|
|
|
|
params.require(:project_access_token).permit(:name, :expires_at, scopes: [])
|
|
|
|
end
|
|
|
|
|
|
|
|
def set_index_vars
|
|
|
|
@scopes = Gitlab::Auth.resource_bot_scopes
|
|
|
|
@active_project_access_tokens = finder(state: 'active').execute
|
|
|
|
@inactive_project_access_tokens = finder(state: 'inactive', sort: 'expires_at_asc').execute
|
|
|
|
@new_project_access_token = PersonalAccessToken.redis_getdel(key_identity)
|
|
|
|
end
|
|
|
|
|
|
|
|
def finder(options = {})
|
|
|
|
PersonalAccessTokensFinder.new({ user: bot_users, impersonation: false }.merge(options))
|
|
|
|
end
|
|
|
|
|
|
|
|
def bot_users
|
|
|
|
@project.bots
|
|
|
|
end
|
|
|
|
|
|
|
|
def key_identity
|
|
|
|
"#{current_user.id}:#{@project.id}"
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|