From dad2c4321584a4e118e87f71cc8836f3ee56d30a Mon Sep 17 00:00:00 2001
From: Hendrik Jungnitsch <hendrik.jungnitsch@gedoplan.de>
Date: Mo, 19 Sep 2022 18:37:04 +0200
Subject: [PATCH] exercise02

---
 src/main/java/de/gedoplan/seminar/sbt/sbtrestexercise/rest/PersonResource.java |   40 ++++++++++++++++++++++++++++++++++++----
 1 files changed, 36 insertions(+), 4 deletions(-)

diff --git a/src/main/java/de/gedoplan/seminar/sbt/sbtrestexercise/rest/PersonResource.java b/src/main/java/de/gedoplan/seminar/sbt/sbtrestexercise/rest/PersonResource.java
index fc8689c..8f0c094 100644
--- a/src/main/java/de/gedoplan/seminar/sbt/sbtrestexercise/rest/PersonResource.java
+++ b/src/main/java/de/gedoplan/seminar/sbt/sbtrestexercise/rest/PersonResource.java
@@ -4,13 +4,14 @@
 import de.gedoplan.seminar.sbt.sbtrestexercise.repository.PersonRepository;
 import org.springframework.http.HttpStatus;
 import org.springframework.http.MediaType;
-import org.springframework.web.bind.annotation.GetMapping;
-import org.springframework.web.bind.annotation.PathVariable;
-import org.springframework.web.bind.annotation.RequestMapping;
-import org.springframework.web.bind.annotation.RestController;
+import org.springframework.http.ResponseEntity;
+import org.springframework.web.bind.annotation.*;
 import org.springframework.web.server.ResponseStatusException;
+import org.springframework.web.util.UriComponentsBuilder;
 
+import java.net.URI;
 import java.util.List;
+import java.util.Objects;
 
 @RestController
 @RequestMapping(path = "/personen", produces = MediaType.APPLICATION_JSON_VALUE)
@@ -32,4 +33,35 @@
                 .orElseThrow(() -> new ResponseStatusException(HttpStatus.NOT_FOUND));
     }
 
+    @ResponseStatus(HttpStatus.NO_CONTENT)
+    @PutMapping(path = "{id}", consumes = MediaType.APPLICATION_JSON_VALUE)
+    public void putPerson(@PathVariable Integer id, @RequestBody Person person) {
+        if(!Objects.equals(id, person.getId())) {
+            throw new ResponseStatusException(HttpStatus.BAD_REQUEST);
+        }
+
+        personRepository.findById(id).orElseThrow(() -> new ResponseStatusException(HttpStatus.NOT_FOUND));
+
+        personRepository.save(person);
+    }
+
+    @PostMapping(consumes = MediaType.APPLICATION_JSON_VALUE)
+    public ResponseEntity<String> postPerson(@RequestBody Person person, UriComponentsBuilder uriComponentsBuilder) {
+        if(Objects.nonNull(person.getId())) {
+            throw new ResponseStatusException(HttpStatus.BAD_REQUEST, "id of new entry must not be set");
+        }
+        personRepository.save(person);
+
+        URI uri = uriComponentsBuilder
+                .pathSegment("personen", person.getId().toString())
+                .build().toUri();
+
+        return ResponseEntity.created(uri).build();
+    }
+
+    @DeleteMapping("{id}")
+    public void deletePerson(@PathVariable Integer id) {
+        personRepository.deleteById(id);
+    }
+
 }

--
Gitblit v1.7.1