From 34d960634636a77bad37af324c5ade16263de684 Mon Sep 17 00:00:00 2001 From: Olivier Lamy Date: Wed, 5 Oct 2011 14:49:22 +0000 Subject: [PATCH] [MRM-1327] implement alternative or improve repository metadata storage: if no repository.xml found in ${appserver.base}/conf/repository.xml revert to the default found in resources. git-svn-id: https://svn.apache.org/repos/asf/archiva/trunk@1179245 13f79535-47bb-0310-9956-ffa450edef68 --- .../archiva-web/archiva-webapp/pom.xml | 1 - .../src/appserver-base/conf/repository.xml | 48 ---------------- .../startup/ArchivaJcrRepositoryConfig.java | 55 +++++++++++++++++++ .../resources/META-INF/spring-context.xml | 2 +- .../org/apache/archiva}/repository.xml | 0 5 files changed, 56 insertions(+), 50 deletions(-) delete mode 100644 archiva-modules/archiva-web/archiva-webapp/src/appserver-base/conf/repository.xml create mode 100644 archiva-modules/archiva-web/archiva-webapp/src/main/java/org/apache/archiva/web/startup/ArchivaJcrRepositoryConfig.java rename {archiva-jetty/src/main/conf => archiva-modules/archiva-web/archiva-webapp/src/main/resources/org/apache/archiva}/repository.xml (100%) diff --git a/archiva-modules/archiva-web/archiva-webapp/pom.xml b/archiva-modules/archiva-web/archiva-webapp/pom.xml index bb1650e85..4926e8731 100644 --- a/archiva-modules/archiva-web/archiva-webapp/pom.xml +++ b/archiva-modules/archiva-web/archiva-webapp/pom.xml @@ -465,7 +465,6 @@ org.apache.jackrabbit jackrabbit-core - runtime commons-logging diff --git a/archiva-modules/archiva-web/archiva-webapp/src/appserver-base/conf/repository.xml b/archiva-modules/archiva-web/archiva-webapp/src/appserver-base/conf/repository.xml deleted file mode 100644 index 4cf264f3e..000000000 --- a/archiva-modules/archiva-web/archiva-webapp/src/appserver-base/conf/repository.xml +++ /dev/null @@ -1,48 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - diff --git a/archiva-modules/archiva-web/archiva-webapp/src/main/java/org/apache/archiva/web/startup/ArchivaJcrRepositoryConfig.java b/archiva-modules/archiva-web/archiva-webapp/src/main/java/org/apache/archiva/web/startup/ArchivaJcrRepositoryConfig.java new file mode 100644 index 000000000..9c414133a --- /dev/null +++ b/archiva-modules/archiva-web/archiva-webapp/src/main/java/org/apache/archiva/web/startup/ArchivaJcrRepositoryConfig.java @@ -0,0 +1,55 @@ +package org.apache.archiva.web.startup; +/* + * 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. + */ + +import org.apache.jackrabbit.core.config.ConfigurationException; +import org.apache.jackrabbit.core.config.RepositoryConfig; +import org.slf4j.LoggerFactory; + +import java.io.File; + +/** + * @author Olivier Lamy + */ +public class ArchivaJcrRepositoryConfig +{ + public static RepositoryConfig create( String file, String home ) + throws ConfigurationException + { + File homeFile = new File( home ); + if ( !homeFile.exists( ) ) + { + homeFile.mkdirs( ); + + } + + File configurationFile = new File( file ); + if ( !configurationFile.exists( ) ) + { + String resourcePath = "org/apache/archiva/repository.xml"; + LoggerFactory.getLogger( ArchivaJcrRepositoryConfig.class ).info( + "now repository.xml file in path {} so use default from resources path {}", file, resourcePath ); + // use bundled repository.xml + return RepositoryConfig.create( + Thread.currentThread( ).getContextClassLoader( ).getResourceAsStream( resourcePath ), home ); + } + + return RepositoryConfig.create( file, home ); + } +} diff --git a/archiva-modules/archiva-web/archiva-webapp/src/main/resources/META-INF/spring-context.xml b/archiva-modules/archiva-web/archiva-webapp/src/main/resources/META-INF/spring-context.xml index 034abf343..13ffc0015 100755 --- a/archiva-modules/archiva-web/archiva-webapp/src/main/resources/META-INF/spring-context.xml +++ b/archiva-modules/archiva-web/archiva-webapp/src/main/resources/META-INF/spring-context.xml @@ -38,7 +38,7 @@ - + diff --git a/archiva-jetty/src/main/conf/repository.xml b/archiva-modules/archiva-web/archiva-webapp/src/main/resources/org/apache/archiva/repository.xml similarity index 100% rename from archiva-jetty/src/main/conf/repository.xml rename to archiva-modules/archiva-web/archiva-webapp/src/main/resources/org/apache/archiva/repository.xml -- 2.39.5