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

io.debezium.time.MicroTime Maven / Gradle / Ivy

The newest version!
/*
 * Copyright Debezium Authors.
 *
 * Licensed under the Apache Software License version 2.0, available at http://www.apache.org/licenses/LICENSE-2.0
 */
package io.debezium.time;

import java.time.Duration;
import java.time.LocalTime;

import org.apache.kafka.connect.data.Schema;
import org.apache.kafka.connect.data.SchemaBuilder;

/**
 * A utility for converting various Java time representations into the {@link SchemaBuilder#int64() INT64} number of
 * microseconds since midnight, and for defining a Kafka Connect {@link Schema} for time values with no date or timezone
 * information.
 *
 * @author Randall Hauch
 * @see Time
 * @see NanoTime
 */
public class MicroTime {

    public static final String SCHEMA_NAME = "io.debezium.time.MicroTime";

    private static final Duration ONE_DAY = Duration.ofDays(1);

    /**
     * Returns a {@link SchemaBuilder} for a {@link MicroTime}. The resulting schema will describe a field
     * with the {@value #SCHEMA_NAME} as the {@link Schema#name() name} and {@link SchemaBuilder#int64() INT64} for the literal
     * type storing the number of microseconds past midnight.
     * 

* You can use the resulting SchemaBuilder to set or override additional schema settings such as required/optional, default * value, and documentation. * * @return the schema builder */ public static SchemaBuilder builder() { return SchemaBuilder.int64() .name(SCHEMA_NAME) .version(1); } /** * Returns a Schema for a {@link MicroTime} but with all other default Schema settings. The schema describes a field * with the {@value #SCHEMA_NAME} as the {@link Schema#name() name} and {@link SchemaBuilder#int64() INT64} for the literal * type storing the number of microseconds past midnight. * * @return the schema * @see #builder() */ public static Schema schema() { return builder().build(); } /** * Get the number of microseconds past midnight of the given {@link Duration}. * * @param value the duration value; may not be null * @param acceptLargeValues whether to accept values less than 00:00:00 and larger than 24:00:00 or not * @return the milliseconds past midnight * @throws IllegalArgumentException if the value is not an instance of the acceptable types or it is out of the supported range */ public static long toMicroOfDay(Object value, boolean acceptLargeValues) { if (value instanceof Duration) { Duration duration = (Duration) value; if (!acceptLargeValues && (duration.isNegative() || duration.compareTo(ONE_DAY) > 0)) { throw new IllegalArgumentException("Time values must be between 00:00:00 and 24:00:00 (inclusive): " + duration); } // conversion to nanos is fine as TIME values won't exceed long range return ((Duration) value).toNanos() / 1_000; } // TODO only needed for SQL Server/Oracle, where we don't produce Duration right away; // this should go eventually, as the conversion to LocalTime is superfluous LocalTime time = Conversions.toLocalTime(value); return Math.floorDiv(time.toNanoOfDay(), Conversions.NANOSECONDS_PER_MICROSECOND); } private MicroTime() { } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy