From 56ce684ea6338217a36b7faa3f3a6342edccb5d3 Mon Sep 17 00:00:00 2001 From: Martin Stockhammer Date: Tue, 9 Jul 2019 21:28:00 +0200 Subject: Fixing test errors after refactoring --- .../archiva/webdav/ArchivaDavResourceFactory.java | 4 +- .../apache/archiva/webdav/RepositoryServlet.java | 139 +++++++++++---------- 2 files changed, 74 insertions(+), 69 deletions(-) (limited to 'archiva-modules/archiva-web/archiva-webdav/src/main') diff --git a/archiva-modules/archiva-web/archiva-webdav/src/main/java/org/apache/archiva/webdav/ArchivaDavResourceFactory.java b/archiva-modules/archiva-web/archiva-webdav/src/main/java/org/apache/archiva/webdav/ArchivaDavResourceFactory.java index 5102db7a1..e8602caaa 100644 --- a/archiva-modules/archiva-web/archiva-webdav/src/main/java/org/apache/archiva/webdav/ArchivaDavResourceFactory.java +++ b/archiva-modules/archiva-web/archiva-webdav/src/main/java/org/apache/archiva/webdav/ArchivaDavResourceFactory.java @@ -611,8 +611,8 @@ public class ArchivaDavResourceFactory { // Perform an adjustment of the resource to the managed // repository expected path. - String localResourcePath = managedRepository.getRequestInfo().toNativePath( logicalResource.getPath() ); - resourceAsset = managedRepositoryContent.getAsset( localResourcePath ); + // String localResourcePath = managedRepository.getRequestInfo().toNativePath( logicalResource.getPath() ); + resourceAsset = managedRepositoryContent.getAsset( logicalResource.getPath() ); resource = new ArchivaDavResource( resourceAsset, logicalResource.getPath(), managedRepositoryContent, diff --git a/archiva-modules/archiva-web/archiva-webdav/src/main/java/org/apache/archiva/webdav/RepositoryServlet.java b/archiva-modules/archiva-web/archiva-webdav/src/main/java/org/apache/archiva/webdav/RepositoryServlet.java index 1b6e64d62..5ca41715f 100644 --- a/archiva-modules/archiva-web/archiva-webdav/src/main/java/org/apache/archiva/webdav/RepositoryServlet.java +++ b/archiva-modules/archiva-web/archiva-webdav/src/main/java/org/apache/archiva/webdav/RepositoryServlet.java @@ -20,12 +20,12 @@ package org.apache.archiva.webdav; */ import org.apache.archiva.admin.model.RepositoryAdminException; -import org.apache.archiva.admin.model.beans.ManagedRepository; -import org.apache.archiva.admin.model.managed.ManagedRepositoryAdmin; import org.apache.archiva.configuration.ArchivaConfiguration; import org.apache.archiva.configuration.ConfigurationEvent; import org.apache.archiva.configuration.ConfigurationListener; import org.apache.archiva.redback.integration.filter.authentication.HttpAuthenticator; +import org.apache.archiva.repository.ManagedRepository; +import org.apache.archiva.repository.RepositoryRegistry; import org.apache.archiva.security.ServletAuthenticator; import org.apache.jackrabbit.webdav.DavException; import org.apache.jackrabbit.webdav.DavLocatorFactory; @@ -53,7 +53,10 @@ import java.io.IOException; import java.nio.file.Files; import java.nio.file.Path; import java.nio.file.Paths; +import java.util.LinkedHashMap; import java.util.Map; +import java.util.concurrent.locks.ReentrantReadWriteLock; +import java.util.stream.Collectors; /** * RepositoryServlet @@ -66,7 +69,7 @@ public class RepositoryServlet private ArchivaConfiguration configuration; - private ManagedRepositoryAdmin managedRepositoryAdmin; + RepositoryRegistry repositoryRegistry; private Map repositoryMap; @@ -76,22 +79,14 @@ public class RepositoryServlet private DavSessionProvider sessionProvider; - private final Object reloadLock = new Object(); + protected final ReentrantReadWriteLock rwLock = new ReentrantReadWriteLock(); @Override public void init( ServletConfig servletConfig ) throws ServletException { super.init( servletConfig ); - try - { - initServers( servletConfig ); - } - catch ( RepositoryAdminException e ) - { - log.error( e.getMessage(), e ); - throw new ServletException( e.getMessage(), e ); - } + initServers( servletConfig ); } /** @@ -170,53 +165,62 @@ public class RepositoryServlet } } - public synchronized void initServers( ServletConfig servletConfig ) - throws RepositoryAdminException - { + public void initServers( ServletConfig servletConfig ) { long start = System.currentTimeMillis(); WebApplicationContext wac = WebApplicationContextUtils.getRequiredWebApplicationContext( servletConfig.getServletContext() ); - configuration = wac.getBean( "archivaConfiguration#default", ArchivaConfiguration.class ); - configuration.addListener( this ); + rwLock.writeLock().lock(); + try { + configuration = wac.getBean("archivaConfiguration#default", ArchivaConfiguration.class); + configuration.addListener(this); - managedRepositoryAdmin = wac.getBean( ManagedRepositoryAdmin.class ); + repositoryRegistry = wac.getBean(RepositoryRegistry.class); + repositoryMap = new LinkedHashMap<>(); - repositoryMap = managedRepositoryAdmin.getManagedRepositoriesAsMap(); + fillRepositoryMap(); - for ( ManagedRepository repo : repositoryMap.values() ) - { - Path repoDir = Paths.get( repo.getLocation() ); + for (ManagedRepository repo : repositoryMap.values()) { + Path repoDir = Paths.get(repo.getLocation()); - if ( !Files.exists(repoDir) ) - { - try - { - Files.createDirectories( repoDir ); - } - catch ( IOException e ) - { - log.info( "Unable to create missing directory for {}", repo.getLocation() ); - continue; + if (!Files.exists(repoDir)) { + try { + Files.createDirectories(repoDir); + } catch (IOException e) { + log.info("Unable to create missing directory for {}", repo.getLocation()); + continue; + } } } - } - - resourceFactory = wac.getBean( "davResourceFactory#archiva", DavResourceFactory.class ); - locatorFactory = new ArchivaDavLocatorFactory(); - ServletAuthenticator servletAuth = wac.getBean( ServletAuthenticator.class ); - HttpAuthenticator httpAuth = wac.getBean( "httpAuthenticator#basic", HttpAuthenticator.class ); + resourceFactory = wac.getBean("davResourceFactory#archiva", DavResourceFactory.class); + locatorFactory = new ArchivaDavLocatorFactory(); - sessionProvider = new ArchivaDavSessionProvider( servletAuth, httpAuth ); + ServletAuthenticator servletAuth = wac.getBean(ServletAuthenticator.class); + HttpAuthenticator httpAuth = wac.getBean("httpAuthenticator#basic", HttpAuthenticator.class); + sessionProvider = new ArchivaDavSessionProvider(servletAuth, httpAuth); + } finally { + rwLock.writeLock().unlock(); + } long end = System.currentTimeMillis(); log.debug( "initServers done in {} ms", (end - start) ); } + private void fillRepositoryMap() { + final Map repos = repositoryRegistry.getManagedRepositories().stream().collect(Collectors.toMap(r -> r.getId(), r -> r)); + rwLock.writeLock().lock(); + try { + repositoryMap.clear(); + repositoryMap.putAll(repos); + } finally { + rwLock.writeLock().unlock(); + } + } + @Override public void configurationEvent( ConfigurationEvent event ) { @@ -237,26 +241,23 @@ public class RepositoryServlet private void initRepositories() throws RepositoryAdminException { - synchronized ( repositoryMap ) - { - repositoryMap.clear(); - repositoryMap.putAll( managedRepositoryAdmin.getManagedRepositoriesAsMap() ); - } - - synchronized ( reloadLock ) - { initServers( getServletConfig() ); - } } - public synchronized ManagedRepository getRepository( String prefix ) + public ManagedRepository getRepository( String prefix ) throws RepositoryAdminException { - if ( repositoryMap.isEmpty() ) - { - repositoryMap.putAll( managedRepositoryAdmin.getManagedRepositoriesAsMap() ); + rwLock.readLock().lock(); + try { + if (repositoryMap.isEmpty()) { + rwLock.readLock().unlock(); + fillRepositoryMap(); + rwLock.readLock().lock(); + } + return repositoryMap.get(prefix); + } finally { + rwLock.readLock().unlock(); } - return repositoryMap.get( prefix ); } ArchivaConfiguration getConfiguration() @@ -322,21 +323,25 @@ public class RepositoryServlet @Override public void destroy() { - configuration.removeListener( this ); - - resourceFactory = null; - configuration = null; - locatorFactory = null; - sessionProvider = null; - repositoryMap.clear(); - repositoryMap = null; + rwLock.writeLock().lock(); + try { + configuration.removeListener(this); + + resourceFactory = null; + configuration = null; + locatorFactory = null; + sessionProvider = null; + repositoryMap.clear(); + repositoryMap = null; - WebApplicationContext wac = WebApplicationContextUtils.getRequiredWebApplicationContext( getServletContext() ); + WebApplicationContext wac = WebApplicationContextUtils.getRequiredWebApplicationContext(getServletContext()); - if ( wac instanceof ConfigurableApplicationContext ) - { - ( (ConfigurableApplicationContext) wac ).close(); + if (wac instanceof ConfigurableApplicationContext) { + ((ConfigurableApplicationContext) wac).close(); + } + super.destroy(); + } finally { + rwLock.writeLock().unlock(); } - super.destroy(); } } -- cgit v1.2.3