X-Git-Url: http://juplo.de/gitweb/?a=blobdiff_plain;f=src%2Fmain%2Fjava%2Fde%2Fjuplo%2Fkafka%2FDriverController.java;h=26a5bc86488f6dbb5f82852bd82bf41d62b8f811;hb=a4be0eac8d9f234cd53ae1917a084f65d91d0460;hp=0870f19de5dcdda626eb790a39106a4af7f22d2f;hpb=5b4b7acf7b6a02e0e5c779257d3f5996366625e6;p=demos%2Fkafka%2Ftraining diff --git a/src/main/java/de/juplo/kafka/DriverController.java b/src/main/java/de/juplo/kafka/DriverController.java index 0870f19..26a5bc8 100644 --- a/src/main/java/de/juplo/kafka/DriverController.java +++ b/src/main/java/de/juplo/kafka/DriverController.java @@ -5,6 +5,7 @@ import org.springframework.http.HttpStatus; import org.springframework.http.ResponseEntity; import org.springframework.web.bind.annotation.*; +import java.util.List; import java.util.Map; import java.util.Optional; import java.util.concurrent.ExecutionException; @@ -16,7 +17,8 @@ import java.util.stream.Collectors; public class DriverController { private final EndlessConsumer consumer; - private final AdderRecordHandler adderRecordHandler; + private final ApplicationRecordHandler recordHandler; + private final AdderResults results; @PostMapping("start") @@ -33,10 +35,10 @@ public class DriverController @GetMapping("state") - public Map> state() + public Map> state() { return - adderRecordHandler + recordHandler .getState() .entrySet() .stream() @@ -46,11 +48,11 @@ public class DriverController } @GetMapping("state/{user}") - public ResponseEntity seen(@PathVariable String user) + public ResponseEntity state(@PathVariable String user) { - for (AdderBusinessLogic adderBusinessLogic : adderRecordHandler.getState().values()) + for (AdderBusinessLogic adder : recordHandler.getState().values()) { - Optional sum = adderBusinessLogic.getSum(user); + Optional sum = adder.getSum(user); if (sum.isPresent()) return ResponseEntity.ok(sum.get()); } @@ -58,6 +60,25 @@ public class DriverController return ResponseEntity.notFound().build(); } + @GetMapping("results") + public Map>> results() + { + return results.getState(); + } + + @GetMapping("results/{user}") + public ResponseEntity> results(@PathVariable String user) + { + for (Map> resultsByUser : this.results.getState().values()) + { + List results = resultsByUser.get(user); + if (results != null) + return ResponseEntity.ok(results); + } + + return ResponseEntity.notFound().build(); + } + @ExceptionHandler @ResponseStatus(HttpStatus.BAD_REQUEST)