diff options
4 files changed, 81 insertions, 15 deletions
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 df353fa19..bd75b5720 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 @@ -67,7 +67,7 @@ public class FileMetadataRepository private final ArchivaConfiguration configuration; - private static final Logger log = LoggerFactory.getLogger( FileMetadataRepository.class ); + private Logger log = LoggerFactory.getLogger( FileMetadataRepository.class ); private static final String PROJECT_METADATA_KEY = "project-metadata"; @@ -118,7 +118,7 @@ public class FileMetadataRepository catch ( IOException e ) { // TODO! - e.printStackTrace(); + log.error( e.getMessage(), e ); } } @@ -222,7 +222,7 @@ public class FileMetadataRepository catch ( IOException e ) { // TODO - e.printStackTrace(); //To change body of catch statement use File | Settings | File Templates. + log.error( e.getMessage(), e ); } } @@ -279,7 +279,7 @@ public class FileMetadataRepository catch ( IOException e ) { // TODO - e.printStackTrace(); //To change body of catch statement use File | Settings | File Templates. + log.error( e.getMessage(), e ); } } @@ -296,7 +296,7 @@ public class FileMetadataRepository catch ( IOException e ) { // TODO! - e.printStackTrace(); + log.error( e.getMessage(), e ); } } @@ -342,7 +342,7 @@ public class FileMetadataRepository catch ( IOException e ) { // TODO - e.printStackTrace(); //To change body of catch statement use File | Settings | File Templates. + log.error( e.getMessage(), e ); return null; } MetadataFacet metadataFacet = null; @@ -375,7 +375,7 @@ public class FileMetadataRepository catch ( IOException e ) { // TODO! - e.printStackTrace(); //To change body of catch statement use File | Settings | File Templates. + log.error( e.getMessage(), e ); } } @@ -746,7 +746,7 @@ public class FileMetadataRepository catch ( IOException e ) { // TODO - e.printStackTrace(); //To change body of catch statement use File | Settings | File Templates. + log.error( e.getMessage(), e ); } return new Properties(); } @@ -933,7 +933,7 @@ public class FileMetadataRepository MetadataFacetFactory factory = metadataFacetFactories.get( facetId ); if ( factory == null ) { - log.error( "Attempted to load unknown project version metadata facet: " + facetId ); + log.error( "Attempted to load unknown project version metadata facet: {}", facetId ); } else { 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 4301fc025..9b3ea500e 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 @@ -24,13 +24,21 @@ import org.apache.archiva.metadata.repository.MetadataRepository; import org.apache.archiva.metadata.repository.MetadataResolver; import org.apache.archiva.metadata.repository.RepositorySession; import org.apache.archiva.metadata.repository.RepositorySessionFactory; +import org.apache.commons.lang.StringUtils; import org.apache.maven.archiva.configuration.ArchivaConfiguration; +import org.springframework.context.ApplicationContext; +import org.springframework.stereotype.Service; +import javax.annotation.PostConstruct; +import javax.inject.Inject; +import javax.inject.Named; +import java.util.HashMap; import java.util.Map; /** - * @plexus.component role="org.apache.archiva.metadata.repository.RepositorySessionFactory" role-hint="file" + * plexus.component role="org.apache.archiva.metadata.repository.RepositorySessionFactory" role-hint="file" */ +@Service( "repositorySessionFactory#file" ) public class FileRepositorySessionFactory implements RepositorySessionFactory { @@ -40,15 +48,38 @@ public class FileRepositorySessionFactory private Map<String, MetadataFacetFactory> metadataFacetFactories; /** - * @plexus.requirement + * plexus.requirement */ + @Inject + @Named( value = "archivaConfiguration#default" ) private ArchivaConfiguration configuration; /** - * @plexus.requirement + * plexus.requirement */ + @Inject private MetadataResolver metadataResolver; + @Inject + private ApplicationContext applicationContext; + + @PostConstruct + public void initialize() + { + Map<String, MetadataFacetFactory> 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<String, MetadataFacetFactory>( tmpMetadataFacetFactories.size() ); + + for ( Map.Entry<String, MetadataFacetFactory> entry : tmpMetadataFacetFactories.entrySet() ) + { + metadataFacetFactories.put( StringUtils.substringAfterLast( entry.getKey(), "#" ), entry.getValue() ); + } + + + } + public RepositorySession createSession() { MetadataRepository metadataRepository = new FileMetadataRepository( metadataFacetFactories, configuration ); diff --git a/archiva-modules/plugins/metadata-store-file/src/main/resources/META-INF/spring-context.xml b/archiva-modules/plugins/metadata-store-file/src/main/resources/META-INF/spring-context.xml new file mode 100755 index 000000000..c5f30ba5c --- /dev/null +++ b/archiva-modules/plugins/metadata-store-file/src/main/resources/META-INF/spring-context.xml @@ -0,0 +1,33 @@ +<?xml version="1.0"?> + +<!-- + ~ 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. + --> +<beans xmlns="http://www.springframework.org/schema/beans" + xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" + xmlns:context="http://www.springframework.org/schema/context" + xsi:schemaLocation="http://www.springframework.org/schema/beans + http://www.springframework.org/schema/beans/spring-beans-3.0.xsd + http://www.springframework.org/schema/context + http://www.springframework.org/schema/context/spring-context-3.0.xsd" + default-lazy-init="true"> + + <context:annotation-config/> + <context:component-scan base-package="org.apache.archiva.metadata.repository.file"/> + +</beans>
\ No newline at end of file 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 3922ec0ea..05693af32 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 @@ -41,9 +41,11 @@ public class FileMetadataRepositoryTest { super.setUp(); - File directory = getTestFile( "target/test-repositories" ); - FileUtils.deleteDirectory( directory ); - + File directory = new File( "target/test-repositories" ); + if (directory.exists()) + { + FileUtils.deleteDirectory( directory ); + } ArchivaConfiguration config = createTestConfiguration( directory ); Map<String, MetadataFacetFactory> factories = createTestMetadataFacetFactories(); |