org.dbflute.system.DBFluteSystem 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.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
// ============
// #date_parade
/**
* 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