From 18261df6f0f8d304fddf21d254400af6c0489c16 Mon Sep 17 00:00:00 2001 From: Jada White <141670521+Nelshulla@users.noreply.github.com> Date: Wed, 17 Apr 2024 12:03:43 -0400 Subject: [PATCH] Delete lesson_16/api/api_app/src/main/java/com/codedifferently/lesson16/web/MediaItemsController.java --- .../lesson16/web/MediaItemsController.java | 78 ------------------- 1 file changed, 78 deletions(-) delete mode 100644 lesson_16/api/api_app/src/main/java/com/codedifferently/lesson16/web/MediaItemsController.java diff --git a/lesson_16/api/api_app/src/main/java/com/codedifferently/lesson16/web/MediaItemsController.java b/lesson_16/api/api_app/src/main/java/com/codedifferently/lesson16/web/MediaItemsController.java deleted file mode 100644 index 4acf3659e..000000000 --- a/lesson_16/api/api_app/src/main/java/com/codedifferently/lesson16/web/MediaItemsController.java +++ /dev/null @@ -1,78 +0,0 @@ -package com.codedifferently.lesson16.web; - -import com.codedifferently.lesson16.library.Librarian; -import com.codedifferently.lesson16.library.Library; -import com.codedifferently.lesson16.library.MediaItem; -import com.codedifferently.lesson16.library.exceptions.MediaItemCheckedOutException; -import com.codedifferently.lesson16.library.search.SearchCriteria; -import jakarta.validation.Valid; -import java.io.IOException; -import java.util.List; -import java.util.Set; -import java.util.UUID; -import org.springframework.http.HttpStatus; -import org.springframework.http.ResponseEntity; -import org.springframework.web.bind.annotation.CrossOrigin; -import org.springframework.web.bind.annotation.DeleteMapping; -import org.springframework.web.bind.annotation.GetMapping; -import org.springframework.web.bind.annotation.PathVariable; -import org.springframework.web.bind.annotation.PostMapping; -import org.springframework.web.bind.annotation.RequestBody; -import org.springframework.web.bind.annotation.RestController; -import org.springframework.web.server.ResponseStatusException; - -/** - * @author vscode - */ -@RestController -@CrossOrigin -public class MediaItemsController { - private final Library library; - private final Librarian librarian; - - public MediaItemsController(Library library) throws IOException { - this.library = library; - this.librarian = library.getLibrarians().stream().findFirst().orElseThrow(); - } - - @GetMapping("/items") - public GetMediaItemsResponse getItems() { - Set items = library.search(SearchCriteria.builder().build()); - List responseItems = items.stream().map(MediaItemResponse::from).toList(); - var response = GetMediaItemsResponse.builder().items(responseItems).build(); - return response; - } - - @PostMapping("/items") - public CreateMediaItemResponse postItem(@Valid @RequestBody CreateMediaItemRequest request) { - MediaItem item = MediaItemRequest.asMediaItem(request.getItem()); - library.addMediaItem(item, librarian); - var response = CreateMediaItemResponse.builder().item(MediaItemResponse.from(item)).build(); - return response; - } - - @GetMapping("/items/{id}") - public GetMediaItemsResponse getMediaItem(@PathVariable String id) { - Set items = library.search(SearchCriteria.builder().id(id).build()); - if (items.isEmpty()) { - throw new ResponseStatusException(HttpStatus.NOT_FOUND, "Media item not found"); - } - List responseItems = items.stream().map(MediaItemResponse::from).toList(); - var response = GetMediaItemsResponse.builder().items(responseItems).build(); - return response; - } - - @DeleteMapping("/items/{id}") - public ResponseEntity deleteItem(@PathVariable("id") UUID id) { - if (!library.hasMediaItem(id)) { - return ResponseEntity.notFound().build(); - } - try { - library.removeMediaItem(id, new Librarian("Default", "librarian@example.com")); - return ResponseEntity.noContent().build(); - } catch (MediaItemCheckedOutException e) { - throw new ResponseStatusException( - HttpStatus.BAD_REQUEST, "Cannot delete checked out item", e); - } - } -}