blob: 54766d50866c9cbcd42d67c004ff7a38caf06b77 [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
package org.apache.maven.bridge;
import javax.inject.Inject;
import javax.inject.Named;
import javax.inject.Singleton;
import java.io.File;
import java.net.MalformedURLException;
import java.net.URL;
import java.util.ArrayList;
import java.util.Collection;
import java.util.Collections;
import java.util.HashSet;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.Map;
import java.util.Set;
import org.apache.maven.RepositoryUtils;
import org.apache.maven.artifact.Artifact;
import org.apache.maven.artifact.DefaultArtifact;
import org.apache.maven.artifact.InvalidRepositoryException;
import org.apache.maven.artifact.handler.ArtifactHandler;
import org.apache.maven.artifact.handler.manager.ArtifactHandlerManager;
import org.apache.maven.artifact.repository.ArtifactRepository;
import org.apache.maven.artifact.repository.ArtifactRepositoryPolicy;
import org.apache.maven.artifact.repository.Authentication;
import org.apache.maven.artifact.repository.MavenArtifactRepository;
import org.apache.maven.artifact.repository.layout.ArtifactRepositoryLayout;
import org.apache.maven.artifact.repository.layout.ArtifactRepositoryLayout2;
import org.apache.maven.artifact.repository.layout.DefaultRepositoryLayout;
import org.apache.maven.artifact.resolver.filter.ExclusionArtifactFilter;
import org.apache.maven.artifact.versioning.InvalidVersionSpecificationException;
import org.apache.maven.artifact.versioning.VersionRange;
import org.apache.maven.execution.MavenExecutionRequest;
import org.apache.maven.model.Dependency;
import org.apache.maven.model.Plugin;
import org.apache.maven.repository.Proxy;
import org.apache.maven.settings.Mirror;
import org.eclipse.aether.RepositorySystemSession;
import org.eclipse.aether.repository.AuthenticationContext;
import org.eclipse.aether.repository.AuthenticationSelector;
import org.eclipse.aether.repository.ProxySelector;
import org.eclipse.aether.repository.RemoteRepository;
/**
*/
@Named("default")
@Singleton
public class MavenRepositorySystem {
public static final String DEFAULT_REMOTE_REPO_ID = "central";
public static final String DEFAULT_REMOTE_REPO_URL = "https://repo.maven.apache.org/maven2";
public static final String DEFAULT_LOCAL_REPO_ID = "local";
private final ArtifactHandlerManager artifactHandlerManager;
private final Map<String, ArtifactRepositoryLayout> layouts;
@Inject
public MavenRepositorySystem(
ArtifactHandlerManager artifactHandlerManager, Map<String, ArtifactRepositoryLayout> layouts) {
this.artifactHandlerManager = artifactHandlerManager;
this.layouts = layouts;
}
// DefaultProjectBuilder
public Artifact createArtifact(String groupId, String artifactId, String version, String scope, String type) {
return createArtifactX(groupId, artifactId, version, scope, type);
}
// DefaultProjectBuilder
public Artifact createProjectArtifact(String groupId, String artifactId, String metaVersionId) {
return createProjectArtifactX(groupId, artifactId, metaVersionId);
}
// DefaultProjectBuilder
public Artifact createDependencyArtifact(Dependency d) {
if (d.getVersion() == null) {
return null;
}
VersionRange versionRange;
try {
versionRange = VersionRange.createFromVersionSpec(d.getVersion());
} catch (InvalidVersionSpecificationException e) {
return null;
}
Artifact artifact = createDependencyArtifactX(
d.getGroupId(),
d.getArtifactId(),
versionRange,
d.getType(),
d.getClassifier(),
d.getScope(),
d.isOptional());
if (Artifact.SCOPE_SYSTEM.equals(d.getScope()) && d.getSystemPath() != null) {
artifact.setFile(new File(d.getSystemPath()));
}
if (!d.getExclusions().isEmpty()) {
artifact.setDependencyFilter(new ExclusionArtifactFilter(d.getExclusions()));
}
return artifact;
}
// DefaultProjectBuilder
public Artifact createExtensionArtifact(String groupId, String artifactId, String version) {
VersionRange versionRange;
try {
versionRange = VersionRange.createFromVersionSpec(version);
} catch (InvalidVersionSpecificationException e) {
return null;
}
return createExtensionArtifactX(groupId, artifactId, versionRange);
}
// DefaultProjectBuilder
public Artifact createParentArtifact(String groupId, String artifactId, String version) {
return createParentArtifactX(groupId, artifactId, version);
}
// DefaultProjectBuilder
public Artifact createPluginArtifact(Plugin plugin) {
VersionRange versionRange;
try {
String version = plugin.getVersion();
if (version == null || version.isEmpty()) {
version = "RELEASE";
}
versionRange = VersionRange.createFromVersionSpec(version);
} catch (InvalidVersionSpecificationException e) {
return null;
}
return createPluginArtifactX(plugin.getGroupId(), plugin.getArtifactId(), versionRange);
}
public void injectMirror(List<ArtifactRepository> repositories, List<Mirror> mirrors) {
if (repositories != null && mirrors != null) {
for (ArtifactRepository repository : repositories) {
Mirror mirror = getMirror(repository, mirrors);
injectMirror(repository, mirror);
}
}
}
private Mirror getMirror(RepositorySystemSession session, ArtifactRepository repository) {
if (session != null) {
org.eclipse.aether.repository.MirrorSelector selector = session.getMirrorSelector();
if (selector != null) {
RemoteRepository repo = selector.getMirror(RepositoryUtils.toRepo(repository));
if (repo != null) {
Mirror mirror = new Mirror();
mirror.setId(repo.getId());
mirror.setUrl(repo.getUrl());
mirror.setLayout(repo.getContentType());
mirror.setBlocked(repo.isBlocked());
return mirror;
}
}
}
return null;
}
public void injectMirror(RepositorySystemSession session, List<ArtifactRepository> repositories) {
if (repositories != null && session != null) {
for (ArtifactRepository repository : repositories) {
Mirror mirror = getMirror(session, repository);
injectMirror(repository, mirror);
}
}
}
private void injectMirror(ArtifactRepository repository, Mirror mirror) {
if (mirror != null) {
ArtifactRepository original = createArtifactRepository(
repository.getId(),
repository.getUrl(),
repository.getLayout(),
repository.getSnapshots(),
repository.getReleases());
repository.setMirroredRepositories(Collections.singletonList(original));
repository.setId(mirror.getId());
repository.setUrl(mirror.getUrl());
if (mirror.getLayout() != null && !mirror.getLayout().isEmpty()) {
repository.setLayout(getLayout(mirror.getLayout()));
}
repository.setBlocked(mirror.isBlocked());
}
}
private Authentication getAuthentication(RepositorySystemSession session, ArtifactRepository repository) {
if (session != null) {
AuthenticationSelector selector = session.getAuthenticationSelector();
if (selector != null) {
RemoteRepository repo = RepositoryUtils.toRepo(repository);
org.eclipse.aether.repository.Authentication auth = selector.getAuthentication(repo);
if (auth != null) {
repo = new RemoteRepository.Builder(repo)
.setAuthentication(auth)
.build();
AuthenticationContext authCtx = AuthenticationContext.forRepository(session, repo);
Authentication result = new Authentication(
authCtx.get(AuthenticationContext.USERNAME), authCtx.get(AuthenticationContext.PASSWORD));
result.setPrivateKey(authCtx.get(AuthenticationContext.PRIVATE_KEY_PATH));
result.setPassphrase(authCtx.get(AuthenticationContext.PRIVATE_KEY_PASSPHRASE));
authCtx.close();
return result;
}
}
}
return null;
}
public void injectAuthentication(RepositorySystemSession session, List<ArtifactRepository> repositories) {
if (repositories != null && session != null) {
for (ArtifactRepository repository : repositories) {
repository.setAuthentication(getAuthentication(session, repository));
}
}
}
private Proxy getProxy(RepositorySystemSession session, ArtifactRepository repository) {
if (session != null) {
ProxySelector selector = session.getProxySelector();
if (selector != null) {
RemoteRepository repo = RepositoryUtils.toRepo(repository);
org.eclipse.aether.repository.Proxy proxy = selector.getProxy(repo);
if (proxy != null) {
Proxy p = new Proxy();
p.setHost(proxy.getHost());
p.setProtocol(proxy.getType());
p.setPort(proxy.getPort());
if (proxy.getAuthentication() != null) {
repo = new RemoteRepository.Builder(repo)
.setProxy(proxy)
.build();
AuthenticationContext authCtx = AuthenticationContext.forProxy(session, repo);
p.setUserName(authCtx.get(AuthenticationContext.USERNAME));
p.setPassword(authCtx.get(AuthenticationContext.PASSWORD));
p.setNtlmDomain(authCtx.get(AuthenticationContext.NTLM_DOMAIN));
p.setNtlmHost(authCtx.get(AuthenticationContext.NTLM_WORKSTATION));
authCtx.close();
}
return p;
}
}
}
return null;
}
public void injectProxy(RepositorySystemSession session, List<ArtifactRepository> repositories) {
if (repositories != null && session != null) {
for (ArtifactRepository repository : repositories) {
repository.setProxy(getProxy(session, repository));
}
}
}
private ArtifactRepositoryLayout getLayout(String id) {
return layouts.get(id);
}
//
// Taken from LegacyRepositorySystem
//
public static org.apache.maven.model.Repository fromSettingsRepository(
org.apache.maven.settings.Repository settingsRepository) {
org.apache.maven.model.Repository modelRepository = new org.apache.maven.model.Repository();
modelRepository.setId(settingsRepository.getId());
modelRepository.setLayout(settingsRepository.getLayout());
modelRepository.setName(settingsRepository.getName());
modelRepository.setUrl(settingsRepository.getUrl());
modelRepository.setReleases(fromSettingsRepositoryPolicy(settingsRepository.getReleases()));
modelRepository.setSnapshots(fromSettingsRepositoryPolicy(settingsRepository.getSnapshots()));
return modelRepository;
}
public static org.apache.maven.model.RepositoryPolicy fromSettingsRepositoryPolicy(
org.apache.maven.settings.RepositoryPolicy settingsRepositoryPolicy) {
org.apache.maven.model.RepositoryPolicy modelRepositoryPolicy = new org.apache.maven.model.RepositoryPolicy();
if (settingsRepositoryPolicy != null) {
modelRepositoryPolicy.setEnabled(settingsRepositoryPolicy.isEnabled());
modelRepositoryPolicy.setUpdatePolicy(settingsRepositoryPolicy.getUpdatePolicy());
modelRepositoryPolicy.setChecksumPolicy(settingsRepositoryPolicy.getChecksumPolicy());
}
return modelRepositoryPolicy;
}
public static ArtifactRepository buildArtifactRepository(org.apache.maven.settings.Repository repo)
throws InvalidRepositoryException {
return buildArtifactRepository(fromSettingsRepository(repo));
}
public static ArtifactRepository buildArtifactRepository(org.apache.maven.model.Repository repo)
throws InvalidRepositoryException {
if (repo != null) {
String id = repo.getId();
if (id == null || id.isEmpty()) {
throw new InvalidRepositoryException("Repository identifier missing", "");
}
String url = repo.getUrl();
if (url == null || url.isEmpty()) {
throw new InvalidRepositoryException("URL missing for repository " + id, id);
}
ArtifactRepositoryPolicy snapshots = buildArtifactRepositoryPolicy(repo.getSnapshots());
ArtifactRepositoryPolicy releases = buildArtifactRepositoryPolicy(repo.getReleases());
ArtifactRepositoryLayout layout = new DefaultRepositoryLayout();
return createArtifactRepository(id, url, layout, snapshots, releases);
} else {
return null;
}
}
public static ArtifactRepositoryPolicy buildArtifactRepositoryPolicy(
org.apache.maven.model.RepositoryPolicy policy) {
boolean enabled = true;
String updatePolicy = null;
String checksumPolicy = null;
if (policy != null) {
enabled = policy.isEnabled();
if (policy.getUpdatePolicy() != null) {
updatePolicy = policy.getUpdatePolicy();
}
if (policy.getChecksumPolicy() != null) {
checksumPolicy = policy.getChecksumPolicy();
}
}
return new ArtifactRepositoryPolicy(enabled, updatePolicy, checksumPolicy);
}
public ArtifactRepository createArtifactRepository(
String id,
String url,
String layoutId,
ArtifactRepositoryPolicy snapshots,
ArtifactRepositoryPolicy releases)
throws InvalidRepositoryException {
ArtifactRepositoryLayout layout = layouts.get(layoutId);
checkLayout(id, layoutId, layout);
return createArtifactRepository(id, url, layout, snapshots, releases);
}
private void checkLayout(String repositoryId, String layoutId, ArtifactRepositoryLayout layout)
throws InvalidRepositoryException {
if (layout == null) {
throw new InvalidRepositoryException(
String.format("Cannot find ArtifactRepositoryLayout instance for: %s %s", layoutId, repositoryId),
repositoryId);
}
}
public static ArtifactRepository createArtifactRepository(
String id,
String url,
ArtifactRepositoryLayout repositoryLayout,
ArtifactRepositoryPolicy snapshots,
ArtifactRepositoryPolicy releases) {
if (snapshots == null) {
snapshots = new ArtifactRepositoryPolicy();
}
if (releases == null) {
releases = new ArtifactRepositoryPolicy();
}
ArtifactRepository repository;
if (repositoryLayout instanceof ArtifactRepositoryLayout2) {
repository = ((ArtifactRepositoryLayout2) repositoryLayout)
.newMavenArtifactRepository(id, url, snapshots, releases);
} else {
repository = new MavenArtifactRepository(id, url, repositoryLayout, snapshots, releases);
}
return repository;
}
// ArtifactFactory
private Artifact createArtifactX(String groupId, String artifactId, String version, String scope, String type) {
return createArtifactX(groupId, artifactId, version, scope, type, null, null);
}
private Artifact createDependencyArtifactX(
String groupId,
String artifactId,
VersionRange versionRange,
String type,
String classifier,
String scope,
boolean optional) {
return createArtifactX(groupId, artifactId, versionRange, type, classifier, scope, null, optional);
}
private Artifact createProjectArtifactX(String groupId, String artifactId, String version) {
return createProjectArtifactX(groupId, artifactId, version, null);
}
private Artifact createParentArtifactX(String groupId, String artifactId, String version) {
return createProjectArtifactX(groupId, artifactId, version);
}
private Artifact createPluginArtifactX(String groupId, String artifactId, VersionRange versionRange) {
return createArtifactX(groupId, artifactId, versionRange, "maven-plugin", null, Artifact.SCOPE_RUNTIME, null);
}
private Artifact createProjectArtifactX(String groupId, String artifactId, String version, String scope) {
return createArtifactX(groupId, artifactId, version, scope, "pom");
}
private Artifact createExtensionArtifactX(String groupId, String artifactId, VersionRange versionRange) {
return createArtifactX(groupId, artifactId, versionRange, "jar", null, Artifact.SCOPE_RUNTIME, null);
}
private Artifact createArtifactX(
String groupId,
String artifactId,
String version,
String scope,
String type,
String classifier,
String inheritedScope) {
VersionRange versionRange = null;
if (version != null) {
versionRange = VersionRange.createFromVersion(version);
}
return createArtifactX(groupId, artifactId, versionRange, type, classifier, scope, inheritedScope);
}
private Artifact createArtifactX(
String groupId,
String artifactId,
VersionRange versionRange,
String type,
String classifier,
String scope,
String inheritedScope) {
return createArtifactX(groupId, artifactId, versionRange, type, classifier, scope, inheritedScope, false);
}
@SuppressWarnings("checkstyle:parameternumber")
private Artifact createArtifactX(
String groupId,
String artifactId,
VersionRange versionRange,
String type,
String classifier,
String scope,
String inheritedScope,
boolean optional) {
String desiredScope = Artifact.SCOPE_RUNTIME;
if (inheritedScope == null) {
desiredScope = scope;
} else if (Artifact.SCOPE_TEST.equals(scope) || Artifact.SCOPE_PROVIDED.equals(scope)) {
return null;
} else if (Artifact.SCOPE_COMPILE.equals(scope) && Artifact.SCOPE_COMPILE.equals(inheritedScope)) {
// added to retain compile artifactScope. Remove if you want compile inherited as runtime
desiredScope = Artifact.SCOPE_COMPILE;
}
if (Artifact.SCOPE_TEST.equals(inheritedScope)) {
desiredScope = Artifact.SCOPE_TEST;
}
if (Artifact.SCOPE_PROVIDED.equals(inheritedScope)) {
desiredScope = Artifact.SCOPE_PROVIDED;
}
if (Artifact.SCOPE_SYSTEM.equals(scope)) {
// system scopes come through unchanged...
desiredScope = Artifact.SCOPE_SYSTEM;
}
ArtifactHandler handler = artifactHandlerManager.getArtifactHandler(type);
return new DefaultArtifact(
groupId, artifactId, versionRange, desiredScope, type, classifier, handler, optional);
}
//
// Code taken from LegacyRepositorySystem
//
public ArtifactRepository createDefaultRemoteRepository() throws Exception {
return createDefaultRemoteRepository(null);
}
public ArtifactRepository createDefaultRemoteRepository(MavenExecutionRequest request) throws Exception {
return createRepository(
MavenRepositorySystem.DEFAULT_REMOTE_REPO_URL,
MavenRepositorySystem.DEFAULT_REMOTE_REPO_ID,
true,
ArtifactRepositoryPolicy.UPDATE_POLICY_DAILY,
false,
ArtifactRepositoryPolicy.UPDATE_POLICY_DAILY,
ArtifactRepositoryPolicy.DEFAULT_CHECKSUM_POLICY);
}
public ArtifactRepository createRepository(
String url,
String repositoryId,
boolean releases,
String releaseUpdates,
boolean snapshots,
String snapshotUpdates,
String checksumPolicy)
throws InvalidRepositoryException {
ArtifactRepositoryPolicy snapshotsPolicy =
new ArtifactRepositoryPolicy(snapshots, snapshotUpdates, checksumPolicy);
ArtifactRepositoryPolicy releasesPolicy =
new ArtifactRepositoryPolicy(releases, releaseUpdates, checksumPolicy);
return createArtifactRepository(repositoryId, url, "default", snapshotsPolicy, releasesPolicy);
}
public Set<String> getRepoIds(List<ArtifactRepository> repositories) {
Set<String> repoIds = new HashSet<>();
if (repositories != null) {
for (ArtifactRepository repository : repositories) {
repoIds.add(repository.getId());
}
}
return repoIds;
}
/**
* Source from org.apache.maven.repository.legacy.LegacyRepositorySystem#getEffectiveRepositories
*
* @param repositories a list of repositories
* @return corresponding effective repositories
* @since 3.6.1
*/
public List<ArtifactRepository> getEffectiveRepositories(List<ArtifactRepository> repositories) {
if (repositories == null) {
return null;
}
Map<String, List<ArtifactRepository>> reposByKey = new LinkedHashMap<>();
for (ArtifactRepository repository : repositories) {
String key = repository.getId();
List<ArtifactRepository> aliasedRepos = reposByKey.computeIfAbsent(key, k -> new ArrayList<>());
aliasedRepos.add(repository);
}
List<ArtifactRepository> effectiveRepositories = new ArrayList<>();
for (List<ArtifactRepository> aliasedRepos : reposByKey.values()) {
List<ArtifactRepository> mirroredRepos = new ArrayList<>();
List<ArtifactRepositoryPolicy> releasePolicies = new ArrayList<>(aliasedRepos.size());
for (ArtifactRepository aliasedRepo : aliasedRepos) {
releasePolicies.add(aliasedRepo.getReleases());
mirroredRepos.addAll(aliasedRepo.getMirroredRepositories());
}
ArtifactRepositoryPolicy releasePolicy = getEffectivePolicy(releasePolicies);
List<ArtifactRepositoryPolicy> snapshotPolicies = new ArrayList<>(aliasedRepos.size());
for (ArtifactRepository aliasedRepo : aliasedRepos) {
snapshotPolicies.add(aliasedRepo.getSnapshots());
}
ArtifactRepositoryPolicy snapshotPolicy = getEffectivePolicy(snapshotPolicies);
ArtifactRepository aliasedRepo = aliasedRepos.get(0);
ArtifactRepository effectiveRepository = createArtifactRepository(
aliasedRepo.getId(), aliasedRepo.getUrl(), aliasedRepo.getLayout(), snapshotPolicy, releasePolicy);
effectiveRepository.setAuthentication(aliasedRepo.getAuthentication());
effectiveRepository.setProxy(aliasedRepo.getProxy());
effectiveRepository.setMirroredRepositories(mirroredRepos);
effectiveRepository.setBlocked(aliasedRepo.isBlocked());
effectiveRepositories.add(effectiveRepository);
}
return effectiveRepositories;
}
private ArtifactRepositoryPolicy getEffectivePolicy(Collection<ArtifactRepositoryPolicy> policies) {
ArtifactRepositoryPolicy effectivePolicy = null;
for (ArtifactRepositoryPolicy policy : policies) {
if (effectivePolicy == null) {
effectivePolicy = new ArtifactRepositoryPolicy(policy);
} else {
effectivePolicy.merge(policy);
}
}
return effectivePolicy;
}
public ArtifactRepository createLocalRepository(MavenExecutionRequest request, File localRepository)
throws InvalidRepositoryException {
return createLocalRepository(localRepository);
}
public ArtifactRepository createLocalRepository(File localRepository) throws InvalidRepositoryException {
return createRepository(
"file://" + localRepository.toURI().getRawPath(),
MavenRepositorySystem.DEFAULT_LOCAL_REPO_ID,
true,
ArtifactRepositoryPolicy.UPDATE_POLICY_ALWAYS,
true,
ArtifactRepositoryPolicy.UPDATE_POLICY_ALWAYS,
ArtifactRepositoryPolicy.CHECKSUM_POLICY_IGNORE);
}
private static final String WILDCARD = "*";
private static final String EXTERNAL_WILDCARD = "external:*";
private static final String EXTERNAL_HTTP_WILDCARD = "external:http:*";
public static Mirror getMirror(ArtifactRepository repository, List<Mirror> mirrors) {
String repoId = repository.getId();
if (repoId != null && mirrors != null) {
for (Mirror mirror : mirrors) {
if (repoId.equals(mirror.getMirrorOf()) && matchesLayout(repository, mirror)) {
return mirror;
}
}
for (Mirror mirror : mirrors) {
if (matchPattern(repository, mirror.getMirrorOf()) && matchesLayout(repository, mirror)) {
return mirror;
}
}
}
return null;
}
/**
* This method checks if the pattern matches the originalRepository. Valid patterns:
* <ul>
* <li>{@code *} = everything,</li>
* <li>{@code external:*} = everything not on the localhost and not file based,</li>
* <li>{@code external:http:*} = any repository not on the localhost using HTTP,</li>
* <li>{@code repo,repo1} = {@code repo} or {@code repo1},</li>
* <li>{@code *,!repo1} = everything except {@code repo1}.</li>
* </ul>
*
* @param originalRepository to compare for a match.
* @param pattern used for match.
* @return true if the repository is a match to this pattern.
*/
static boolean matchPattern(ArtifactRepository originalRepository, String pattern) {
boolean result = false;
String originalId = originalRepository.getId();
// simple checks first to short circuit processing below.
if (WILDCARD.equals(pattern) || pattern.equals(originalId)) {
result = true;
} else {
// process the list
String[] repos = pattern.split(",");
for (String repo : repos) {
// see if this is a negative match
if (repo.length() > 1 && repo.startsWith("!")) {
if (repo.substring(1).equals(originalId)) {
// explicitly exclude. Set result and stop processing.
result = false;
break;
}
}
// check for exact match
else if (repo.equals(originalId)) {
result = true;
break;
}
// check for external:*
else if (EXTERNAL_WILDCARD.equals(repo) && isExternalRepo(originalRepository)) {
result = true;
// don't stop processing in case a future segment explicitly excludes this repo
}
// check for external:http:*
else if (EXTERNAL_HTTP_WILDCARD.equals(repo) && isExternalHttpRepo(originalRepository)) {
result = true;
// don't stop processing in case a future segment explicitly excludes this repo
} else if (WILDCARD.equals(repo)) {
result = true;
// don't stop processing in case a future segment explicitly excludes this repo
}
}
}
return result;
}
/**
* Checks the URL to see if this repository refers to an external repository
*
* @param originalRepository
* @return true if external.
*/
static boolean isExternalRepo(ArtifactRepository originalRepository) {
try {
URL url = new URL(originalRepository.getUrl());
return !(isLocal(url.getHost()) || url.getProtocol().equals("file"));
} catch (MalformedURLException e) {
// bad url just skip it here. It should have been validated already, but the wagon lookup will deal with it
return false;
}
}
private static boolean isLocal(String host) {
return "localhost".equals(host) || "127.0.0.1".equals(host);
}
/**
* Checks the URL to see if this repository refers to a non-localhost repository using HTTP.
*
* @param originalRepository
* @return true if external.
*/
static boolean isExternalHttpRepo(ArtifactRepository originalRepository) {
try {
URL url = new URL(originalRepository.getUrl());
return ("http".equalsIgnoreCase(url.getProtocol())
|| "dav".equalsIgnoreCase(url.getProtocol())
|| "dav:http".equalsIgnoreCase(url.getProtocol())
|| "dav+http".equalsIgnoreCase(url.getProtocol()))
&& !isLocal(url.getHost());
} catch (MalformedURLException e) {
// bad url just skip it here. It should have been validated already, but the wagon lookup will deal with it
return false;
}
}
static boolean matchesLayout(ArtifactRepository repository, Mirror mirror) {
return matchesLayout(RepositoryUtils.getLayout(repository), mirror.getMirrorOfLayouts());
}
/**
* Checks whether the layouts configured for a mirror match with the layout of the repository.
*
* @param repoLayout The layout of the repository, may be {@code null}.
* @param mirrorLayout The layouts supported by the mirror, may be {@code null}.
* @return {@code true} if the layouts associated with the mirror match the layout of the original repository,
* {@code false} otherwise.
*/
static boolean matchesLayout(String repoLayout, String mirrorLayout) {
boolean result = false;
// simple checks first to short circuit processing below.
if ((mirrorLayout == null || mirrorLayout.isEmpty()) || WILDCARD.equals(mirrorLayout)) {
result = true;
} else if (mirrorLayout.equals(repoLayout)) {
result = true;
} else {
// process the list
String[] layouts = mirrorLayout.split(",");
for (String layout : layouts) {
// see if this is a negative match
if (layout.length() > 1 && layout.startsWith("!")) {
if (layout.substring(1).equals(repoLayout)) {
// explicitly exclude. Set result and stop processing.
result = false;
break;
}
}
// check for exact match
else if (layout.equals(repoLayout)) {
result = true;
break;
} else if (WILDCARD.equals(layout)) {
result = true;
// don't stop processing in case a future segment explicitly excludes this repo
}
}
}
return result;
}
}