DockerRegistryConfigAuthentication Class — spring-boot Architecture
Architecture documentation for the DockerRegistryConfigAuthentication class in DockerRegistryConfigAuthentication.java from the spring-boot codebase.
Entity Profile
Relationship Graph
Source Code
buildpack/spring-boot-buildpack-platform/src/main/java/org/springframework/boot/buildpack/platform/docker/configuration/DockerRegistryConfigAuthentication.java lines 40–157
class DockerRegistryConfigAuthentication implements DockerRegistryAuthentication {
private static final String DEFAULT_DOMAIN = "docker.io";
private static final String INDEX_URL = "https://index.docker.io/v1/";
static Map<String, Credential> credentialFromHelperCache = new ConcurrentHashMap<>();
private final @Nullable DockerRegistryAuthentication fallback;
private final BiConsumer<String, Exception> credentialHelperExceptionHandler;
private final Function<String, @Nullable CredentialHelper> credentialHelperFactory;
private final DockerConfig dockerConfig;
DockerRegistryConfigAuthentication(@Nullable DockerRegistryAuthentication fallback,
BiConsumer<String, Exception> credentialHelperExceptionHandler) {
this(fallback, credentialHelperExceptionHandler, Environment.SYSTEM,
(helper) -> new CredentialHelper("docker-credential-" + helper));
}
DockerRegistryConfigAuthentication(@Nullable DockerRegistryAuthentication fallback,
BiConsumer<String, Exception> credentialHelperExceptionHandler, Environment environment,
Function<String, @Nullable CredentialHelper> credentialHelperFactory) {
this.fallback = fallback;
this.credentialHelperExceptionHandler = credentialHelperExceptionHandler;
this.dockerConfig = DockerConfigurationMetadata.from(environment).getConfiguration();
this.credentialHelperFactory = credentialHelperFactory;
}
@Override
public @Nullable String getAuthHeader() {
return getAuthHeader(null);
}
@Override
public @Nullable String getAuthHeader(@Nullable ImageReference imageReference) {
String serverUrl = getServerUrl(imageReference);
DockerRegistryAuthentication authentication = getAuthentication(serverUrl);
return (authentication != null) ? authentication.getAuthHeader(imageReference) : null;
}
private @Nullable String getServerUrl(@Nullable ImageReference imageReference) {
String domain = (imageReference != null) ? imageReference.getDomain() : null;
return (!DEFAULT_DOMAIN.equals(domain)) ? domain : INDEX_URL;
}
private @Nullable DockerRegistryAuthentication getAuthentication(@Nullable String serverUrl) {
Credential credentialsFromHelper = getCredentialsFromHelper(serverUrl);
Map.Entry<String, Auth> authConfigEntry = getAuthConfigEntry(serverUrl);
Auth authConfig = (authConfigEntry != null) ? authConfigEntry.getValue() : null;
if (credentialsFromHelper != null) {
return getAuthentication(credentialsFromHelper, authConfig, serverUrl);
}
if (authConfig != null) {
Assert.state(authConfigEntry != null, "'authConfigEntry' must not be null");
String username = authConfig.getUsername();
String password = authConfig.getPassword();
Assert.state(username != null, "'username' must not be null");
Assert.state(password != null, "'password' must not be null");
return DockerRegistryAuthentication.user(username, password, authConfigEntry.getKey(),
authConfig.getEmail());
}
return this.fallback;
}
private DockerRegistryAuthentication getAuthentication(Credential credentialsFromHelper, @Nullable Auth authConfig,
@Nullable String serverUrl) {
if (credentialsFromHelper.isIdentityToken()) {
return DockerRegistryAuthentication.token(credentialsFromHelper.getSecret());
}
String username = credentialsFromHelper.getUsername();
String password = credentialsFromHelper.getSecret();
String serverAddress = (StringUtils.hasLength(credentialsFromHelper.getServerUrl()))
? credentialsFromHelper.getServerUrl() : serverUrl;
String email = (authConfig != null) ? authConfig.getEmail() : null;
return DockerRegistryAuthentication.user(username, password, serverAddress, email);
}
private @Nullable Credential getCredentialsFromHelper(@Nullable String serverUrl) {
return StringUtils.hasLength(serverUrl)
? credentialFromHelperCache.computeIfAbsent(serverUrl, this::computeCredentialsFromHelper) : null;
}
private @Nullable Credential computeCredentialsFromHelper(String serverUrl) {
CredentialHelper credentialHelper = getCredentialHelper(serverUrl);
if (credentialHelper != null) {
try {
return credentialHelper.get(serverUrl);
}
catch (Exception ex) {
String message = "Error retrieving credentials for '%s' due to: %s".formatted(serverUrl,
ex.getMessage());
this.credentialHelperExceptionHandler.accept(message, ex);
}
}
return null;
}
private @Nullable CredentialHelper getCredentialHelper(String serverUrl) {
String name = this.dockerConfig.getCredHelpers().getOrDefault(serverUrl, this.dockerConfig.getCredsStore());
return (StringUtils.hasLength(name)) ? this.credentialHelperFactory.apply(name) : null;
}
private Map.@Nullable Entry<String, Auth> getAuthConfigEntry(@Nullable String serverUrl) {
if (serverUrl == null) {
return null;
}
for (Map.Entry<String, Auth> candidate : this.dockerConfig.getAuths().entrySet()) {
if (candidate.getKey().equals(serverUrl) || candidate.getKey().endsWith("://" + serverUrl)) {
return candidate;
}
}
return null;
}
}
Domain
Source
Analyze Your Own Codebase
Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.
Try Supermodel Free