X-Git-Url: http://juplo.de/gitweb/?a=blobdiff_plain;f=src%2Fmain%2Fjava%2Fde%2Fjuplo%2Fkafka%2FAdderBusinessLogic.java;h=cbd500dcdab4de973960aa6ca8bf52fa3be21f46;hb=b9a482c8228e0b9197d7cb0c3f6b8849e5cd66da;hp=c0a43326f683cf6047c464148e598c2ae06a6693;hpb=5b4b7acf7b6a02e0e5c779257d3f5996366625e6;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 c0a4332..cbd500d 100644 --- a/src/main/java/de/juplo/kafka/AdderBusinessLogic.java +++ b/src/main/java/de/juplo/kafka/AdderBusinessLogic.java @@ -22,14 +22,6 @@ public class AdderBusinessLogic } - public synchronized void startSum(String user) - { - if (state.containsKey(user)) - throw new IllegalStateException("Sumation for " + user + " already in progress, state: " + state.get(user)); - - state.put(user, 0l); - } - public synchronized Optional getSum(String user) { return Optional.ofNullable(state.get(user)); @@ -37,21 +29,22 @@ public class AdderBusinessLogic public synchronized void addToSum(String user, Integer value) { - if (!state.containsKey(user)) - throw new IllegalStateException("No sumation for " + user + " in progress"); if (value == null || value < 1) throw new IllegalArgumentException("Not a positive number: " + value); - long result = state.get(user) + value; - state.put(user, result); + long sum = + Optional + .ofNullable(state.get(user)) + .orElse(0l); + state.put(user, sum + value); } - public synchronized Long endSum(String user) + public synchronized Long calculate(String user) { if (!state.containsKey(user)) throw new IllegalStateException("No sumation for " + user + " in progress"); - return state.get(user); + return state.remove(user); } protected Map getState()