mirror of https://github.com/apache/maven.git
[MNG-7116] add support for mirrorOf external:http:*
This commit is contained in:
parent
e5f6634e17
commit
fa79cb22e4
|
@ -41,6 +41,8 @@ public class DefaultMirrorSelector
|
||||||
|
|
||||||
private static final String EXTERNAL_WILDCARD = "external:*";
|
private static final String EXTERNAL_WILDCARD = "external:*";
|
||||||
|
|
||||||
|
private static final String EXTERNAL_HTTP_WILDCARD = "external:http:*";
|
||||||
|
|
||||||
public Mirror getMirror( ArtifactRepository repository, List<Mirror> mirrors )
|
public Mirror getMirror( ArtifactRepository repository, List<Mirror> mirrors )
|
||||||
{
|
{
|
||||||
String repoId = repository.getId();
|
String repoId = repository.getId();
|
||||||
|
@ -68,9 +70,14 @@ public class DefaultMirrorSelector
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This method checks if the pattern matches the originalRepository. Valid patterns: * =
|
* This method checks if the pattern matches the originalRepository. Valid patterns:
|
||||||
* everything external:* = everything not on the localhost and not file based. repo,repo1 = repo
|
* <ul>
|
||||||
* or repo1 *,!repo1 = everything except repo1
|
* <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 originalRepository to compare for a match.
|
||||||
* @param pattern used for match. Currently only '*' is supported.
|
* @param pattern used for match. Currently only '*' is supported.
|
||||||
|
@ -115,6 +122,12 @@ public class DefaultMirrorSelector
|
||||||
result = true;
|
result = true;
|
||||||
// don't stop processing in case a future segment explicitly excludes this repo
|
// 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 ) )
|
else if ( WILDCARD.equals( repo ) )
|
||||||
{
|
{
|
||||||
result = true;
|
result = true;
|
||||||
|
@ -136,8 +149,7 @@ public class DefaultMirrorSelector
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
URL url = new URL( originalRepository.getUrl() );
|
URL url = new URL( originalRepository.getUrl() );
|
||||||
return !( url.getHost().equals( "localhost" ) || url.getHost().equals( "127.0.0.1" )
|
return !( isLocal( url.getHost() ) || url.getProtocol().equals( "file" ) );
|
||||||
|| url.getProtocol().equals( "file" ) );
|
|
||||||
}
|
}
|
||||||
catch ( MalformedURLException e )
|
catch ( MalformedURLException e )
|
||||||
{
|
{
|
||||||
|
@ -146,7 +158,34 @@ public class DefaultMirrorSelector
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static boolean matchesLayout( ArtifactRepository repository, Mirror mirror )
|
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() );
|
return matchesLayout( RepositoryUtils.getLayout( repository ), mirror.getMirrorOfLayouts() );
|
||||||
}
|
}
|
||||||
|
|
|
@ -710,6 +710,8 @@ public class MavenRepositorySystem
|
||||||
|
|
||||||
private static final String EXTERNAL_WILDCARD = "external:*";
|
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 )
|
public static Mirror getMirror( ArtifactRepository repository, List<Mirror> mirrors )
|
||||||
{
|
{
|
||||||
String repoId = repository.getId();
|
String repoId = repository.getId();
|
||||||
|
@ -737,8 +739,14 @@ public class MavenRepositorySystem
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This method checks if the pattern matches the originalRepository. Valid patterns: * = everything external:* =
|
* This method checks if the pattern matches the originalRepository. Valid patterns:
|
||||||
* everything not on the localhost and not file based. repo,repo1 = repo or repo1 *,!repo1 = everything except repo1
|
* <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 originalRepository to compare for a match.
|
||||||
* @param pattern used for match. Currently only '*' is supported.
|
* @param pattern used for match. Currently only '*' is supported.
|
||||||
|
@ -782,6 +790,12 @@ public class MavenRepositorySystem
|
||||||
result = true;
|
result = true;
|
||||||
// don't stop processing in case a future segment explicitly excludes this repo
|
// 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 ) )
|
else if ( WILDCARD.equals( repo ) )
|
||||||
{
|
{
|
||||||
result = true;
|
result = true;
|
||||||
|
@ -803,8 +817,34 @@ public class MavenRepositorySystem
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
URL url = new URL( originalRepository.getUrl() );
|
URL url = new URL( originalRepository.getUrl() );
|
||||||
return !( url.getHost().equals( "localhost" ) || url.getHost().equals( "127.0.0.1" )
|
return !( isLocal( url.getHost() ) || url.getProtocol().equals( "file" ) );
|
||||||
|| 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 )
|
catch ( MalformedURLException e )
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in New Issue