c847f172d2
[11.4] Fix Token lookup for Git over HTTP and registry authentication See merge request gitlab/gitlabhq!2577
50 lines
931 B
Ruby
50 lines
931 B
Ruby
# frozen_string_literal: true
|
|
|
|
class PersonalAccessTokensFinder
|
|
attr_accessor :params
|
|
|
|
delegate :build, :find, :find_by, :find_by_token, to: :execute
|
|
|
|
def initialize(params = {})
|
|
@params = params
|
|
end
|
|
|
|
def execute
|
|
tokens = PersonalAccessToken.all
|
|
tokens = by_user(tokens)
|
|
tokens = by_impersonation(tokens)
|
|
by_state(tokens)
|
|
end
|
|
|
|
private
|
|
|
|
# rubocop: disable CodeReuse/ActiveRecord
|
|
def by_user(tokens)
|
|
return tokens unless @params[:user]
|
|
|
|
tokens.where(user: @params[:user])
|
|
end
|
|
# rubocop: enable CodeReuse/ActiveRecord
|
|
|
|
def by_impersonation(tokens)
|
|
case @params[:impersonation]
|
|
when true
|
|
tokens.with_impersonation
|
|
when false
|
|
tokens.without_impersonation
|
|
else
|
|
tokens
|
|
end
|
|
end
|
|
|
|
def by_state(tokens)
|
|
case @params[:state]
|
|
when 'active'
|
|
tokens.active
|
|
when 'inactive'
|
|
tokens.inactive
|
|
else
|
|
tokens
|
|
end
|
|
end
|
|
end
|