From 94fead6be729cfb23b657d853c5499709a3d27c4 Mon Sep 17 00:00:00 2001 From: Fibinger Ádám <adam.fibinger@wup.hu> Date: Mon, 11 Mar 2019 19:39:11 +0100 Subject: [PATCH] Just keeping calm and keep refactoring --- src/main/java/hu/unr/fiber/cardapi/CardController.java | 88 ++++++++++++++++++++------------------------ 1 files changed, 40 insertions(+), 48 deletions(-) diff --git a/src/main/java/hu/unr/fiber/cardapi/CardController.java b/src/main/java/hu/unr/fiber/cardapi/CardController.java index 33c51b2..8de17cc 100644 --- a/src/main/java/hu/unr/fiber/cardapi/CardController.java +++ b/src/main/java/hu/unr/fiber/cardapi/CardController.java @@ -1,20 +1,16 @@ package hu.unr.fiber.cardapi; -import java.net.URI; import java.util.List; -import java.util.Optional; -import hu.unr.fiber.cardapi.entity.CardEntityInterface; -import hu.unr.fiber.cardapi.entity.CardEntityNotFoundException; -import hu.unr.fiber.cardapi.entity.CardInteractor; -import hu.unr.fiber.cardapi.entity.CardRepository; -import hu.unr.fiber.cardapi.rest.CardEntity; +import hu.unr.fiber.cardapi.hibernate.CardNotFoundException; +import hu.unr.fiber.cardapi.interfaces.CardInterface; +import hu.unr.fiber.cardapi.hibernate.CardInteractor; 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.util.UriComponentsBuilder; +import org.springframework.web.server.ResponseStatusException; @RestController public class CardController { @@ -32,53 +28,49 @@ } @GetMapping("/cards") - public ResponseEntity<List<CardEntityInterface>> cards() { + public ResponseEntity<List<CardInterface>> cards() { logger.info("GET /cards called, responded with items."); - List<CardEntityInterface> cardList = cardService.getCardList(); + List<CardInterface> cardList = cardService.getCardList(); return ResponseEntity.ok().body(cardList); } @GetMapping(value = "/card/{id}") - public ResponseEntity<CardEntityInterface> getCard(@PathVariable("id") long id) { + public ResponseEntity<CardInterface> getCard(@PathVariable("id") long id) { logger.info("GET /card/" + id + " called."); - CardEntityInterface card = this.cardService.getCardById(id); - - if (card == null) { - return ResponseEntity.notFound().build(); + try { + CardInterface card = this.cardService.getCardById(id); + return ResponseEntity.ok().body(card); + } catch (CardNotFoundException e) { + throw new ResponseStatusException(HttpStatus.NOT_FOUND, "No such card with id: #" + id); } - - return ResponseEntity.ok().body(card); } -/* + @DeleteMapping(value = "/card/{id}") public ResponseEntity<String> deleteCard(@PathVariable("id") long id) { logger.info("DELETE /card/" + id + " called"); - return Optional - .ofNullable(this.cardRepository.getOne(id)) - .map( - card -> { - this.cardRepository.delete(card); - this.cardRepository.flush(); - return ResponseEntity.ok().body("OK"); - } - ) - .orElseGet(() -> ResponseEntity.status(HttpStatus.NOT_FOUND).body("No card available with id: " + id)); - } - - @PostMapping(value = "/card/{id}") - public ResponseEntity<String> updateCard(@PathVariable("id") long id, @RequestBody CardEntity updatedCardEntity, UriComponentsBuilder ucBuilder) { - - logger.info("POST /card/" + id + " called, card update."); - - if (updatedCardEntity.validId() && (updatedCardEntity.getId() != id)) { - return ResponseEntity - .badRequest() - .body("Id field cannot be modified."); + try { + this.cardService.delete(id); + } catch (CardNotFoundException e) { + throw new ResponseStatusException(HttpStatus.NOT_FOUND, "No such card with id: #" + id, e); } - CardEntity originalCardEntity = this.cardRepository.getOne(id); + 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){ + + } + + + RestCard originalCardEntity = this.cardRepository.getOne(id); if (originalCardEntity.equals(updatedCardEntity)) { return ResponseEntity.accepted().body("Update has no changes."); @@ -86,8 +78,8 @@ //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 CardEntity with number {} already exist", originalCardEntity.getId(), updatedCardEntity.getNumber()); - return ResponseEntity.status(HttpStatus.CONFLICT).body("CardEntity with number " + updatedCardEntity.getNumber() + " already exists."); + 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); @@ -96,7 +88,7 @@ return ResponseEntity.accepted().body("OK"); } - private CardEntity getCardByNumber(String number) { + private RestCard getCardByNumber(String number) { Long id = cardRepository.findIdByNumber(number); @@ -108,12 +100,12 @@ } @PostMapping(value = "/card") - public ResponseEntity<String> createCard(@RequestBody CardEntity card, UriComponentsBuilder ucBuilder) { - logger.info("Creating CardEntity : {}", card.getNumber()); + 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 CardEntity with number {} already exist", card.getNumber()); - return ResponseEntity.status(HttpStatus.CONFLICT).body("CardEntity with number " + card.getNumber() + " already exists."); + 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."); } this.cardRepository.saveAndFlush(card); @@ -124,5 +116,5 @@ .created(newCardURI) .body(newCardURI.toString()); } -*/ + */ } \ No newline at end of file -- Gitblit v1.8.0