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

org.dbflute.system.DBFluteSystem Maven / Gradle / Ivy

/*
 * Copyright 2014-2015 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.system;

import java.sql.Timestamp;
import java.time.LocalDate;
import java.time.LocalDateTime;
import java.time.ZonedDateTime;
import java.util.Date;
import java.util.Locale;
import java.util.TimeZone;

import org.dbflute.system.provider.DfCurrentDateProvider;
import org.dbflute.system.provider.DfFinalLocaleProvider;
import org.dbflute.system.provider.DfFinalTimeZoneProvider;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

/**
 * @author jflute
 */
public class DBFluteSystem {

    // ===================================================================================
    //                                                                          Definition
    //                                                                          ==========
    /** The logger instance for this class. (NotNull) */
    private static final Logger _log = LoggerFactory.getLogger(DBFluteSystem.class);

    // ===================================================================================
    //                                                                    Option Attribute
    //                                                                    ================
    /**
     * The provider of current date for DBFlute system. 
* e.g. AccessContext might use this (actually, very very rare case)
* (NullAllowed: if null, server date might be used) */ protected static DfCurrentDateProvider _currentDateProvider; /** * The provider of final default locale for DBFlute system.
* e.g. DisplaySql, Date conversion, LocalDate mapping and so on...
* (NullAllowed: if null, server locale might be used) */ protected static DfFinalLocaleProvider _finalLocaleProvider; /** * The provider of final default time-zone for DBFlute system.
* e.g. DisplaySql, Date conversion, LocalDate mapping and so on...
* (NullAllowed: if null, server zone might be used) */ protected static DfFinalTimeZoneProvider _finalTimeZoneProvider; /** Is this system adjustment locked? */ protected static boolean _locked = true; // =================================================================================== // Current Time // ============ // #dateParade /** * Get current local date. (server date if no provider) * @return The new-created local date instance as current date. (NotNull) */ public static LocalDate currentLocalDate() { return currentZonedDateTime().toLocalDate(); } /** * Get current local date-time. (server date if no provider) * @return The new-created local date instance as current date. (NotNull) */ public static LocalDateTime currentLocalDateTime() { return currentZonedDateTime().toLocalDateTime(); } /** * Get current zoned date-time. (server date if no provider) * @return The new-created zoned date instance as current date. (NotNull) */ public static ZonedDateTime currentZonedDateTime() { final TimeZone timeZone = getFinalTimeZone(); return ZonedDateTime.ofInstant(currentDate().toInstant(), timeZone.toZoneId()); } /** * Get current date. (server date if no provider) * @return The new-created date instance as current date. (NotNull) */ public static Date currentDate() { return new Date(currentTimeMillis()); } /** * Get current time-stamp. (server date if no provider) * @return The new-created time-stamp instance as current date. (NotNull) */ public static Timestamp currentTimestamp() { return new Timestamp(currentTimeMillis()); } /** * Get current date as milliseconds. (server date if no provider) * @return The long value as milliseconds. */ public static long currentTimeMillis() { final long millis; if (_currentDateProvider != null) { millis = _currentDateProvider.currentTimeMillis(); } else { millis = System.currentTimeMillis(); } return millis; } // =================================================================================== // Final Locale // ============ /** * Get the final default locale for DBFlute system.
* basically for e.g. DisplaySql, Date conversion, LocalDate mapping and so on... * @return The final default locale for DBFlute system. (NotNull: if no provider, server locale) */ public static Locale getFinalLocale() { return _finalLocaleProvider != null ? _finalLocaleProvider.provide() : Locale.getDefault(); } // =================================================================================== // Final TimeZone // ============== /** * Get the final default time-zone for DBFlute system.
* basically for e.g. DisplaySql, Date conversion, LocalDate mapping and so on... * @return The final default time-zone for DBFlute system. (NotNull: if no provider, server zone) */ public static TimeZone getFinalTimeZone() { return _finalTimeZoneProvider != null ? _finalTimeZoneProvider.provide() : TimeZone.getDefault(); } // =================================================================================== // Line Separator // ============== /** * Get basic line separator for DBFlute process. * @return The string of line separator. (NotNull) */ public static String ln() { return "\n"; // LF is basic here // /- - - - - - - - - - - - - - - - - - - - - - - - - - - // The 'CR + LF' causes many trouble all over the world. // e.g. Oracle stored procedure // - - - - - - - - - -/ } // unused on DBFlute //public static String getSystemLn() { // return System.getProperty("line.separator"); //} // =================================================================================== // System Adjustment // ================= // ----------------------------------------------------- // Current Date // ------------ public static boolean hasCurrentDateProvider() { return _currentDateProvider != null; } public static void setCurrentDateProvider(DfCurrentDateProvider currentDateProvider) { assertUnlocked(); if (_log.isInfoEnabled()) { _log.info("...Setting currentDateProvider: " + currentDateProvider); } _currentDateProvider = currentDateProvider; lock(); // auto-lock here, because of deep world } // ----------------------------------------------------- // Final Locale // ------------ public static boolean hasFinalLocaleProvider() { return _finalTimeZoneProvider != null; } public static void setFinalLocaleProvider(DfFinalLocaleProvider finalLocaleProvider) { assertUnlocked(); if (_log.isInfoEnabled()) { _log.info("...Setting finalLocaleProvider: " + finalLocaleProvider); } _finalLocaleProvider = finalLocaleProvider; lock(); // auto-lock here, because of deep world } // ----------------------------------------------------- // Final TimeZone // -------------- public static boolean hasFinalTimeZoneProvider() { return _finalTimeZoneProvider != null; } public static void setFinalTimeZoneProvider(DfFinalTimeZoneProvider finalTimeZoneProvider) { assertUnlocked(); if (_log.isInfoEnabled()) { _log.info("...Setting finalTimeZoneProvider: " + finalTimeZoneProvider); } _finalTimeZoneProvider = finalTimeZoneProvider; lock(); // auto-lock here, because of deep world } // =================================================================================== // System Lock // =========== public static void lock() { if (_locked) { return; } if (_log.isInfoEnabled()) { _log.info("...Locking the DBFlute system"); } _locked = true; } public static void unlock() { if (!_locked) { return; } if (_log.isInfoEnabled()) { _log.info("...Unlocking the DBFlute system"); } _locked = false; } public static boolean isLocked() { return _locked; } protected static void assertUnlocked() { if (!isLocked()) { return; } throw new IllegalStateException("The DBFlute system is locked."); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy