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

org.dbflute.helper.jprop.ObjectiveProperties Maven / Gradle / Ivy

/*
 * Copyright 2014-2020 the original author or authors.
 *
 * 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 org.dbflute.helper.jprop;

import java.io.IOException;
import java.io.InputStream;
import java.math.BigDecimal;
import java.util.Date;
import java.util.List;

import org.dbflute.util.DfCollectionUtil;
import org.dbflute.util.DfTypeUtil;
import org.dbflute.util.DfTypeUtil.ParseDateException;
import org.dbflute.util.DfTypeUtil.ParseDateNumberFormatException;
import org.dbflute.util.DfTypeUtil.ParseDateOutOfCalendarException;

/**
 * The properties object that can be objective. 
* You can make properties that extends other (super) properties. * @author jflute * @since 1.0.1 (2012/12/30 Sunday) */ public class ObjectiveProperties { // =================================================================================== // Attribute // ========= /** The resource path of (base-point) properties loaded by class loader. (NotNull) */ protected final String _resourcePath; // ----------------------------------------------------- // Option // ------ /** The list of resource path of extends properties loaded by class loader. (NotNull, EmptyAllowed) */ protected List _extendsResourcePathList = DfCollectionUtil.newArrayListSized(4); /** Does it check the implicit override property? */ protected boolean _checkImplicitOverride; /** The encoding for stream to the properties file. (NullAllowed: if nul, use default encoding) */ protected String _streamEncoding; // used if set // ----------------------------------------------------- // Contents // -------- /** The result of java properties reading. (NotNull: after loading) */ protected JavaPropertiesResult _javaPropertiesResult; // =================================================================================== // Constructor // =========== /** * @param resourcePath The path of the property as resource for this class loader. (NotNull) */ public ObjectiveProperties(String resourcePath) { _resourcePath = resourcePath; } // ----------------------------------------------------- // Option // ------ /** * Set the properties paths to extends them. * @param extendsResourcePaths The varying array of path for resources to extends. (NotNull) * @return this. (NotNull) */ public ObjectiveProperties extendsProperties(String... extendsResourcePaths) { if (extendsResourcePaths != null && extendsResourcePaths.length > 0) { for (String extendsResourcePath : extendsResourcePaths) { _extendsResourcePathList.add(extendsResourcePath); } } return this; } /** * Enable implicit override check.
* If the property existing in super-properties is set in sub-properties implicitly, * an exception is thrown (you can detect the wrong situation). * You can override by override annotation in the line comment like this: *
     * # @Override here is comment area, you can write about the property
     * foo.bar = qux
     * 
* And if the property with override annotation but no existence in super-properties, * an exception is thrown (you can detect the wrong situation). * @return this. (NotNull) */ public ObjectiveProperties checkImplicitOverride() { _checkImplicitOverride = true; return this; } /** * Encode the stream to the properties file as UTF-8.
* If not use this, encoded as default encoding. * @return this. (NotNull) */ public ObjectiveProperties encodeAsUTF8() { _streamEncoding = "UTF-8"; return this; } // =================================================================================== // Load Properties // =============== /** * Load properties.
* You can get properties after loading. * @return this. (NotNull) */ public ObjectiveProperties load() { final String title = toTitle(_resourcePath); final JavaPropertiesReader reader = createJavaPropertiesReader(title); prepareExtendsProperties(reader); if (_checkImplicitOverride) { reader.checkImplicitOverride(); } if (_streamEncoding != null) { reader.encodeAs(_streamEncoding); } _javaPropertiesResult = reader.read(); return this; } protected JavaPropertiesReader createJavaPropertiesReader(final String title) { return new JavaPropertiesReader(title, createJavaPropertiesStreamProvider()); } protected JavaPropertiesStreamProvider createJavaPropertiesStreamProvider() { return new JavaPropertiesStreamProvider() { public InputStream provideStream() throws IOException { return toStream(_resourcePath); } }; } protected void prepareExtendsProperties(final JavaPropertiesReader reader) { for (final String extendsResourcePath : _extendsResourcePathList) { final String title = toTitle(extendsResourcePath); reader.extendsProperties(title, new JavaPropertiesStreamProvider() { public InputStream provideStream() throws IOException { return toStream(extendsResourcePath); } }); } } protected String toTitle(String path) { return DfTypeUtil.toClassTitle(this) + ":" + path; } protected InputStream toStream(String resourcePath) { return getClass().getClassLoader().getResourceAsStream(resourcePath); } // =================================================================================== // Get Property // ============ /** * Get the value of property as {@link String}. * @param propertyKey The key of the property. (NotNull) * @return The value of found property. (NullAllowed: if null, not found) */ public String get(String propertyKey) { final JavaPropertiesProperty property = _javaPropertiesResult.getProperty(propertyKey); return property != null ? property.getPropertyValue() : null; } /** * Get the value of property as {@link Integer}. * @param propertyKey The key of the property. (NotNull) * @return The value of found property. (NullAllowed: if null, not found) * @throws NumberFormatException When the property is not integer. */ public Integer getAsInteger(String propertyKey) { final String value = get(propertyKey); return value != null ? DfTypeUtil.toInteger(value) : null; } /** * Get the value of property as {@link Long}. * @param propertyKey The key of the property. (NotNull) * @return The value of found property. (NullAllowed: if null, not found) * @throws NumberFormatException When the property is not long. */ public Long getAsLong(String propertyKey) { final String value = get(propertyKey); return value != null ? DfTypeUtil.toLong(value) : null; } /** * Get the value of property as {@link BigDecimal}. * @param propertyKey The key of the property. (NotNull) * @return The value of found property. (NullAllowed: if null, not found) * @throws NumberFormatException When the property is not decimal. */ public BigDecimal getAsDecimal(String propertyKey) { final String value = get(propertyKey); return value != null ? DfTypeUtil.toBigDecimal(value) : null; } /** * Get the value of property as {@link Date}. * @param propertyKey The key of the property. (NotNull) * @return The value of found property. (NullAllowed: if null, not found) * @throws ParseDateException When it failed to parse the string to date. * @throws ParseDateNumberFormatException When it failed to format the elements as number. * @throws ParseDateOutOfCalendarException When the date was out of calendar. (if BC, not thrown) */ public Date getAsDate(String propertyKey) { final String value = get(propertyKey); return value != null ? DfTypeUtil.toDate(value) : null; } /** * Is the property true? * @param propertyKey The key of the property which is boolean type. (NotNull) * @return The determination, true or false. (if the property can be true, returns true) */ public boolean is(String propertyKey) { final String value = get(propertyKey); return value != null && value.trim().equalsIgnoreCase("true"); } // =================================================================================== // Basic Override // ============== @Override public boolean equals(Object obj) { if (obj == null || !(obj instanceof ObjectiveProperties)) { return false; } final ObjectiveProperties another = (ObjectiveProperties) obj; if (_javaPropertiesResult == null) { return another._javaPropertiesResult == null; } return _javaPropertiesResult.equals(another._javaPropertiesResult); } @Override public int hashCode() { return _javaPropertiesResult != null ? _javaPropertiesResult.hashCode() : 0; } @Override public String toString() { return DfTypeUtil.toClassTitle(this) + ":{" + _javaPropertiesResult + "}"; } // =================================================================================== // Accessor // ======== /** * Get the resource path of (base-point) properties loaded by class loader. (NotNull) * @return The path string for the resource. (NotNull) */ public String getResourcePath() { return _resourcePath; } /** * Get the list of resource path of extends properties loaded by class loader. * @return The list of path string for the resource. (NotNull, EmptyAllowed) */ public List getExtendsResourcePathList() { return _extendsResourcePathList; } /** * Does it check the implicit override property? * @return The determination, true or false. */ public boolean isCheckImplicitOverride() { return _checkImplicitOverride; } /** * Get the result of java properties reading. * @return The result of java properties reading. (NotNull: after loading) */ public JavaPropertiesResult getJavaPropertiesResult() { return _javaPropertiesResult; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy