aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--archiva-modules/archiva-scheduler/archiva-scheduler-indexing/src/main/java/org/apache/archiva/scheduler/indexing/DefaultDownloadRemoteIndexScheduler.java81
-rw-r--r--archiva-modules/archiva-scheduler/archiva-scheduler-indexing/src/main/java/org/apache/archiva/scheduler/indexing/DownloadRemoteIndexTask.java144
2 files changed, 114 insertions, 111 deletions
diff --git a/archiva-modules/archiva-scheduler/archiva-scheduler-indexing/src/main/java/org/apache/archiva/scheduler/indexing/DefaultDownloadRemoteIndexScheduler.java b/archiva-modules/archiva-scheduler/archiva-scheduler-indexing/src/main/java/org/apache/archiva/scheduler/indexing/DefaultDownloadRemoteIndexScheduler.java
index a2cb8cf8a..3ceb79199 100644
--- a/archiva-modules/archiva-scheduler/archiva-scheduler-indexing/src/main/java/org/apache/archiva/scheduler/indexing/DefaultDownloadRemoteIndexScheduler.java
+++ b/archiva-modules/archiva-scheduler/archiva-scheduler-indexing/src/main/java/org/apache/archiva/scheduler/indexing/DefaultDownloadRemoteIndexScheduler.java
@@ -62,7 +62,7 @@ public class DefaultDownloadRemoteIndexScheduler
implements ConfigurationListener, DownloadRemoteIndexScheduler
{
- private Logger log = LoggerFactory.getLogger( getClass() );
+ private Logger log = LoggerFactory.getLogger( getClass( ) );
@Inject
@Named( value = "taskScheduler#indexDownloadRemote" )
@@ -94,10 +94,10 @@ public class DefaultDownloadRemoteIndexScheduler
private IndexUpdater indexUpdater;
// store ids about currently running remote download : updated in DownloadRemoteIndexTask
- private List<String> runningRemoteDownloadIds = new CopyOnWriteArrayList<String>();
+ private List<String> runningRemoteDownloadIds = new CopyOnWriteArrayList<String>( );
@PostConstruct
- public void startup()
+ public void startup( )
throws ArchivaException, RepositoryAdminException, PlexusSisuBridgeException, IOException,
UnsupportedExistingLuceneIndexException, DownloadRemoteIndexException
{
@@ -111,33 +111,33 @@ public class DefaultDownloadRemoteIndexScheduler
indexUpdater = plexusSisuBridge.lookup( IndexUpdater.class );
- for ( RemoteRepository remoteRepository : remoteRepositoryAdmin.getRemoteRepositories() )
+ for ( RemoteRepository remoteRepository : remoteRepositoryAdmin.getRemoteRepositories( ) )
{
- String contextKey = "remote-" + remoteRepository.getId();
- if ( nexusIndexer.getIndexingContexts().get( contextKey ) != null )
+ String contextKey = "remote-" + remoteRepository.getId( );
+ if ( nexusIndexer.getIndexingContexts( ).get( contextKey ) != null )
{
continue;
}
// create path
- File repoDir = new File( appServerBase, "data/remotes/" + remoteRepository.getId() );
- if ( !repoDir.exists() )
+ File repoDir = new File( appServerBase, "data/remotes/" + remoteRepository.getId( ) );
+ if ( !repoDir.exists( ) )
{
- repoDir.mkdirs();
+ repoDir.mkdirs( );
}
File indexDirectory = new File( repoDir, ".index" );
- if ( !indexDirectory.exists() )
+ if ( !indexDirectory.exists( ) )
{
- indexDirectory.mkdirs();
+ indexDirectory.mkdirs( );
}
- nexusIndexer.addIndexingContext( contextKey, remoteRepository.getId(), repoDir, indexDirectory,
- remoteRepository.getUrl(), calculateIndexRemoteUrl( remoteRepository ),
- mavenIndexerUtils.getAllIndexCreators() );
+ nexusIndexer.addIndexingContext( contextKey, remoteRepository.getId( ), repoDir, indexDirectory,
+ remoteRepository.getUrl( ), calculateIndexRemoteUrl( remoteRepository ),
+ mavenIndexerUtils.getAllIndexCreators( ) );
// TODO record jobs from configuration
- if ( remoteRepository.isDownloadRemoteIndex() && StringUtils.isNotEmpty(
- remoteRepository.getCronExpression() ) )
+ if ( remoteRepository.isDownloadRemoteIndex( ) && StringUtils.isNotEmpty(
+ remoteRepository.getCronExpression( ) ) )
{
- boolean fullDownload = indexDirectory.list().length == 0;
- scheduleDownloadRemote( remoteRepository.getId(), false, fullDownload );
+ boolean fullDownload = indexDirectory.list( ).length == 0;
+ scheduleDownloadRemote( remoteRepository.getId( ), false, fullDownload );
}
}
@@ -145,13 +145,13 @@ public class DefaultDownloadRemoteIndexScheduler
}
@PreDestroy
- public void shutdown()
+ public void shutdown( )
throws RepositoryAdminException, IOException
{
- for ( RemoteRepository remoteRepository : remoteRepositoryAdmin.getRemoteRepositories() )
+ for ( RemoteRepository remoteRepository : remoteRepositoryAdmin.getRemoteRepositories( ) )
{
- String contextKey = "remote-" + remoteRepository.getId();
- IndexingContext context = nexusIndexer.getIndexingContexts().get( contextKey );
+ String contextKey = "remote-" + remoteRepository.getId( );
+ IndexingContext context = nexusIndexer.getIndexingContexts( ).get( contextKey );
if ( context == null )
{
continue;
@@ -178,66 +178,65 @@ public class DefaultDownloadRemoteIndexScheduler
return;
}
NetworkProxy networkProxy = null;
- if ( StringUtils.isNotBlank( remoteRepository.getRemoteDownloadNetworkProxyId() ) )
+ if ( StringUtils.isNotBlank( remoteRepository.getRemoteDownloadNetworkProxyId( ) ) )
{
- networkProxy = networkProxyAdmin.getNetworkProxy( remoteRepository.getRemoteDownloadNetworkProxyId() );
+ networkProxy = networkProxyAdmin.getNetworkProxy( remoteRepository.getRemoteDownloadNetworkProxyId( ) );
if ( networkProxy == null )
{
log.warn(
"your remote repository is configured to download remote index trought a proxy we cannot find id:{}",
- remoteRepository.getRemoteDownloadNetworkProxyId() );
+ remoteRepository.getRemoteDownloadNetworkProxyId( ) );
}
}
- //archivaConfiguration.getConfiguration().getProxyConnectorAsMap().get( "" ).get( 0 ).
- //archivaConfiguration.getConfiguration().getNetworkProxiesAsMap()
-
DownloadRemoteIndexTaskRequest downloadRemoteIndexTaskRequest =
- new DownloadRemoteIndexTaskRequest().setRemoteRepository( remoteRepository ).setNetworkProxy(
+ new DownloadRemoteIndexTaskRequest( ).setRemoteRepository( remoteRepository ).setNetworkProxy(
networkProxy ).setFullDownload( fullDownload ).setWagonFactory( wagonFactory ).setNexusIndexer(
nexusIndexer ).setIndexUpdater( indexUpdater );
if ( now )
{
+ log.info( "schedule download remote index for repository {}", remoteRepository.getId( ) );
// do it in async
taskScheduler.schedule(
new DownloadRemoteIndexTask( downloadRemoteIndexTaskRequest, this.runningRemoteDownloadIds ),
- new Date() );
+ new Date( ) );
}
else
{
-
+ log.info( "schedule download remote index for repository {} with cron expression {}",
+ remoteRepository.getId( ), remoteRepository.getCronExpression( ) );
taskScheduler.schedule(
new DownloadRemoteIndexTask( downloadRemoteIndexTaskRequest, this.runningRemoteDownloadIds ),
- new CronTrigger( remoteRepository.getCronExpression() ) );
+ new CronTrigger( remoteRepository.getCronExpression( ) ) );
}
}
catch ( RepositoryAdminException e )
{
- log.error( e.getMessage(), e );
- throw new DownloadRemoteIndexException( e.getMessage(), e );
+ log.error( e.getMessage( ), e );
+ throw new DownloadRemoteIndexException( e.getMessage( ), e );
}
}
protected String calculateIndexRemoteUrl( RemoteRepository remoteRepository )
{
- if ( StringUtils.startsWith( remoteRepository.getRemoteIndexUrl(), "http" ) )
+ if ( StringUtils.startsWith( remoteRepository.getRemoteIndexUrl( ), "http" ) )
{
- String baseUrl = remoteRepository.getRemoteIndexUrl();
+ String baseUrl = remoteRepository.getRemoteIndexUrl( );
return baseUrl.endsWith( "/" ) ? StringUtils.substringBeforeLast( baseUrl, "/" ) : baseUrl;
}
- String baseUrl = StringUtils.endsWith( remoteRepository.getUrl(), "/" ) ? StringUtils.substringBeforeLast(
- remoteRepository.getUrl(), "/" ) : remoteRepository.getUrl();
+ String baseUrl = StringUtils.endsWith( remoteRepository.getUrl( ), "/" ) ? StringUtils.substringBeforeLast(
+ remoteRepository.getUrl( ), "/" ) : remoteRepository.getUrl( );
- baseUrl = StringUtils.isEmpty( remoteRepository.getRemoteIndexUrl() )
+ baseUrl = StringUtils.isEmpty( remoteRepository.getRemoteIndexUrl( ) )
? baseUrl + "/.index"
- : baseUrl + "/" + remoteRepository.getRemoteIndexUrl();
+ : baseUrl + "/" + remoteRepository.getRemoteIndexUrl( );
return baseUrl;
}
- public TaskScheduler getTaskScheduler()
+ public TaskScheduler getTaskScheduler( )
{
return taskScheduler;
}
diff --git a/archiva-modules/archiva-scheduler/archiva-scheduler-indexing/src/main/java/org/apache/archiva/scheduler/indexing/DownloadRemoteIndexTask.java b/archiva-modules/archiva-scheduler/archiva-scheduler-indexing/src/main/java/org/apache/archiva/scheduler/indexing/DownloadRemoteIndexTask.java
index b1e1427f5..b334449f5 100644
--- a/archiva-modules/archiva-scheduler/archiva-scheduler-indexing/src/main/java/org/apache/archiva/scheduler/indexing/DownloadRemoteIndexTask.java
+++ b/archiva-modules/archiva-scheduler/archiva-scheduler-indexing/src/main/java/org/apache/archiva/scheduler/indexing/DownloadRemoteIndexTask.java
@@ -23,6 +23,7 @@ import org.apache.archiva.admin.model.beans.RemoteRepository;
import org.apache.archiva.proxy.common.WagonFactory;
import org.apache.archiva.proxy.common.WagonFactoryException;
import org.apache.commons.io.FileUtils;
+import org.apache.commons.lang.time.StopWatch;
import org.apache.maven.index.NexusIndexer;
import org.apache.maven.index.context.IndexingContext;
import org.apache.maven.index.updater.IndexUpdateRequest;
@@ -62,7 +63,7 @@ import java.util.List;
public class DownloadRemoteIndexTask
implements Runnable
{
- private Logger log = LoggerFactory.getLogger( getClass() );
+ private Logger log = LoggerFactory.getLogger( getClass( ) );
private RemoteRepository remoteRepository;
@@ -81,78 +82,80 @@ public class DownloadRemoteIndexTask
public DownloadRemoteIndexTask( DownloadRemoteIndexTaskRequest downloadRemoteIndexTaskRequest,
List<String> runningRemoteDownloadIds )
{
- this.remoteRepository = downloadRemoteIndexTaskRequest.getRemoteRepository();
- this.nexusIndexer = downloadRemoteIndexTaskRequest.getNexusIndexer();
- this.wagonFactory = downloadRemoteIndexTaskRequest.getWagonFactory();
- this.networkProxy = downloadRemoteIndexTaskRequest.getNetworkProxy();
- this.fullDownload = downloadRemoteIndexTaskRequest.isFullDownload();
+ this.remoteRepository = downloadRemoteIndexTaskRequest.getRemoteRepository( );
+ this.nexusIndexer = downloadRemoteIndexTaskRequest.getNexusIndexer( );
+ this.wagonFactory = downloadRemoteIndexTaskRequest.getWagonFactory( );
+ this.networkProxy = downloadRemoteIndexTaskRequest.getNetworkProxy( );
+ this.fullDownload = downloadRemoteIndexTaskRequest.isFullDownload( );
this.runningRemoteDownloadIds = runningRemoteDownloadIds;
- this.indexUpdater = downloadRemoteIndexTaskRequest.getIndexUpdater();
+ this.indexUpdater = downloadRemoteIndexTaskRequest.getIndexUpdater( );
}
- public void run()
+ public void run( )
{
// so short lock : not sure we need it
synchronized ( this.runningRemoteDownloadIds )
{
- if ( this.runningRemoteDownloadIds.contains( this.remoteRepository.getId() ) )
+ if ( this.runningRemoteDownloadIds.contains( this.remoteRepository.getId( ) ) )
{
// skip it as it's running
log.info( "skip download index remote for repo {} it's already running",
- this.remoteRepository.getId() );
+ this.remoteRepository.getId( ) );
return;
}
- log.info( "start download remote index for remote repository " + this.remoteRepository.getId() );
- this.runningRemoteDownloadIds.add( this.remoteRepository.getId() );
+ this.runningRemoteDownloadIds.add( this.remoteRepository.getId( ) );
}
+ StopWatch stopWatch = new StopWatch( );
+ stopWatch.start( );
+ log.info( "start download remote index for remote repository " + this.remoteRepository.getId( ) );
IndexingContext indexingContext =
- nexusIndexer.getIndexingContexts().get( "remote-" + remoteRepository.getId() );
+ nexusIndexer.getIndexingContexts( ).get( "remote-" + remoteRepository.getId( ) );
// TODO check if null ? normally not as created by DefaultDownloadRemoteIndexScheduler#startup
// create a temp directory to download files
- final File tempIndexDirectory = new File( indexingContext.getIndexDirectoryFile().getParent(), ".tmpIndex" );
+ final File tempIndexDirectory = new File( indexingContext.getIndexDirectoryFile( ).getParent( ), ".tmpIndex" );
try
{
- if ( tempIndexDirectory.exists() )
+ if ( tempIndexDirectory.exists( ) )
{
FileUtils.deleteDirectory( tempIndexDirectory );
}
- tempIndexDirectory.mkdirs();
- String baseIndexUrl = indexingContext.getIndexUpdateUrl();
+ tempIndexDirectory.mkdirs( );
+ String baseIndexUrl = indexingContext.getIndexUpdateUrl( );
- final Wagon wagon = wagonFactory.getWagon( new URL( this.remoteRepository.getUrl() ).getProtocol() );
+ final Wagon wagon = wagonFactory.getWagon( new URL( this.remoteRepository.getUrl( ) ).getProtocol( ) );
setupWagonReadTimeout( wagon );
// TODO transferListener
- wagon.addTransferListener( new DownloadListener() );
+ wagon.addTransferListener( new DownloadListener( ) );
ProxyInfo proxyInfo = null;
if ( this.networkProxy != null )
{
- proxyInfo = new ProxyInfo();
- proxyInfo.setHost( this.networkProxy.getHost() );
- proxyInfo.setPort( this.networkProxy.getPort() );
- proxyInfo.setUserName( this.networkProxy.getUsername() );
- proxyInfo.setPassword( this.networkProxy.getPassword() );
+ proxyInfo = new ProxyInfo( );
+ proxyInfo.setHost( this.networkProxy.getHost( ) );
+ proxyInfo.setPort( this.networkProxy.getPort( ) );
+ proxyInfo.setUserName( this.networkProxy.getUsername( ) );
+ proxyInfo.setPassword( this.networkProxy.getPassword( ) );
}
AuthenticationInfo authenticationInfo = null;
- if ( this.remoteRepository.getUserName() != null )
+ if ( this.remoteRepository.getUserName( ) != null )
{
- authenticationInfo = new AuthenticationInfo();
- authenticationInfo.setUserName( this.remoteRepository.getUserName() );
- authenticationInfo.setPassword( this.remoteRepository.getPassword() );
+ authenticationInfo = new AuthenticationInfo( );
+ authenticationInfo.setUserName( this.remoteRepository.getUserName( ) );
+ authenticationInfo.setPassword( this.remoteRepository.getPassword( ) );
}
- wagon.connect( new Repository( this.remoteRepository.getId(), baseIndexUrl ), authenticationInfo,
+ wagon.connect( new Repository( this.remoteRepository.getId( ), baseIndexUrl ), authenticationInfo,
proxyInfo );
- File indexDirectory = indexingContext.getIndexDirectoryFile();
- if ( !indexDirectory.exists() )
+ File indexDirectory = indexingContext.getIndexDirectoryFile( );
+ if ( !indexDirectory.exists( ) )
{
- indexDirectory.mkdirs();
+ indexDirectory.mkdirs( );
}
- ResourceFetcher resourceFetcher = new ResourceFetcher()
+ ResourceFetcher resourceFetcher = new ResourceFetcher( )
{
public void connect( String id, String url )
throws IOException
@@ -160,7 +163,7 @@ public class DownloadRemoteIndexTask
//no op
}
- public void disconnect()
+ public void disconnect( )
throws IOException
{
// no op
@@ -174,9 +177,9 @@ public class DownloadRemoteIndexTask
log.debug( "resourceFetcher#retrieve, name:{}", name );
//TODO check those files are deleted !!
File file = new File( tempIndexDirectory, name );
- if ( file.exists() )
+ if ( file.exists( ) )
{
- file.delete();
+ file.delete( );
}
//file.deleteOnExit();
wagon.get( name, file );
@@ -184,15 +187,15 @@ public class DownloadRemoteIndexTask
}
catch ( AuthorizationException e )
{
- throw new IOException( e.getMessage() );
+ throw new IOException( e.getMessage( ) );
}
catch ( TransferFailedException e )
{
- throw new IOException( e.getMessage() );
+ throw new IOException( e.getMessage( ) );
}
catch ( ResourceDoesNotExistException e )
{
- throw new FileNotFoundException( e.getMessage() );
+ throw new FileNotFoundException( e.getMessage( ) );
}
}
};
@@ -201,40 +204,41 @@ public class DownloadRemoteIndexTask
request.setForceFullUpdate( this.fullDownload );
this.indexUpdater.fetchAndUpdateIndex( request );
-
-
+ stopWatch.stop( );
+ log.info( "time to download remote repository index for repository {}: {} s",
+ this.remoteRepository.getId( ), ( stopWatch.getTime( ) / 1000 ) );
}
catch ( MalformedURLException e )
{
- log.error( e.getMessage(), e );
- throw new RuntimeException( e.getMessage(), e );
+ log.error( e.getMessage( ), e );
+ throw new RuntimeException( e.getMessage( ), e );
}
catch ( WagonFactoryException e )
{
- log.error( e.getMessage(), e );
- throw new RuntimeException( e.getMessage(), e );
+ log.error( e.getMessage( ), e );
+ throw new RuntimeException( e.getMessage( ), e );
}
catch ( ConnectionException e )
{
- log.error( e.getMessage(), e );
- throw new RuntimeException( e.getMessage(), e );
+ log.error( e.getMessage( ), e );
+ throw new RuntimeException( e.getMessage( ), e );
}
catch ( AuthenticationException e )
{
- log.error( e.getMessage(), e );
- throw new RuntimeException( e.getMessage(), e );
+ log.error( e.getMessage( ), e );
+ throw new RuntimeException( e.getMessage( ), e );
}
catch ( IOException e )
{
- log.error( e.getMessage(), e );
- throw new RuntimeException( e.getMessage(), e );
+ log.error( e.getMessage( ), e );
+ throw new RuntimeException( e.getMessage( ), e );
}
finally
{
deleteDirectoryQuiet( tempIndexDirectory );
- this.runningRemoteDownloadIds.remove( this.remoteRepository.getId() );
+ this.runningRemoteDownloadIds.remove( this.remoteRepository.getId( ) );
}
- log.info( "end download remote index for remote repository " + this.remoteRepository.getId() );
+ log.info( "end download remote index for remote repository " + this.remoteRepository.getId( ) );
}
private void deleteDirectoryQuiet( File f )
@@ -245,7 +249,7 @@ public class DownloadRemoteIndexTask
}
catch ( IOException e )
{
- log.warn( "skip error delete " + f + ": " + e.getMessage() );
+ log.warn( "skip error delete " + f + ": " + e.getMessage( ) );
}
}
@@ -253,15 +257,15 @@ public class DownloadRemoteIndexTask
{
try
{
- HttpConfiguration httpConfiguration = new HttpConfiguration().setAll(
- new HttpMethodConfiguration().setReadTimeout( remoteRepository.getRemoteDownloadTimeout() * 1000 ) );
+ HttpConfiguration httpConfiguration = new HttpConfiguration( ).setAll(
+ new HttpMethodConfiguration( ).setReadTimeout( remoteRepository.getRemoteDownloadTimeout( ) * 1000 ) );
Method setHttpConfigurationMethod =
- wagon.getClass().getMethod( "setHttpConfiguration", HttpConfiguration.class );
+ wagon.getClass( ).getMethod( "setHttpConfiguration", HttpConfiguration.class );
setHttpConfigurationMethod.invoke( wagon, httpConfiguration );
}
catch ( Exception e )
{
- log.debug( "unable to set download remote time out for index {}", e.getMessage(), e );
+ log.debug( "unable to set download remote time out for index {}", e.getMessage( ), e );
}
}
@@ -269,7 +273,7 @@ public class DownloadRemoteIndexTask
public static class DownloadListener
implements TransferListener
{
- private Logger log = LoggerFactory.getLogger( getClass() );
+ private Logger log = LoggerFactory.getLogger( getClass( ) );
String reourceName;
@@ -277,36 +281,36 @@ public class DownloadRemoteIndexTask
public void transferInitiated( TransferEvent transferEvent )
{
- reourceName = transferEvent.getResource().getName();
+ reourceName = transferEvent.getResource( ).getName( );
log.debug( "initiate transfer of {}", reourceName );
}
public void transferStarted( TransferEvent transferEvent )
{
- reourceName = transferEvent.getResource().getName();
- startTime = System.currentTimeMillis();
- log.info( "start transfer of {}", transferEvent.getResource().getName() );
+ reourceName = transferEvent.getResource( ).getName( );
+ startTime = System.currentTimeMillis( );
+ log.info( "start transfer of {}", transferEvent.getResource( ).getName( ) );
}
public void transferProgress( TransferEvent transferEvent, byte[] buffer, int length )
{
log.debug( "transfer of {} : {}/{}",
- Arrays.asList( transferEvent.getResource().getName(), buffer.length, length ).toArray() );
+ Arrays.asList( transferEvent.getResource( ).getName( ), buffer.length, length ).toArray( ) );
}
public void transferCompleted( TransferEvent transferEvent )
{
- reourceName = transferEvent.getResource().getName();
- long endTime = System.currentTimeMillis();
- log.info( "end of transfer file {}: {}s", transferEvent.getResource().getName(),
+ reourceName = transferEvent.getResource( ).getName( );
+ long endTime = System.currentTimeMillis( );
+ log.info( "end of transfer file {}: {}s", transferEvent.getResource( ).getName( ),
( endTime - startTime ) / 1000 );
}
public void transferError( TransferEvent transferEvent )
{
- log.info( "error of transfer file {}: {}", Arrays.asList( transferEvent.getResource().getName(),
- transferEvent.getException().getMessage() ).toArray(
- new Object[2] ), transferEvent.getException() );
+ log.info( "error of transfer file {}: {}", Arrays.asList( transferEvent.getResource( ).getName( ),
+ transferEvent.getException( ).getMessage( ) ).toArray(
+ new Object[2] ), transferEvent.getException( ) );
}
public void debug( String message )