From 12abae6da924cb33858fbc9948fdf7a181e2038c Mon Sep 17 00:00:00 2001 From: Fibinger Ádám <adam.fibinger@wup.hu> Date: Tue, 12 Mar 2019 19:31:27 +0100 Subject: [PATCH] Decoupling final version --- src/main/java/hu/unr/fiber/cardapi/CardController.java | 52 +++++++++++++++------------------------------------- 1 files changed, 15 insertions(+), 37 deletions(-) diff --git a/src/main/java/hu/unr/fiber/cardapi/CardController.java b/src/main/java/hu/unr/fiber/cardapi/CardController.java index 8de17cc..141cd21 100644 --- a/src/main/java/hu/unr/fiber/cardapi/CardController.java +++ b/src/main/java/hu/unr/fiber/cardapi/CardController.java @@ -1,16 +1,20 @@ package hu.unr.fiber.cardapi; +import java.net.URI; import java.util.List; -import hu.unr.fiber.cardapi.hibernate.CardNotFoundException; +import hu.unr.fiber.cardapi.interfaces.CardInvalidUpdateException; +import hu.unr.fiber.cardapi.interfaces.CardNotFoundException; import hu.unr.fiber.cardapi.interfaces.CardInterface; import hu.unr.fiber.cardapi.hibernate.CardInteractor; +import hu.unr.fiber.cardapi.rest.RestCard; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.http.HttpStatus; import org.springframework.http.ResponseEntity; import org.springframework.web.bind.annotation.*; import org.springframework.web.server.ResponseStatusException; +import org.springframework.web.util.UriComponentsBuilder; @RestController public class CardController { @@ -58,57 +62,32 @@ return ResponseEntity.ok().body("OK"); } -/* + @PostMapping(value = "/card/{id}") public ResponseEntity<String> updateCard(@PathVariable("id") long id, @RequestBody RestCard updatedCardEntity, UriComponentsBuilder ucBuilder) { logger.info("POST /card/" + id + " called, card update."); try { this.cardService.update(id, updatedCardEntity); - } catch (CardInvalidUpdateException e){ - + } catch (CardInvalidUpdateException e) { + throw new ResponseStatusException(HttpStatus.BAD_REQUEST, e.getMessage()); + } catch (CardNotFoundException e) { + throw new ResponseStatusException(HttpStatus.NOT_FOUND, "No such card with id: #" + id, e); } - - - RestCard originalCardEntity = this.cardRepository.getOne(id); - - if (originalCardEntity.equals(updatedCardEntity)) { - return ResponseEntity.accepted().body("Update has no changes."); - } - - //card number updated, we have to check if its already exists - if (!originalCardEntity.getNumber().equals(updatedCardEntity.getNumber()) && this.getCardByNumber(updatedCardEntity.getNumber()) != null) { - logger.error("Unable to update card with id {}. A different RestCard with number {} already exist", originalCardEntity.getId(), updatedCardEntity.getNumber()); - return ResponseEntity.status(HttpStatus.CONFLICT).body("RestCard with number " + updatedCardEntity.getNumber() + " already exists."); - } - - originalCardEntity.update(updatedCardEntity); - this.cardRepository.flush(); return ResponseEntity.accepted().body("OK"); - } - - private RestCard getCardByNumber(String number) { - - Long id = cardRepository.findIdByNumber(number); - - if (id == null) { - return null; - } - - return cardRepository.getOne(id); } @PostMapping(value = "/card") public ResponseEntity<String> createCard(@RequestBody RestCard card, UriComponentsBuilder ucBuilder) { logger.info("Creating RestCard : {}", card.getNumber()); - if (this.getCardByNumber(card.getNumber()) != null) { - logger.error("Unable to create. A RestCard with number {} already exist", card.getNumber()); - return ResponseEntity.status(HttpStatus.CONFLICT).body("RestCard with number " + card.getNumber() + " already exists."); + try { + CardInterface c = this.cardService.create(card); + card.setId(c.getId()); + } catch (CardInvalidUpdateException e) { + throw new ResponseStatusException(HttpStatus.CONFLICT, e.getMessage()); } - - this.cardRepository.saveAndFlush(card); URI newCardURI = ucBuilder.path("/card/{id}").buildAndExpand(card.getId()).toUri(); @@ -116,5 +95,4 @@ .created(newCardURI) .body(newCardURI.toString()); } - */ } \ No newline at end of file -- Gitblit v1.8.0