X-Git-Url: http://juplo.de/gitweb/?a=blobdiff_plain;f=src%2Fmain%2Fjava%2Fde%2Fjuplo%2Fkafka%2FAdderBusinessLogic.java;h=bd89871be92a9d41c0240e98a73126dd3eecfdd2;hb=3aa0d314b04adea02cb8c7735687ac46e44601b3;hp=a3848c466fe1dde9d393a4b7718fc541b0b8b330;hpb=47657918b484fad60ac4062177cfeb569275d3d3;p=demos%2Fkafka%2Ftraining diff --git a/src/main/java/de/juplo/kafka/AdderBusinessLogic.java b/src/main/java/de/juplo/kafka/AdderBusinessLogic.java index a3848c4..bd89871 100644 --- a/src/main/java/de/juplo/kafka/AdderBusinessLogic.java +++ b/src/main/java/de/juplo/kafka/AdderBusinessLogic.java @@ -3,6 +3,7 @@ package de.juplo.kafka; import java.util.HashMap; import java.util.Map; +import java.util.Optional; public class AdderBusinessLogic @@ -28,4 +29,21 @@ public class AdderBusinessLogic state.put(user, 0l); } + + public synchronized Optional getSum(String user) + { + return Optional.ofNullable(state.get(user)); + } + + public synchronized void addToSum(String user, Integer value) + { + } + + public synchronized Long endSum(String user) + { + if (!state.containsKey(user)) + throw new IllegalStateException("No sumation for " + user + " in progress"); + + return state.get(user); + } }