blob: 09b402dc1094123d126f4253af0146a6e859a997 [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you 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.apache.kylin.engine.spark.cross
import org.apache.spark.sql.catalyst.util.{DateTimeUtils, TimestampFormatter}
import org.apache.spark.unsafe.types.UTF8String
import java.time.ZoneId
import java.util.TimeZone
object CrossDateTimeUtils {
val DEFAULT_TZ_ID = TimeZone.getDefault.toZoneId
def stringToTimestamp(value: Any): Option[Long] = {
DateTimeUtils.stringToTimestamp(UTF8String.fromString(value.toString), DEFAULT_TZ_ID)
}
def stringToTimestamp(value: Any, zoneId: ZoneId): Option[Long] = {
DateTimeUtils.stringToTimestamp(UTF8String.fromString(value.toString), zoneId)
}
def stringToDate(value: Any): Option[Int] = {
DateTimeUtils.stringToDate(UTF8String.fromString(value.toString), DEFAULT_TZ_ID)
}
def millisToDays(millis: Long): Int = {
DateTimeUtils.microsToDays(DateTimeUtils.millisToMicros(millis), DEFAULT_TZ_ID)
}
def daysToMillis(days: Int): Long = {
DateTimeUtils.microsToMillis(DateTimeUtils.daysToMicros(days, DEFAULT_TZ_ID))
}
def dateToString(): String = {
TimestampFormatter
.apply("yyyy-MM-dd", DEFAULT_TZ_ID, isParsing = false)
.format(DateTimeUtils.currentTimestamp())
}
}