All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.netflix.config.ClasspathPropertiesConfiguration Maven / Gradle / Ivy

There is a newer version: 0.40.13
Show newest version
/**
 * Copyright 2014 Netflix, Inc.
 *
 * Licensed 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.
 */
package com.netflix.config;

import java.util.Properties;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

/**
 * A Conventional Standard based approach to modular configuration
 * 
 * Assuming your application utilizes many modules (.jar files) and need
 * Properties support, this class provides a convention based approach to
 * scanning and loading properties from every jar in a classpath from a specific
 * location. All modules are assumed to have properties in a location such as
 * META-INF/conf/configuration.properties. Such resources may be anywhere in the
 * classpath; for example in directories for a unit test or application.
 * 
 * Parameters from such resources are contained in a Configuration whose name is
 * usually the name of the .jar; for example
 * "com.netflix.movieserviceclient.jar". For a resource not in a .jar, the
 * Configuration name is the URL of the directory that contains the resource.
 * However, if the resource contains a property named conf.configName, its
 * value will be used as the Configuration name.
 * 

* Such properties are often used in Spring, by defining a * PropertyPlaceholderConfigurer that gets parameter values from * ClasspathConfiguration.getProperties(). * * @author stonse */ public class ClasspathPropertiesConfiguration extends ConcurrentMapConfiguration { private static final Logger log = LoggerFactory .getLogger(ClasspathPropertiesConfiguration.class); static String propertiesResourceRelativePath = "META-INF/conf/config.properties"; static ClasspathPropertiesConfiguration instance = null; /** * Dead Code. No longer needed. Deprecate first before removing. */ @Deprecated static String configNameProperty = "config.configName"; /** You can't instantiate this class. */ private ClasspathPropertiesConfiguration() { } /** * No longer needed. Deprecate first before removing. * @return */ @Deprecated public String getConfigNameProperty() { return configNameProperty; } /** * Sets the name for the property name that defines the name for a bag of * properties loaded from a properties resources * * Default if not set is config.configName * Dead code. No longer needed. Deprecate first before removing. * * @param configNameProperty */ @Deprecated public static void setConfigNameProperty(String configNameProperty) { ClasspathPropertiesConfiguration.configNameProperty = configNameProperty; } public String getPropertiesResourceRelativePath() { return propertiesResourceRelativePath; } /** * Set relative class path for the config file * @param propertiesResourceRelativePath New relative path of config file */ public static void setPropertiesResourceRelativePath( String propertiesResourceRelativePath) { ClasspathPropertiesConfiguration.propertiesResourceRelativePath = propertiesResourceRelativePath; } /** * Returns properties from this configuration */ public Properties getProperties() { return instance !=null ? instance.getProperties() : new Properties(); } public static void initialize() { try { instance = new ClasspathPropertiesConfiguration(); loadResources(propertiesResourceRelativePath); } catch (Exception e) { throw new RuntimeException( "failed to read configuration properties from classpath", e); } } private static void loadResources(String resourceName) throws Exception { ConfigurationManager.loadPropertiesFromResources(resourceName); log.debug("Added properties from:" + resourceName); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy