io.keyko.monitoring.examples.celo.CeloProcessor Maven / Gradle / Ivy
package io.keyko.monitoring.examples.celo;
import io.keyko.monitoring.examples.celo.model.AccountCreatedAggregation;
import io.keyko.monitoring.schemas.*;
import io.keyko.monitoring.time.EventBlockTimestampExtractor;
import org.apache.kafka.common.serialization.Serdes;
import org.apache.kafka.streams.KeyValue;
import org.apache.kafka.streams.StreamsBuilder;
import org.apache.kafka.streams.kstream.*;
import java.time.Duration;
import java.time.ZoneId;
import java.time.ZoneOffset;
import java.time.format.DateTimeFormatter;
import java.util.List;
public class CeloProcessor {
/**
* Aggregate accounts created events using a daily window
*
* @param topicsToAggregate
* @param builder
* @return
*/
public static KStream accountDailyAggregation(List topicsToAggregate, StreamsBuilder builder) {
final int windowStartHour = 0;
final ZoneId zone = ZoneOffset.UTC;
final Duration gracePeriod = Duration.ofMinutes(60L);
List accountsTopics = topicsToAggregate;//, "VoteSignerAuthorized".toLowerCase(), "AttestationSignerAuthorized".toLowerCase());
KStream accountsCreatedStream = builder.stream(accountsTopics,
Consumed.with(Serdes.String(), CeloSerdes.getEventBlockSerde())
.withTimestampExtractor(new EventBlockTimestampExtractor()));
KTable, Long> accountsCreatedDayTable =
accountsCreatedStream
.selectKey((key, event) -> event.getDetails().getName())
.groupByKey(Grouped.with(Serdes.String(), CeloSerdes.getEventBlockSerde()))
//.windowedBy(new DailyTimeWindows(zone, windowStartHour, gracePeriod))
.windowedBy(TimeWindows.of(Duration.ofSeconds(60)))
.count()//Materialized.>with(Serdes.String(), Serdes.Long())
// the default store retention time is 1 day;
// need to explicitly increase the retention time
// to allow for a 1-day window plus configured grace period
//.withRetention(Duration.ofDays(1L).plus(gracePeriod)))
// emits the final count when the window is closed.
//.suppress(Suppressed.untilWindowCloses(unbounded()));
;
return formatAccountCreatedAggregation(accountsCreatedDayTable, zone);
}
/**
* Transforms a Windowed Aggregation Table in a Stream of formatted data
*
* @param accountsCreatedDayTable
* @param zone
* @return
*/
private static KStream formatAccountCreatedAggregation(KTable, Long> accountsCreatedDayTable, ZoneId zone) {
return accountsCreatedDayTable
.toStream()
.map((windowed, count) -> {
AccountCreatedAggregation accountCreatedAggregation = new AccountCreatedAggregation(
windowed.window().startTime().atZone(zone),
count,
windowed.key()
);
DateTimeFormatter formatter = DateTimeFormatter.ofPattern("dd/MM/yyyy - HH:mm:ss Z");
String formattedString = windowed.window().startTime().atZone(ZoneOffset.UTC).format(formatter);
String key = windowed.key().concat("-").concat(formattedString);
//String key = windowed.key().concat("-").concat(accountCreatedAggregation.getDate());
return KeyValue.pair(key, accountCreatedAggregation);
});
}
public static KStream alertNoEpochRewardsDistributed(StreamsBuilder builder, List EpochRewardsDistributedToVoters) {
return builder.stream(EpochRewardsDistributedToVoters, Consumed.with(Serdes.String(), CeloSerdes.getEventBlockSerde()))
.filter((key, event) -> ((NumberParameter) event.getDetails().getNonIndexedParameters().get(0)).getValue().equals("0"))
.map((key, event) ->
KeyValue.pair(key,
AlertRecord.newBuilder()
.setName("alertNoEpochRewardsDistributed")
.setReference(event.getId())
.setStatus(AlertEventStatus.ERROR)
.setTimestamp(event.getDetailsBlock().getTimestamp())
.setDescription("NoEpochRewardsDistributed for group: " + ((StringParameter) event.getDetails().getIndexedParameters().get(0)).getValue())
.build())
);
// .to("w3m-alerts");
// .foreach((x, y) -> System.out.println("NoEpochRewardsDistributed for group: " + ((StringParameter) y.getDetails().getIndexedParameters().get(0)).getValue()));
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy