25 lines
1 KiB
Ruby
25 lines
1 KiB
Ruby
|
# frozen_string_literal: true
|
||
|
|
||
|
class UpdateContainerRegistryInfoService
|
||
|
def execute
|
||
|
registry_config = Gitlab.config.registry
|
||
|
return unless registry_config.enabled && registry_config.api_url.presence
|
||
|
|
||
|
# registry_info will query the /v2 route of the registry API. This route
|
||
|
# requires authentication, but not authorization (the response has no body,
|
||
|
# only headers that show the version of the registry). There might be no
|
||
|
# associated user when running this (e.g. from a rake task or a cron job),
|
||
|
# so we need to generate a valid JWT token with no access permissions to
|
||
|
# authenticate as a trusted client.
|
||
|
token = Auth::ContainerRegistryAuthenticationService.access_token([], [])
|
||
|
client = ContainerRegistry::Client.new(registry_config.api_url, token: token)
|
||
|
info = client.registry_info
|
||
|
|
||
|
Gitlab::CurrentSettings.update!(
|
||
|
container_registry_vendor: info[:vendor] || '',
|
||
|
container_registry_version: info[:version] || '',
|
||
|
container_registry_features: info[:features] || []
|
||
|
)
|
||
|
end
|
||
|
end
|