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

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

There is a newer version: 1.13.0
Show 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.math.BigDecimal;
import java.time.temporal.ChronoUnit;

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

/**
 * A utility representing a duration into a corresponding {@link SchemaBuilder#int64() INT64}
 * number of microsecond, and for defining a Kafka Connect {@link Schema} for duration values.
 *
 * @author Horia Chiorean ([email protected])
 */
public class MicroDuration {

    /**
     * The approximation used by the plugins when converting a duration to micros
     */
    public static final double DAYS_PER_MONTH_AVG = 365.25 / 12.0d;

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

    /**
     * Returns a {@link SchemaBuilder} for a {@link MicroDuration}. The resulting schema will describe a field
     * with the {@value #SCHEMA_NAME} as the {@link Schema#name() name} and {@link SchemaBuilder#float64()} FLOAT64} for the literal
     * type storing the number of microseconds for that duration.
     * 

* 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 MicroDuration} 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#float64()} FLOAT64} for the literal * type storing the number of microseconds. * * @return the schema * @see #builder() */ public static Schema schema() { return builder().build(); } private MicroDuration() { } /** * Converts a number of time units to a duration in microseconds. * * @param years a number of years * @param months a number of months * @param days a number of days * @param hours a number of hours * @param minutes a number of minutes * @param seconds a number of seconds * @param micros a number of microseconds * @param daysPerMonthAvg an optional value representing a days per month average; if null, the default duration * from {@link ChronoUnit#MONTHS} is used. * @return @return Approximate representation of the given interval as a number of microseconds */ public static long durationMicros(int years, int months, int days, int hours, int minutes, double seconds, int micros, Double daysPerMonthAvg) { if (daysPerMonthAvg == null) { daysPerMonthAvg = (double) ChronoUnit.MONTHS.getDuration().toDays(); } double numberOfDays = ((years * 12) + months) * daysPerMonthAvg + days; double numberOfSeconds = (((numberOfDays * 24 + hours) * 60) + minutes) * 60 + seconds; return (long) (numberOfSeconds * 1e6 + micros); } /** * Converts a number of time units to a duration in microseconds. * * @param years a number of years * @param months a number of months * @param days a number of days * @param hours a number of hours * @param minutes a number of minutes * @param seconds a number of seconds * @param daysPerMonthAvg an optional value representing a days per month average; if null, the default duration * from {@link ChronoUnit#MONTHS} is used. * @return a {@link BigDecimal} value which contains the number of microseconds, never {@code null} */ public static long durationMicros(int years, int months, int days, int hours, int minutes, double seconds, Double daysPerMonthAvg) { return durationMicros(years, months, days, hours, minutes, seconds, 0, daysPerMonthAvg); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy