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

com.couchbase.client.CouchbaseProperties Maven / Gradle / Ivy

/**
 * Copyright (C) 2009-2013 Couchbase, Inc.
 *
 * Permission is hereby granted, free of charge, to any person obtaining a copy
 * of this software and associated documentation files (the "Software"), to deal
 * in the Software without restriction, including without limitation the rights
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 * copies of the Software, and to permit persons to whom the Software is
 * furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be included in
 * all copies or substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALING
 * IN THE SOFTWARE.
 */

package com.couchbase.client;

import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.net.URL;
import java.util.Properties;

import net.spy.memcached.compat.CloseUtil;
import net.spy.memcached.compat.log.Logger;
import net.spy.memcached.compat.log.LoggerFactory;

/**
 * The CouchbaseProperties class abstracts system properties and those set
 * via a file exposed through a unified class.
 *
 * The main purpose of this class is to centralize property management which
 * can be called throughout the stack. If a filename is set and the properties
 * file can be loaded, the information is used. All the time, properties set
 * in the code override the file-given ones.
 *
 * The default namespace is "cbclient", which means that all properties need
 * to adhere to the "cbclient." syntax. The getProperty method
 * also allows you to pass a boolean param to control this behavior (ignore
 * the namespace at all).
 */
public final class CouchbaseProperties {

  private static Properties fileProperties = new Properties();

  private static final Logger LOGGER =
    LoggerFactory.getLogger(CouchbaseProperties.class.getName());

  private CouchbaseProperties() {}

  /**
   * The default namespace of the properties.
   */
  private static String namespace = "cbclient";

  /**
   * Set the filename of the properties file and load it (if possible).
   *
   * @param filename the filename of the properties file.
   */
  public static void setPropertyFile(String filename) {
    FileInputStream fs = null;
    try {
      if(filename == null) {
        throw new IllegalArgumentException(
          "Given property filename is null.");
      }

      URL url =  ClassLoader.getSystemResource(filename);
      if (url != null) {
        String clFilename = url.getFile();
        File propFile = new File(clFilename);
        fs = new FileInputStream(propFile);
        fileProperties.load(fs);
      } else {
        throw new IOException("File not found with system classloader.");
      }
      LOGGER.info("Successfully loaded properties file \"" + filename + "\".");
    } catch (Exception e) {
      LOGGER.debug("Could not load properties file \"" + filename + "\" because: "
        +  e.getMessage());
    } finally {
      if (fs != null) {
        CloseUtil.close(fs);
      }
    }
  }

  /**
   * Returns the property for the given name (or given default if not set).
   *
   * If a System property is found, it is returned. Otherwise, if a file
   * is set and it contains the property, it is returned. If no property
   * is found, the default is returned.
   *
   * @param name the name of the property.
   * @param def the default value to return.
   * @param ignore ignore the property namespace.
   * @return returns the property or default if not set.
   */
  public static String getProperty(String name, String def, boolean ignore) {
    if(!ignore) {
      name = namespace + "." + name;
    }

    String systemProperty = System.getProperty(name, null);
    if(systemProperty != null) {
      return systemProperty;
    }

    if(fileProperties != null
      && fileProperties.getProperty(name, null) != null) {
      return fileProperties.getProperty(name, null);
    }

    return def;
  }

  /**
   * Returns the property for the given name (or null if not set).
   *
   * @param name the name of the property.
   * @param ignore ignore the property namespace.
   * @return returns the property or null if not set.
   */
  public static String getProperty(String name, boolean ignore) {
    return getProperty(name, null, ignore);
  }

  /**
   * Returns the property for the given name (or null if not set).
   *
   * @param name the name of the property.
   * @return returns the property or null if not set.
   */
  public static String getProperty(String name) {
    return getProperty(name, null, false);
  }

  /**
   * Returns the property for the given name (or given default if not set).
   *
   * @param name the name of the property.
   * @param def the default value to return.
   * @return returns the property or the default if not set.
   */
  public static String getProperty(String name, String def) {
    return getProperty(name, def, false);
  }

  /**
   * Returns the namespace to be used for the properties.
   *
   * @return the namespace.
   */
  public static String getNamespace() {
    return namespace;
  }

  /**
   * Replaces the default (or old) namespace with this new one.
   *
   * @param ns the namespace to be used.
   */
  public static void setNamespace(String ns) {
    namespace = ns;
  }

  /**
   * Checks if there are any properties set through a properties file.
   *
   * @return true if there are file properties set.
   */
  static boolean hasFileProperties() {
    return !fileProperties.isEmpty();
  }

  /**
   * Reset the file properties to an empty state.
   */
  static void resetFileProperties() {
    fileProperties = new Properties();
  }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy