From d4ce38836d9f093d2024e26182f38fa3bc4890e2 Mon Sep 17 00:00:00 2001 From: Martin Stockhammer Date: Tue, 20 Aug 2019 00:08:08 +0200 Subject: Implementing new stream methods --- .../cassandra/CassandraMetadataRepository.java | 106 +++++++++++++++++++-- .../CassandraRepositorySessionFactory.java | 18 +--- .../cassandra/CassandraMetadataRepositoryTest.java | 8 +- .../repository/file/FileMetadataRepository.java | 85 +++++++++++++---- .../file/FileRepositorySessionFactory.java | 18 +--- .../file/FileMetadataRepositoryTest.java | 8 +- .../repository/jcr/JcrMetadataRepository.java | 75 +++++++-------- .../repository/jcr/OakRepositoryFactory.java | 85 +++++------------ .../archiva/metadata/repository/jcr/jcr-schema.cnd | 3 +- 9 files changed, 248 insertions(+), 158 deletions(-) (limited to 'archiva-modules/plugins') diff --git a/archiva-modules/plugins/metadata-store-cassandra/src/main/java/org/apache/archiva/metadata/repository/cassandra/CassandraMetadataRepository.java b/archiva-modules/plugins/metadata-store-cassandra/src/main/java/org/apache/archiva/metadata/repository/cassandra/CassandraMetadataRepository.java index 05d6c5c33..757d50a50 100644 --- a/archiva-modules/plugins/metadata-store-cassandra/src/main/java/org/apache/archiva/metadata/repository/cassandra/CassandraMetadataRepository.java +++ b/archiva-modules/plugins/metadata-store-cassandra/src/main/java/org/apache/archiva/metadata/repository/cassandra/CassandraMetadataRepository.java @@ -52,9 +52,11 @@ import org.apache.archiva.metadata.model.ProjectMetadata; import org.apache.archiva.metadata.model.ProjectVersionMetadata; import org.apache.archiva.metadata.model.ProjectVersionReference; import org.apache.archiva.metadata.model.Scm; +import org.apache.archiva.metadata.repository.AbstractMetadataRepository; import org.apache.archiva.metadata.repository.MetadataRepository; import org.apache.archiva.metadata.repository.MetadataRepositoryException; import org.apache.archiva.metadata.repository.MetadataResolutionException; +import org.apache.archiva.metadata.repository.MetadataService; import org.apache.archiva.metadata.repository.RepositorySession; import org.apache.archiva.metadata.repository.cassandra.model.ArtifactMetadataModel; import org.apache.archiva.metadata.repository.cassandra.model.MetadataFacetModel; @@ -62,11 +64,13 @@ import org.apache.archiva.metadata.repository.cassandra.model.Namespace; import org.apache.archiva.metadata.repository.cassandra.model.Project; import org.apache.archiva.metadata.repository.cassandra.model.ProjectVersionMetadataModel; import org.apache.archiva.metadata.repository.cassandra.model.Repository; +import org.apache.archiva.repository.RepositoryException; import org.apache.commons.lang.StringUtils; import org.modelmapper.ModelMapper; import org.slf4j.Logger; import org.slf4j.LoggerFactory; +import java.time.ZonedDateTime; import java.util.ArrayList; import java.util.Collection; import java.util.Collections; @@ -78,7 +82,12 @@ import java.util.LinkedList; import java.util.List; import java.util.Map; import java.util.Set; +import java.util.Spliterator; import java.util.UUID; +import java.util.function.Consumer; +import java.util.function.Function; +import java.util.stream.Stream; +import java.util.stream.StreamSupport; import static org.apache.archiva.metadata.repository.cassandra.CassandraUtils.*; import static org.apache.archiva.metadata.repository.cassandra.model.ColumnNames.*; @@ -88,15 +97,13 @@ import static org.apache.archiva.metadata.repository.cassandra.model.ColumnNames * @since 2.0.0 */ public class CassandraMetadataRepository - implements MetadataRepository + extends AbstractMetadataRepository implements MetadataRepository { private Logger logger = LoggerFactory.getLogger( getClass() ); private ArchivaConfiguration configuration; - private final Map metadataFacetFactories; - private final CassandraArchivaManager cassandraArchivaManager; private final ColumnFamilyTemplate projectVersionMetadataTemplate; @@ -117,11 +124,11 @@ public class CassandraMetadataRepository private final StringSerializer ss = StringSerializer.get(); - public CassandraMetadataRepository( Map metadataFacetFactories, + public CassandraMetadataRepository( MetadataService metadataService, ArchivaConfiguration configuration, CassandraArchivaManager cassandraArchivaManager ) { - this.metadataFacetFactories = metadataFacetFactories; + super( metadataService ); this.configuration = configuration; this.cassandraArchivaManager = cassandraArchivaManager; this.keyspace = cassandraArchivaManager.getKeyspace(); @@ -1026,7 +1033,7 @@ public class CassandraMetadataRepository { for ( Map.Entry> entry : metadataFacetsPerFacetIds.entrySet() ) { - MetadataFacetFactory metadataFacetFactory = metadataFacetFactories.get( entry.getKey() ); + MetadataFacetFactory metadataFacetFactory = getFacetFactory( entry.getKey() ); if ( metadataFacetFactory != null ) { MetadataFacet metadataFacet = metadataFacetFactory.createMetadataFacet(); @@ -1445,7 +1452,7 @@ public class CassandraMetadataRepository String cf = cassandraArchivaManager.getMetadataFacetFamilyName(); - for ( final String facetId : metadataFacetFactories.keySet() ) + for ( final String facetId : getSupportedFacets() ) { MetadataFacet metadataFacet = facetedMetadata.getFacet( facetId ); if ( metadataFacet == null ) @@ -1518,6 +1525,75 @@ public class CassandraMetadataRepository return facets; } + private Spliterator createResultSpliterator( QueryResult> result, Function, T> converter) throws MetadataRepositoryException + { + final int size = result.get().getCount(); + return new Spliterator( ) + { + @Override + public boolean tryAdvance( Consumer action ) + { + if (size>=1) + { + for ( Row row : result.get( ) ) + { + T item = converter.apply( row ); + if ( item != null ) + { + action.accept( item ); + return true; + } + } + + } + return false; + } + + @Override + public Spliterator trySplit( ) + { + return null; + } + + @Override + public long estimateSize( ) + { + return size; + } + + @Override + public int characteristics( ) + { + return ORDERED+NONNULL+SIZED; + } + }; + } + + @Override + public Stream getMetadataFacetStream( RepositorySession session, String repositoryId, Class facetClazz, long offset, long maxEntries ) throws MetadataRepositoryException + { + final MetadataFacetFactory metadataFacetFactory = getFacetFactory( facetClazz ); + final String facetId = metadataFacetFactory.getFacetId( ); + + QueryResult> result = HFactory // + .createRangeSlicesQuery( keyspace, ss, ss, ss ) // + .setColumnFamily( cassandraArchivaManager.getMetadataFacetFamilyName() ) // + .setColumnNames( NAME.toString() ) // + .addEqualsExpression( REPOSITORY_NAME.toString(), repositoryId ) // + .addEqualsExpression( FACET_ID.toString(), facetId ) // + .execute(); + + return StreamSupport.stream( createResultSpliterator( result, ( Row row)-> { + ColumnSlice columnSlice = row.getColumnSlice(); + String name = getStringValue( columnSlice, NAME.toString( ) ); + T metadataFacet = metadataFacetFactory.createMetadataFacet( repositoryId, name ); + Map map = new HashMap<>( ); + map.put( getStringValue( columnSlice, KEY.toString() ), getStringValue( columnSlice, VALUE.toString() ) ); + metadataFacet.fromProperties( map ); + return metadataFacet; + }), false ); + } + @Override public boolean hasMetadataFacet( RepositorySession session, String repositoryId, String facetId ) throws MetadataRepositoryException @@ -1530,7 +1606,7 @@ public class CassandraMetadataRepository throws MetadataRepositoryException { - MetadataFacetFactory metadataFacetFactory = metadataFacetFactories.get( facetId ); + MetadataFacetFactory metadataFacetFactory = getFacetFactory( facetId ); if ( metadataFacetFactory == null ) { return null; @@ -1561,6 +1637,12 @@ public class CassandraMetadataRepository return metadataFacet; } + @Override + public T getMetadataFacet( RepositorySession session, String repositoryId, Class clazz, String name ) throws MetadataRepositoryException + { + return null; + } + @Override public void addMetadataFacet( RepositorySession session, String repositoryId, MetadataFacet metadataFacet ) throws MetadataRepositoryException @@ -1703,6 +1785,12 @@ public class CassandraMetadataRepository return artifactMetadatas; } + @Override + public Stream getArtifactsByDateRangeStream( RepositorySession session, String repositoryId, ZonedDateTime startTime, ZonedDateTime endTime, long offset, long maxEntries ) throws MetadataRepositoryException + { + return null; + } + protected ArtifactMetadata mapArtifactMetadataLongColumnSlice( ColumnSlice columnSlice ) { @@ -2175,7 +2263,7 @@ public class CassandraMetadataRepository for ( Map.Entry> entry : metadataFacetValuesPerFacetId.entrySet() ) { - MetadataFacetFactory metadataFacetFactory = metadataFacetFactories.get( entry.getKey() ); + MetadataFacetFactory metadataFacetFactory = getFacetFactory( entry.getKey() ); if ( metadataFacetFactory != null ) { List facetModels = entry.getValue(); diff --git a/archiva-modules/plugins/metadata-store-cassandra/src/main/java/org/apache/archiva/metadata/repository/cassandra/CassandraRepositorySessionFactory.java b/archiva-modules/plugins/metadata-store-cassandra/src/main/java/org/apache/archiva/metadata/repository/cassandra/CassandraRepositorySessionFactory.java index 6413fa955..63a3926d1 100644 --- a/archiva-modules/plugins/metadata-store-cassandra/src/main/java/org/apache/archiva/metadata/repository/cassandra/CassandraRepositorySessionFactory.java +++ b/archiva-modules/plugins/metadata-store-cassandra/src/main/java/org/apache/archiva/metadata/repository/cassandra/CassandraRepositorySessionFactory.java @@ -24,6 +24,7 @@ import org.apache.archiva.metadata.model.MetadataFacetFactory; import org.apache.archiva.metadata.repository.AbstractRepositorySessionFactory; import org.apache.archiva.metadata.repository.MetadataRepositoryException; import org.apache.archiva.metadata.repository.MetadataResolver; +import org.apache.archiva.metadata.repository.MetadataService; import org.apache.archiva.metadata.repository.RepositorySession; import org.apache.archiva.metadata.repository.RepositorySessionFactory; import org.apache.commons.lang.StringUtils; @@ -44,8 +45,6 @@ public class CassandraRepositorySessionFactory extends AbstractRepositorySession implements RepositorySessionFactory { - private Map metadataFacetFactories; - @Inject @Named(value = "archivaConfiguration#default") private ArchivaConfiguration configuration; @@ -59,18 +58,11 @@ public class CassandraRepositorySessionFactory extends AbstractRepositorySession @Inject private CassandraArchivaManager cassandraArchivaManager; + @Inject + private MetadataService metadataService; + public void initialize() { - Map tmpMetadataFacetFactories = - applicationContext.getBeansOfType( MetadataFacetFactory.class ); - // olamy with spring the ID.toString() is now "metadataFacetFactory#hint" - // whereas was only hint with plexus so let remove metadataFacetFactory# - metadataFacetFactories = new HashMap<>( tmpMetadataFacetFactories.size() ); - - for ( Map.Entry entry : tmpMetadataFacetFactories.entrySet() ) - { - metadataFacetFactories.put( StringUtils.substringAfterLast( entry.getKey(), "#" ), entry.getValue() ); - } } @Override @@ -83,7 +75,7 @@ public class CassandraRepositorySessionFactory extends AbstractRepositorySession public RepositorySession createSession() throws MetadataRepositoryException { CassandraMetadataRepository metadataRepository = - new CassandraMetadataRepository( metadataFacetFactories, configuration, cassandraArchivaManager ); + new CassandraMetadataRepository( metadataService, configuration, cassandraArchivaManager ); return new RepositorySession( metadataRepository, metadataResolver ); } diff --git a/archiva-modules/plugins/metadata-store-cassandra/src/test/java/org/apache/archiva/metadata/repository/cassandra/CassandraMetadataRepositoryTest.java b/archiva-modules/plugins/metadata-store-cassandra/src/test/java/org/apache/archiva/metadata/repository/cassandra/CassandraMetadataRepositoryTest.java index e7ba4eda0..b395e3657 100644 --- a/archiva-modules/plugins/metadata-store-cassandra/src/test/java/org/apache/archiva/metadata/repository/cassandra/CassandraMetadataRepositoryTest.java +++ b/archiva-modules/plugins/metadata-store-cassandra/src/test/java/org/apache/archiva/metadata/repository/cassandra/CassandraMetadataRepositoryTest.java @@ -22,6 +22,7 @@ package org.apache.archiva.metadata.repository.cassandra; import org.apache.archiva.metadata.model.MetadataFacetFactory; import org.apache.archiva.metadata.repository.AbstractMetadataRepositoryTest; import org.apache.archiva.metadata.repository.MetadataRepository; +import org.apache.archiva.metadata.repository.MetadataService; import org.apache.archiva.metadata.repository.RepositorySession; import org.apache.archiva.metadata.repository.RepositorySessionFactory; import org.apache.archiva.metadata.repository.cassandra.model.ProjectVersionMetadataModel; @@ -36,6 +37,7 @@ import javax.inject.Named; import java.nio.file.Files; import java.nio.file.Path; import java.nio.file.Paths; +import java.util.List; import java.util.Map; import static org.assertj.core.api.Assertions.assertThat; @@ -85,9 +87,11 @@ public class CassandraMetadataRepositoryTest org.apache.archiva.common.utils.FileUtils.deleteDirectory( directory ); } - Map factories = createTestMetadataFacetFactories(); + List factories = createTestMetadataFacetFactories(); + MetadataService metadataService = new MetadataService( ); + metadataService.setMetadataFacetFactories( factories ); - this.cmr = new CassandraMetadataRepository( factories, null, cassandraArchivaManager ); + this.cmr = new CassandraMetadataRepository( metadataService, null, cassandraArchivaManager ); sessionFactoryControl = EasyMock.createControl( ); sessionFactory = sessionFactoryControl.createMock( RepositorySessionFactory.class ); diff --git a/archiva-modules/plugins/metadata-store-file/src/main/java/org/apache/archiva/metadata/repository/file/FileMetadataRepository.java b/archiva-modules/plugins/metadata-store-file/src/main/java/org/apache/archiva/metadata/repository/file/FileMetadataRepository.java index 635935528..6cf7c3519 100644 --- a/archiva-modules/plugins/metadata-store-file/src/main/java/org/apache/archiva/metadata/repository/file/FileMetadataRepository.java +++ b/archiva-modules/plugins/metadata-store-file/src/main/java/org/apache/archiva/metadata/repository/file/FileMetadataRepository.java @@ -34,9 +34,11 @@ import org.apache.archiva.metadata.model.ProjectMetadata; import org.apache.archiva.metadata.model.ProjectVersionMetadata; import org.apache.archiva.metadata.model.ProjectVersionReference; import org.apache.archiva.metadata.model.Scm; +import org.apache.archiva.metadata.repository.AbstractMetadataRepository; import org.apache.archiva.metadata.repository.MetadataRepository; import org.apache.archiva.metadata.repository.MetadataRepositoryException; import org.apache.archiva.metadata.repository.MetadataResolutionException; +import org.apache.archiva.metadata.repository.MetadataService; import org.apache.archiva.metadata.repository.RepositorySession; import org.slf4j.Logger; import org.slf4j.LoggerFactory; @@ -50,6 +52,7 @@ import java.nio.file.Files; import java.nio.file.NoSuchFileException; import java.nio.file.Path; import java.nio.file.Paths; +import java.time.ZonedDateTime; import java.util.ArrayList; import java.util.Arrays; import java.util.Collection; @@ -68,9 +71,8 @@ import java.util.stream.Collectors; import java.util.stream.Stream; public class FileMetadataRepository - implements MetadataRepository + extends AbstractMetadataRepository implements MetadataRepository { - private final Map metadataFacetFactories; private final ArchivaConfiguration configuration; @@ -84,25 +86,33 @@ public class FileMetadataRepository private static final String METADATA_KEY = "metadata"; - public FileMetadataRepository( Map metadataFacetFactories, + private Map baseDirectory = new HashMap<>( ); + + public FileMetadataRepository( MetadataService metadataService, ArchivaConfiguration configuration ) { - this.metadataFacetFactories = metadataFacetFactories; + super( metadataService ); this.configuration = configuration; } private Path getBaseDirectory(String repoId ) throws IOException { - // TODO: should be configurable, like the index - ManagedRepositoryConfiguration managedRepositoryConfiguration = - configuration.getConfiguration().getManagedRepositoriesAsMap().get( repoId ); - if ( managedRepositoryConfiguration == null ) + if (!baseDirectory.containsKey( repoId )) { - return Files.createTempDirectory( repoId ); + Path baseDir; + ManagedRepositoryConfiguration managedRepositoryConfiguration = + configuration.getConfiguration( ).getManagedRepositoriesAsMap( ).get( repoId ); + if ( managedRepositoryConfiguration == null ) + { + baseDir = Files.createTempDirectory( repoId ); + } else + { + baseDir = Paths.get( managedRepositoryConfiguration.getLocation( ) ); + } + baseDirectory.put(repoId, baseDir.resolve( ".archiva" )); } - String basedir = managedRepositoryConfiguration.getLocation(); - return Paths.get( basedir, ".archiva" ); + return baseDirectory.get(repoId); } private Path getDirectory( String repoId ) @@ -339,6 +349,30 @@ public class FileMetadataRepository } } + @Override + public Stream getMetadataFacetStream( RepositorySession session, String repositoryId, Class facetClazz, long offset, long maxEntries ) throws MetadataRepositoryException + { + final MetadataFacetFactory metadataFacetFactory = getFacetFactory( facetClazz ); + if (metadataFacetFactory==null) { + return null; + } + final String facetId = metadataFacetFactory.getFacetId( ); + final String searchFile = METADATA_KEY + ".properties"; + try + { + Path directory = getMetadataDirectory( repositoryId, facetId ); + return Files.walk( directory, FileVisitOption.FOLLOW_LINKS ).filter( Files::isDirectory ) + .filter( path -> Files.exists( path.resolve( searchFile ) ) ) + .map(path -> directory.relativize(path).toString()) + .sorted() + .skip( offset ) + .limit(maxEntries) + .map(name -> getMetadataFacet( session, repositoryId, facetClazz, name )); + } catch (IOException e) { + throw new MetadataRepositoryException( e.getMessage( ), e ); + } + } + @Override public boolean hasMetadataFacet( RepositorySession session, String repositoryId, String facetId ) throws MetadataRepositoryException @@ -362,8 +396,14 @@ public class FileMetadataRepository @Override - public MetadataFacet getMetadataFacet( RepositorySession session, String repositoryId, String facetId, String name ) + public T getMetadataFacet( RepositorySession session, String repositoryId, Class facetClazz, String name ) { + final MetadataFacetFactory metadataFacetFactory = getFacetFactory( facetClazz ); + if (metadataFacetFactory==null) { + return null; + } + final String facetId = metadataFacetFactory.getFacetId( ); + Properties properties; try { @@ -379,8 +419,7 @@ public class FileMetadataRepository log.error( "Could not read properties from {}, {}: {}", repositoryId, facetId, e.getMessage(), e ); return null; } - MetadataFacet metadataFacet = null; - MetadataFacetFactory metadataFacetFactory = metadataFacetFactories.get( facetId ); + T metadataFacet = null; if ( metadataFacetFactory != null ) { metadataFacet = metadataFacetFactory.createMetadataFacet( repositoryId, name ); @@ -395,6 +434,8 @@ public class FileMetadataRepository return metadataFacet; } + + @Override public void addMetadataFacet( RepositorySession session, String repositoryId, MetadataFacet metadataFacet ) { @@ -467,6 +508,18 @@ public class FileMetadataRepository } } + @Override + public Stream getArtifactsByDateRangeStream( RepositorySession session, String repositoryId, ZonedDateTime startTime, ZonedDateTime endTime ) throws MetadataRepositoryException + { + return null; + } + + @Override + public Stream getArtifactsByDateRangeStream( RepositorySession session, String repositoryId, ZonedDateTime startTime, ZonedDateTime endTime, long offset, long maxEntries ) throws MetadataRepositoryException + { + return null; + } + private void getArtifactsByDateRange( RepositorySession session, List artifacts, String repoId, String ns, Date startTime, Date endTime ) throws MetadataRepositoryException @@ -568,7 +621,7 @@ public class FileMetadataRepository String propertyPrefix = "artifact:facet:" + id + ":"; for ( String facetId : value.split( "," ) ) { - MetadataFacetFactory factory = metadataFacetFactories.get( facetId ); + MetadataFacetFactory factory = getFacetFactory( facetId ); if ( factory == null ) { log.error( "Attempted to load unknown artifact metadata facet: {}", facetId ); @@ -1132,7 +1185,7 @@ public class FileMetadataRepository { for ( String facetId : facetIds.split( "," ) ) { - MetadataFacetFactory factory = metadataFacetFactories.get( facetId ); + MetadataFacetFactory factory = getFacetFactory( facetId ); if ( factory == null ) { log.error( "Attempted to load unknown project version metadata facet: {}", facetId ); diff --git a/archiva-modules/plugins/metadata-store-file/src/main/java/org/apache/archiva/metadata/repository/file/FileRepositorySessionFactory.java b/archiva-modules/plugins/metadata-store-file/src/main/java/org/apache/archiva/metadata/repository/file/FileRepositorySessionFactory.java index e61a845c1..82df7f32c 100644 --- a/archiva-modules/plugins/metadata-store-file/src/main/java/org/apache/archiva/metadata/repository/file/FileRepositorySessionFactory.java +++ b/archiva-modules/plugins/metadata-store-file/src/main/java/org/apache/archiva/metadata/repository/file/FileRepositorySessionFactory.java @@ -25,6 +25,7 @@ import org.apache.archiva.metadata.repository.AbstractRepositorySessionFactory; import org.apache.archiva.metadata.repository.MetadataRepository; import org.apache.archiva.metadata.repository.MetadataRepositoryException; import org.apache.archiva.metadata.repository.MetadataResolver; +import org.apache.archiva.metadata.repository.MetadataService; import org.apache.archiva.metadata.repository.RepositorySession; import org.apache.archiva.metadata.repository.RepositorySessionFactory; import org.apache.commons.lang.StringUtils; @@ -43,8 +44,6 @@ import java.util.Map; public class FileRepositorySessionFactory extends AbstractRepositorySessionFactory implements RepositorySessionFactory { - private Map metadataFacetFactories; - @Inject @Named( value = "archivaConfiguration#default" ) private ArchivaConfiguration configuration; @@ -55,20 +54,13 @@ public class FileRepositorySessionFactory extends AbstractRepositorySessionFacto @Inject private ApplicationContext applicationContext; + @Inject + private MetadataService metadataService; + public void initialize() { Map tmpMetadataFacetFactories = applicationContext.getBeansOfType( MetadataFacetFactory.class ); - // olamy with spring the "id" is now "metadataFacetFactory#hint" - // whereas was only hint with plexus so let remove metadataFacetFactory# - metadataFacetFactories = new HashMap<>( tmpMetadataFacetFactories.size() ); - - for ( Map.Entry entry : tmpMetadataFacetFactories.entrySet() ) - { - metadataFacetFactories.put( StringUtils.substringAfterLast( entry.getKey(), "#" ), entry.getValue() ); - } - - } @Override @@ -79,7 +71,7 @@ public class FileRepositorySessionFactory extends AbstractRepositorySessionFacto @Override public RepositorySession createSession() throws MetadataRepositoryException { - MetadataRepository metadataRepository = new FileMetadataRepository( metadataFacetFactories, configuration ); + MetadataRepository metadataRepository = new FileMetadataRepository( metadataService, configuration ); return new RepositorySession( metadataRepository, metadataResolver ); } diff --git a/archiva-modules/plugins/metadata-store-file/src/test/java/org/apache/archiva/metadata/repository/file/FileMetadataRepositoryTest.java b/archiva-modules/plugins/metadata-store-file/src/test/java/org/apache/archiva/metadata/repository/file/FileMetadataRepositoryTest.java index 1795518d4..41497ac61 100644 --- a/archiva-modules/plugins/metadata-store-file/src/test/java/org/apache/archiva/metadata/repository/file/FileMetadataRepositoryTest.java +++ b/archiva-modules/plugins/metadata-store-file/src/test/java/org/apache/archiva/metadata/repository/file/FileMetadataRepositoryTest.java @@ -25,6 +25,7 @@ import org.apache.archiva.configuration.ManagedRepositoryConfiguration; import org.apache.archiva.metadata.model.MetadataFacetFactory; import org.apache.archiva.metadata.repository.AbstractMetadataRepositoryTest; import org.apache.archiva.metadata.repository.MetadataRepository; +import org.apache.archiva.metadata.repository.MetadataService; import org.apache.archiva.metadata.repository.RepositorySessionFactory; import org.junit.Before; import org.junit.Ignore; @@ -32,6 +33,7 @@ import org.junit.Ignore; import java.nio.file.Files; import java.nio.file.Path; import java.nio.file.Paths; +import java.util.List; import java.util.Map; import static org.mockito.Mockito.mock; @@ -69,9 +71,11 @@ public class FileMetadataRepositoryTest org.apache.archiva.common.utils.FileUtils.deleteDirectory( directory ); } ArchivaConfiguration config = createTestConfiguration( directory ); - Map factories = createTestMetadataFacetFactories(); + List factories = createTestMetadataFacetFactories(); + MetadataService metadataService = new MetadataService( ); + metadataService.setMetadataFacetFactories( factories ); - this.repository = new FileMetadataRepository( factories, config ); + this.repository = new FileMetadataRepository( metadataService, config ); } @Override diff --git a/archiva-modules/plugins/metadata-store-jcr/src/main/java/org/apache/archiva/metadata/repository/jcr/JcrMetadataRepository.java b/archiva-modules/plugins/metadata-store-jcr/src/main/java/org/apache/archiva/metadata/repository/jcr/JcrMetadataRepository.java index 4a2c8b098..0d8a16472 100644 --- a/archiva-modules/plugins/metadata-store-jcr/src/main/java/org/apache/archiva/metadata/repository/jcr/JcrMetadataRepository.java +++ b/archiva-modules/plugins/metadata-store-jcr/src/main/java/org/apache/archiva/metadata/repository/jcr/JcrMetadataRepository.java @@ -35,10 +35,12 @@ import org.apache.archiva.metadata.model.ProjectVersionMetadata; import org.apache.archiva.metadata.model.ProjectVersionReference; import org.apache.archiva.metadata.model.Scm; import org.apache.archiva.metadata.model.maven2.MavenArtifactFacet; +import org.apache.archiva.metadata.repository.AbstractMetadataRepository; import org.apache.archiva.metadata.repository.MetadataRepository; import org.apache.archiva.metadata.repository.MetadataRepositoryException; import org.apache.archiva.metadata.repository.MetadataResolutionException; import org.apache.archiva.metadata.repository.MetadataService; +import org.apache.archiva.metadata.repository.MetadataSessionException; import org.apache.archiva.metadata.repository.RepositorySession; import org.apache.archiva.metadata.repository.stats.model.RepositoryStatistics; import org.apache.archiva.metadata.repository.stats.model.RepositoryStatisticsProvider; @@ -98,7 +100,7 @@ import static org.apache.archiva.metadata.repository.jcr.JcrConstants.*; * TODO revise reference storage */ public class JcrMetadataRepository - implements MetadataRepository, RepositoryStatisticsProvider + extends AbstractMetadataRepository implements MetadataRepository, RepositoryStatisticsProvider { @@ -120,8 +122,6 @@ public class JcrMetadataRepository private static final String QUERY_ARTIFACT_2 = "')"; - private MetadataService metadataService; - private Logger log = LoggerFactory.getLogger( JcrMetadataRepository.class ); private Repository repository; @@ -129,7 +129,7 @@ public class JcrMetadataRepository public JcrMetadataRepository( MetadataService metadataService, Repository repository ) throws RepositoryException { - this.metadataService = metadataService; + super( metadataService ); this.repository = repository; } @@ -542,21 +542,22 @@ public class JcrMetadataRepository } @Override - public Stream getMetadataFacetStream( RepositorySession session, String repositoryId, Class facetClazz ) throws MetadataRepositoryException + public Stream getMetadataFacetStream( RepositorySession session, String repositoryId, Class facetClazz, + long offset, long maxEntries) throws MetadataRepositoryException { final Session jcrSession = getSession( session ); final MetadataFacetFactory factory = metadataService.getFactory( facetClazz ); final String facetId = factory.getFacetId( ); - final String facetPath = getFacetPath( repositoryId, facetId ); - String q = "SELECT * FROM ["+FACET_NODE_TYPE+"] AS facet WHERE ISDESCENDANTNODE(facet, [/"+facetPath+"])"; + final String facetPath = '/'+getFacetPath( repositoryId, facetId ); + String q = "SELECT * FROM ["+FACET_NODE_TYPE+"] AS facet WHERE ISDESCENDANTNODE(facet, ["+facetPath+"]) ORDER BY [facet].[archiva:name]"; Map params = new HashMap<>( ); - QueryResult result = runNativeJcrQuery( jcrSession, q, params ); + QueryResult result = runNativeJcrQuery( jcrSession, q, params, offset, maxEntries ); return StreamSupport.stream( createResultSpliterator( result, (Row row)-> { try { Node node = row.getNode( "facet" ); - String path = StringUtils.removeStart( node.getPath(), facetPath); - return createFacet( factory, node, repositoryId, path ); + String facetName = node.getProperty( "archiva:name" ).getString(); + return createFacet( factory, node, repositoryId, facetName ); } catch ( RepositoryException e ) { @@ -566,12 +567,6 @@ public class JcrMetadataRepository } - @Override - public Stream getMetadataFacetStream( RepositorySession session, String repositoryId, Class facetClazz, long offset, long maxEntries ) throws MetadataRepositoryException - { - return null; - } - private void recurse( List facets, String prefix, Node node ) throws RepositoryException { @@ -599,14 +594,14 @@ public class JcrMetadataRepository return null; } final Session jcrSession = getSession( session ); - final MetadataFacetFactory factory = metadataService.getFactory( clazz ); + final MetadataFacetFactory factory = getFacetFactory( clazz ); final String facetId = factory.getFacetId( ); try { Node root = jcrSession.getRootNode(); Node node = root.getNode( getFacetPath( repositoryId, facetId, name ) ); - if ( metadataService.getSupportedFacets().size()==0) + if ( getSupportedFacets().size()==0) { return null; } @@ -645,13 +640,6 @@ public class JcrMetadataRepository return null; } - @Override - public MetadataFacet getMetadataFacet( RepositorySession session, String repositoryId, String facetId, String name ) - throws MetadataRepositoryException - { - return getMetadataFacet( session, repositoryId, metadataService.getFactoryClassForId( facetId ), name ); - } - @Override public void addMetadataFacet( RepositorySession session, String repositoryId, MetadataFacet metadataFacet ) throws MetadataRepositoryException @@ -665,19 +653,21 @@ public class JcrMetadataRepository String id = metadataFacet.getFacetId(); Node facetNode = JcrUtils.getOrAddNode( facets, id ); - Node node = getOrAddNodeByPath( facetNode, metadataFacet.getName() ); - if (!node.isNodeType( FACET_NODE_TYPE )) + Node facetInstance = getOrAddNodeByPath( facetNode, metadataFacet.getName() ); + if (!facetInstance.isNodeType( FACET_NODE_TYPE )) { - node.addMixin( FACET_NODE_TYPE ); - node.setProperty( "facetId", id ); + facetInstance.addMixin( FACET_NODE_TYPE ); + facetInstance.setProperty( "archiva:facetId", id ); + facetInstance.setProperty( "archiva:name", metadataFacet.getName( ) ); } for ( Map.Entry entry : metadataFacet.toProperties().entrySet() ) { - node.setProperty( entry.getKey(), entry.getValue() ); + facetInstance.setProperty( entry.getKey(), entry.getValue() ); } + session.save(); } - catch ( RepositoryException e ) + catch ( RepositoryException | MetadataSessionException e ) { throw new MetadataRepositoryException( e.getMessage(), e ); } @@ -695,7 +685,7 @@ public class JcrMetadataRepository if ( root.hasNode( path ) ) { Node node = root.getNode( path ); - if ( node.isNodeType( org.apache.archiva.metadata.repository.jcr.JcrConstants.NAMESPACE_NODE_TYPE ) ) + if ( node.isNodeType( NAMESPACE_NODE_TYPE ) ) { node.remove(); } @@ -801,12 +791,6 @@ public class JcrMetadataRepository return artifacts; } - @Override - public Stream getArtifactsByDateRangeStream( RepositorySession session, String repositoryId, ZonedDateTime startTime, ZonedDateTime endTime ) throws MetadataRepositoryException - { - return null; - } - @Override public Stream getArtifactsByDateRangeStream( RepositorySession session, String repositoryId, ZonedDateTime startTime, ZonedDateTime endTime, long offset, long maxEntries ) throws MetadataRepositoryException { @@ -887,7 +871,12 @@ public class JcrMetadataRepository return artifacts; } - public QueryResult runNativeJcrQuery( final Session jcrSession, final String q, final Map bindingParam) + public QueryResult runNativeJcrQuery( final Session jcrSession, final String q, final Map bindingParam) throws MetadataRepositoryException + { + return runNativeJcrQuery( jcrSession, q, bindingParam, 0, Long.MAX_VALUE ); + } + + public QueryResult runNativeJcrQuery( final Session jcrSession, final String q, final Map bindingParam, long offset, long maxEntries) throws MetadataRepositoryException { Map bindings; @@ -899,8 +888,10 @@ public class JcrMetadataRepository try { - log.debug( "Query: {}", q ); + log.debug( "Query: offset={}, limit={}, query={}", offset, maxEntries, q ); Query query = jcrSession.getWorkspace().getQueryManager().createQuery( q, Query.JCR_SQL2 ); + query.setLimit( maxEntries ); + query.setOffset( offset ); ValueFactory valueFactory = jcrSession.getValueFactory(); for ( Entry entry : bindings.entrySet() ) { @@ -1350,7 +1341,7 @@ public class JcrMetadataRepository try { - return getNodeNames( getSession(session), path, org.apache.archiva.metadata.repository.jcr.JcrConstants.NAMESPACE_NODE_TYPE ); + return getNodeNames( getSession(session), path, NAMESPACE_NODE_TYPE ); } catch ( MetadataRepositoryException e ) { @@ -1823,7 +1814,7 @@ public class JcrMetadataRepository throws RepositoryException { Node repo = getOrAddRepositoryContentNode( jcrSession, repositoryId ); - return getOrAddNodeByPath( repo, namespace.replace( '.', '/' ), org.apache.archiva.metadata.repository.jcr.JcrConstants.NAMESPACE_NODE_TYPE ); + return getOrAddNodeByPath( repo, namespace.replace( '.', '/' ), NAMESPACE_NODE_TYPE ); } private Node getOrAddProjectNode( Session jcrSession, String repositoryId, String namespace, String projectId ) diff --git a/archiva-modules/plugins/metadata-store-jcr/src/main/java/org/apache/archiva/metadata/repository/jcr/OakRepositoryFactory.java b/archiva-modules/plugins/metadata-store-jcr/src/main/java/org/apache/archiva/metadata/repository/jcr/OakRepositoryFactory.java index e9982dc52..56f17b42f 100644 --- a/archiva-modules/plugins/metadata-store-jcr/src/main/java/org/apache/archiva/metadata/repository/jcr/OakRepositoryFactory.java +++ b/archiva-modules/plugins/metadata-store-jcr/src/main/java/org/apache/archiva/metadata/repository/jcr/OakRepositoryFactory.java @@ -77,6 +77,7 @@ import org.slf4j.LoggerFactory; import javax.annotation.Nonnull; import javax.jcr.Repository; +import java.io.Closeable; import java.io.IOException; import java.nio.file.Files; import java.nio.file.Path; @@ -467,7 +468,7 @@ public class OakRepositoryFactory FACET_NODE_TYPE // ), Type.STRINGS ); IndexDefinitionBuilder idxBuilder = new IndexDefinitionBuilder( lucene ); - idxBuilder.async( "async", "nrt" ).includedPaths( "/repositories" ).evaluatePathRestrictions(); + idxBuilder.async( "async", "nrt", "sync" ).includedPaths( "/repositories" ).evaluatePathRestrictions(); initBaseRule(idxBuilder.indexRule( REPOSITORY_NODE_TYPE )); initBaseRule(idxBuilder.indexRule( NAMESPACE_NODE_TYPE )) @@ -485,8 +486,12 @@ public class OakRepositoryFactory .property( "whenGathered" ).type("Date").propertyIndex().analyzed().ordered() .property("size").type("Long").propertyIndex().analyzed().ordered() .property("version").propertyIndex().analyzed().ordered(); + initRegexAll( idxBuilder.indexRule( FACET_NODE_TYPE ) ) - .property("facetId").propertyIndex().analyzed().ordered(); + .property("archiva:facetId").propertyIndex().analyzed().ordered() + .property("archiva:name").propertyIndex().analyzed().ordered(); + + idxBuilder.indexRule( MIXIN_META_SCM ) .property( "scm.connection" ).propertyIndex() .property( "scm.developerConnection" ).propertyIndex() @@ -525,9 +530,6 @@ public class OakRepositoryFactory log.info( "Index: {} repo-lucene: {}", lucene, lucene.getChildNode( "repo-lucene" ) ); log.info( "repo-lucene Properties: {}", lucene.getChildNode( "repo-lucene" ).getProperties( ) ); } else { - - NodeBuilder lucene = oakIdx.child( "repo-lucene" ); - lucene.setProperty( "reindex", true ); log.info( "No Index update" ); } // IndexUtils.createIndexDefinition( ) @@ -557,73 +559,36 @@ public class OakRepositoryFactory Repository r = jcr.createRepository(); stopWatch.stop(); log.info( "time to create jcr repository: {} ms", stopWatch.getTime() ); -// try -// { -// Thread.currentThread().sleep( 1000 ); -// } -// catch ( InterruptedException e ) -// { -// log.error( e.getMessage(), e ); -// } + return r; } - public void close() - { - log.info( "Closing JCR RepositoryFactory" ); - if ( fileStore != null ) - { - fileStore.close(); - } - - if (backgroundObserver != null){ - backgroundObserver.close(); - } - - if (externalIndexObserver != null){ - externalIndexObserver.close(); - } - - if (indexProvider != null) { - indexProvider.close(); - indexProvider = null; - } - - if (documentQueue != null){ + private void closeSilently( Closeable service) { + if (service!=null) { try { - documentQueue.close(); + service.close(); } - catch ( IOException e ) + catch ( Throwable e ) { - e.printStackTrace( ); - } - } - - if (nrtIndexFactory != null){ - try - { - nrtIndexFactory.close(); - } - catch ( IOException e ) - { - e.printStackTrace( ); + // } } + } - //Close the copier first i.e. before executorService - if (indexCopier != null){ - try - { - indexCopier.close(); - } - catch ( IOException e ) - { - e.printStackTrace( ); - } - } + public void close() + { + log.info( "Closing JCR RepositoryFactory" ); + closeSilently( fileStore ); + closeSilently( backgroundObserver ); + closeSilently( externalIndexObserver ); + closeSilently( indexProvider ); + indexProvider = null; + closeSilently( documentQueue ); + closeSilently( nrtIndexFactory ); + closeSilently( indexCopier ); if (executorService != null){ executorService.shutdown(); diff --git a/archiva-modules/plugins/metadata-store-jcr/src/main/resources/org/apache/archiva/metadata/repository/jcr/jcr-schema.cnd b/archiva-modules/plugins/metadata-store-jcr/src/main/resources/org/apache/archiva/metadata/repository/jcr/jcr-schema.cnd index 9b56d3fd5..ce33089a8 100644 --- a/archiva-modules/plugins/metadata-store-jcr/src/main/resources/org/apache/archiva/metadata/repository/jcr/jcr-schema.cnd +++ b/archiva-modules/plugins/metadata-store-jcr/src/main/resources/org/apache/archiva/metadata/repository/jcr/jcr-schema.cnd @@ -106,4 +106,5 @@ + * (archiva:facet) multiple [archiva:facet] > archiva:base mixin - - facetId \ No newline at end of file + - archiva:facetId + - archiva:name \ No newline at end of file -- cgit v1.2.3