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

org.duracloud.mill.util.PropertyFileHelper Maven / Gradle / Ivy

There is a newer version: 5.1.1
Show newest version
/*
 * The contents of this file are subject to the license and copyright
 * detailed in the LICENSE and NOTICE files at the root of the source
 * tree and available online at
 *
 *     http://duracloud.org/license/
 */
package org.duracloud.mill.util;

import java.io.File;
import java.io.IOException;

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

/**
 * @author Daniel Bernstein
 */
public class PropertyFileHelper {
    private static Logger log = LoggerFactory.getLogger(PropertyFileHelper.class);

    private PropertyFileHelper() {
        // Ensures no instances are made of this class, as there are only static members.
    }

    /**
     * Ensures that a specified system property is set with a valid file path.
     * If the system property is not set, the specified default value will set instead.
     * If the resulting system property value does not resolve to an existing file,
     * The system will exit after logging the error.
     *
     * @param profileFileSystemProperty The system property to check
     * @param defaultFilePath           The default property file path
     */
    public static void loadFromSystemProperty(String propertyFileSystemProperty, String defaultPropertyFilePath) {
        String path = System.getProperty(propertyFileSystemProperty);

        if (path == null) {
            path = defaultPropertyFilePath;
            System.setProperty(propertyFileSystemProperty, path);
            log.info("Using default " + propertyFileSystemProperty + " value: "
                     + path + ".  To override default specify java commandline param -D"
                     + propertyFileSystemProperty + "=/your/prop/file/path/here");
        } else {
            log.info("Using user-defined " + propertyFileSystemProperty + " property: " + path);
        }

        if (!new File(path).exists()) {
            log.error(path + " does not exist. It is required to run this application. Exiting...");
            System.exit(1);
        } else {
            try {
                SystemPropertyLoader.load(path);
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy