X-Git-Url: https://juplo.de/gitweb/?p=demos%2Fspring%2Fdata-jdbc;a=blobdiff_plain;f=src%2Fmain%2Fjava%2Fde%2Fjuplo%2Fboot%2Fdata%2Fjdbc%2FUserController.java;h=177b1202c3367cc733a477f7690ccebf15637877;hp=4eb10941aa9d1155ead8011b5353b043d5311710;hb=39a57180b2b7d2d01ac558d1a375c826260c7119;hpb=21ee193ca1a46c8f9b52768f4c18af7829a8c35a diff --git a/src/main/java/de/juplo/boot/data/jdbc/UserController.java b/src/main/java/de/juplo/boot/data/jdbc/UserController.java index 4eb1094..177b120 100644 --- a/src/main/java/de/juplo/boot/data/jdbc/UserController.java +++ b/src/main/java/de/juplo/boot/data/jdbc/UserController.java @@ -2,13 +2,19 @@ package de.juplo.boot.data.jdbc; import org.slf4j.Logger; import org.slf4j.LoggerFactory; +import org.springframework.context.ApplicationEventPublisher; import org.springframework.http.ResponseEntity; import org.springframework.transaction.annotation.Transactional; import org.springframework.web.bind.annotation.*; import org.springframework.web.servlet.support.ServletUriComponentsBuilder; import org.springframework.web.util.UriComponents; +import java.time.Clock; import java.time.LocalDateTime; +import java.time.ZonedDateTime; + +import static de.juplo.boot.data.jdbc.UserStatus.CREATED; +import static de.juplo.boot.data.jdbc.UserStatus.DELETED; @RestController @Transactional @@ -19,10 +25,18 @@ public class UserController { private final UserRepository repository; + private final Clock clock; + private final ApplicationEventPublisher publisher; - public UserController(UserRepository repository) { + public UserController( + UserRepository repository, + Clock clock, + ApplicationEventPublisher publisher) + { this.repository = repository; + this.clock = clock; + this.publisher = publisher; } @@ -33,6 +47,12 @@ public class UserController { String sanitizedUsername = UserController.sanitize(username); User user = new User(sanitizedUsername, LocalDateTime.now(), false); repository.save(user); + publisher.publishEvent( + new UserEvent( + this, + sanitizedUsername, + CREATED, + ZonedDateTime.now(clock))); UriComponents uri = builder .fromCurrentRequest() @@ -59,6 +79,12 @@ public class UserController { return ResponseEntity.notFound().build(); repository.delete(user); + publisher.publishEvent( + new UserEvent( + this, + user.getUsername(), + DELETED, + ZonedDateTime.now(clock))); return ResponseEntity.ok(user); }