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

org.eurekaclinical.standardapis.props.EurekaClinicalProperties Maven / Gradle / Ivy

package org.eurekaclinical.standardapis.props;

/*-
 * #%L
 * Eureka! Clinical Standard APIs
 * %%
 * Copyright (C) 2016 Emory University
 * %%
 * 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.
 * #L%
 */
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.List;
import java.util.Properties;

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

/**
 *
 * @author hrathod
 */
public abstract class EurekaClinicalProperties {

    /**
     * The class level logger.
     */
    private static final Logger LOGGER = LoggerFactory.getLogger(EurekaClinicalProperties.class);
    /**
     * Name of the system property containing a pathname to the configuration
     * file.
     */
    private static final String CONFIG_DIR_SYS_PROP = "eureka.config.dir";

    private static final String PROPERTIES_FILENAME = "application.properties";

    /**
     * Fallback properties file for application configuration as a resource.
     */
    private static final String FALLBACK_CONFIG_FILE = '/' + PROPERTIES_FILENAME;

    /**
     * Holds an instance of the properties object which contains all the
     * application configuration properties.
     */
    private final Properties properties;

    private String configDir;

    /**
     * Loads the application configuration.
     *
     * There are two potential sources of application configuration. The
     * fallback configuration should always be there. The default configuration
     * directory, provided as an argument to this constructor, may optionally
     * have an application.properties file within it that overrides the fallback
     * configuration for each configuration property that is specified. The
     * eureka.config.dir system property allows specifying an
     * alternative configuration directory.
     *
     * @param defaultConfigDir the default location of configuration file, based
     * on the operating system. Cannot be null.
     */
    protected EurekaClinicalProperties(String defaultConfigDir) {
        if (defaultConfigDir == null) {
            throw new IllegalArgumentException("defaultConfigDir cannot be null");
        }
        this.properties = new Properties();
        try (InputStream inputStream = getClass().getResourceAsStream(FALLBACK_CONFIG_FILE)) {
            if (inputStream != null) {
                this.properties.load(inputStream);
            }
        } catch (IOException ioe) {
            throw new AssertionError("Fallback configuration is unavailable: " + ioe.getMessage());
        }
        this.configDir = System.getProperty(CONFIG_DIR_SYS_PROP);
        if (this.configDir == null) {
            this.configDir = defaultConfigDir;
        }
        if (this.configDir == null) {
            throw new AssertionError("eureka.config.dir not specified in " + FALLBACK_CONFIG_FILE);
        }
        this.properties.remove(CONFIG_DIR_SYS_PROP);
        File configFile = new File(this.configDir, PROPERTIES_FILENAME);
        if (configFile.exists()) {
            LOGGER.info("Trying to load default configuration from {}",
                    configFile.getAbsolutePath());
            try (InputStream inputStream = new FileInputStream(configFile)) {
                this.properties.load(inputStream);
            } catch (IOException ex) {
                LOGGER.error("Error reading application.properties file {}: {}. "
                        + "Built-in defaults will be used, some "
                        + "of which are unlikely to be what you want.",
                        configFile.getAbsolutePath(), ex.getMessage());
            }
        } else {
            LOGGER.warn("No configuration file found at {}. "
                    + "Built-in defaults will be used, some "
                    + "of which are unlikely to be what you want.",
                    configFile.getAbsolutePath());
        }
    }

    public String getConfigDir() {
        return configDir;
    }

    public String getStage() {
        return this.getValue("eurekaclinical.stage", "DEVELOPMENT");
    }
    
    /**
     * A URL representing the domain in which Eureka Clinical is installed.
     * 
     * @return a URL string.
     */
    public String getDomainUrl() {
        return getValue("eurekaclinical.domain.url", "https://localhost");
    }
    
    public abstract String getUrl();
    
    /**
     * Returns the String value of the given property name.
     *
     * @param propertyName The property name to fetch the value for.
     * @return A String containing the value of the given property name, or null
     * if the property name does not exist.
     */
    protected final String getValue(final String propertyName) {
        /*
	 * Don't use this.properties.containsKey(). It doesn't work with the
	 * built-in default value mechanism. Also, the semantics of a
	 * Properties list are such that a null property value is the same
	 * as never specified in the list.
         */
        return this.properties.getProperty(propertyName);
    }

    /**
     * Returns the String value of the given property name, or the given default
     * if the given property name does not exist.
     *
     * @param propertyName The name of the property to fetch a value for.
     * @param defaultValue The default value to return if the property name does
     * not exist.
     * @return A string containing either the value of the property, or the
     * default value.
     */
    protected final String getValue(final String propertyName, String defaultValue) {
        String value = getValue(propertyName);
        if (value == null) {
            if (defaultValue == null) {
                LOGGER.warn(
                        "Property '{}' is not specified in "
                        + getClass().getName()
                        + ", and no default is specified.", propertyName);
            }
            value = defaultValue;
        }
        return value;
    }

    /**
     * Reads in a property value as a whitespace-delimited list of items.
     *
     * @param inPropertyName The name of the property to read.
     * @return A list containing the items in the value, or null if
     * the property is not found.
     */
    protected final List getStringListValue(final String inPropertyName) {

        List result = null;
        String value = this.properties.getProperty(inPropertyName);
        if (value != null) {
            String[] temp = value.split("\\s+");
            result = new ArrayList<>(temp.length);
            for (String s : temp) {
                String trimmed = s.trim();
                if (trimmed.length() > 0) {
                    result.add(s.trim());
                }
            }
        }
        return result;
    }

    /**
     * Reads in a property value as a whitespace-delimited list of items.
     *
     * @param inPropertyName The name of the property to read.
     * @param defaultValue The value to return if the property is not found.
     * @return A list containing the items in the value.
     */
    protected final List getStringListValue(final String inPropertyName,
            List defaultValue) {

        List result = getStringListValue(inPropertyName);
        if (result == null) {
            LOGGER.warn("Property not found in configuration: {}",
                    inPropertyName);
            result = defaultValue;
        }
        return result;
    }

    /**
     * Utility method to get an int from the properties file.
     *
     * @param propertyName The name of the property.
     * @param defaultValue The default value to return, if the property is not
     * found, or is malformed.
     * @return The property value, as an int.
     */
    protected final int getIntValue(final String propertyName, int defaultValue) {
        int result;
        String property = this.properties.getProperty(propertyName);
        try {
            result = Integer.parseInt(property);
        } catch (NumberFormatException e) {
            LOGGER.warn("Invalid integer property in configuration: {}",
                    propertyName);
            result = defaultValue;
        }
        return result;
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy