data:image/s3,"s3://crabby-images/02ace/02ace956f9868cf2a1a780bd2c0a517cd3a46077" alt="JAR search and dependency download from the Maven repository"
io.numaproj.numaflow.sessionreducer.UniqueIdGenerator Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of numaflow-java Show documentation
Show all versions of numaflow-java Show documentation
SDK to implement Numaflow Source or User Defined Functions or Sinks in Java.
The newest version!
package io.numaproj.numaflow.sessionreducer;
import com.google.protobuf.Timestamp;
import io.numaproj.numaflow.sessionreduce.v1.Sessionreduce;
import java.time.Instant;
/**
* UniqueIdGenerator is a utility class to generate a unique id for a keyed session window.
*/
public class UniqueIdGenerator {
private UniqueIdGenerator() {
throw new AssertionError("utility class cannot be instantiated");
}
public static String getUniqueIdentifier(Sessionreduce.KeyedWindow keyedWindow) {
long startMillis = convertToEpochMilli(keyedWindow.getStart());
long endMillis = convertToEpochMilli(keyedWindow.getEnd());
return String.format(
"%d:%d:%s",
startMillis,
endMillis,
String.join(Constants.DELIMITER, keyedWindow.getKeysList()));
}
private static long convertToEpochMilli(Timestamp timestamp) {
return Instant.ofEpochSecond(timestamp.getSeconds(), timestamp.getNanos()).toEpochMilli();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy