MenuItemReviewController.java
package edu.ucsb.cs156.example.controllers;
import com.fasterxml.jackson.core.JsonProcessingException;
import edu.ucsb.cs156.example.entities.MenuItemReview;
import edu.ucsb.cs156.example.errors.EntityNotFoundException;
import edu.ucsb.cs156.example.repositories.MenuItemReviewRepository;
import io.swagger.v3.oas.annotations.Operation;
import io.swagger.v3.oas.annotations.Parameter;
import io.swagger.v3.oas.annotations.tags.Tag;
import java.time.LocalDateTime;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.format.annotation.DateTimeFormat;
import org.springframework.security.access.prepost.PreAuthorize;
import org.springframework.web.bind.annotation.DeleteMapping;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.PutMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
/** This is a REST controller for MenuItemReview */
@Tag(name = "MenuItemReview")
@RequestMapping("/api/menuitemreview")
@RestController
@Slf4j
public class MenuItemReviewController extends ApiController {
@Autowired MenuItemReviewRepository menuItemReviewRepository;
/**
* List all menu item reviews
*
* @return an iterable of MenuItemReview
*/
@Operation(summary = "List all menu item reviews")
@PreAuthorize("hasRole('ROLE_USER')")
@GetMapping("/all")
public Iterable<MenuItemReview> allMenuItemReviews() {
Iterable<MenuItemReview> reviews = menuItemReviewRepository.findAll();
return reviews;
}
/**
* Get a single menu item review by id
*
* @param id the id of the menu item review
* @return a single menu item review
*/
@Operation(summary = "Get a single menu item review")
@PreAuthorize("hasRole('ROLE_USER')")
@GetMapping("")
public MenuItemReview getById(@Parameter(name = "id") @RequestParam Long id) {
MenuItemReview review =
menuItemReviewRepository
.findById(id)
.orElseThrow(() -> new EntityNotFoundException(MenuItemReview.class, id));
return review;
}
/**
* Create a new menu item review
*
* @param itemId the id of the menu item being reviewed
* @param reviewerEmail the email of the reviewer
* @param stars the star rating (0-5)
* @param dateReviewed the date of the review
* @param comments the review comments
* @return the saved menu item review
*/
@Operation(summary = "Create a new menu item review")
@PreAuthorize("hasRole('ROLE_ADMIN')")
@PostMapping("/post")
public MenuItemReview postMenuItemReview(
@Parameter(name = "itemId") @RequestParam long itemId,
@Parameter(name = "reviewerEmail") @RequestParam String reviewerEmail,
@Parameter(name = "stars") @RequestParam int stars,
@Parameter(
name = "dateReviewed",
description =
"date (in iso format, e.g. YYYY-mm-ddTHH:MM:SS; see https://en.wikipedia.org/wiki/ISO_8601)")
@RequestParam("dateReviewed")
@DateTimeFormat(iso = DateTimeFormat.ISO.DATE_TIME)
LocalDateTime dateReviewed,
@Parameter(name = "comments") @RequestParam String comments)
throws JsonProcessingException {
log.info("dateReviewed={}", dateReviewed);
if (stars < 0 || stars > 5) {
throw new IllegalArgumentException("Stars must be between 0 and 5");
}
MenuItemReview review = new MenuItemReview();
review.setItemId(itemId);
review.setReviewerEmail(reviewerEmail);
review.setStars(stars);
review.setDateReviewed(dateReviewed);
review.setComments(comments);
MenuItemReview savedReview = menuItemReviewRepository.save(review);
return savedReview;
}
/**
* Update a single menu item review. Accessible only to users with the role "ROLE_ADMIN".
*
* @param id the id of the menu item review to update
* @param incoming the new review data
* @return the updated menu item review
*/
@Operation(summary = "Update a single menu item review")
@PreAuthorize("hasRole('ROLE_ADMIN')")
@PutMapping("")
public MenuItemReview updateMenuItemReview(
@Parameter(name = "id") @RequestParam Long id, @RequestBody MenuItemReview incoming) {
if (incoming.getStars() < 0 || incoming.getStars() > 5) {
throw new IllegalArgumentException("Stars must be between 0 and 5");
}
MenuItemReview review =
menuItemReviewRepository
.findById(id)
.orElseThrow(() -> new EntityNotFoundException(MenuItemReview.class, id));
review.setItemId(incoming.getItemId());
review.setReviewerEmail(incoming.getReviewerEmail());
review.setStars(incoming.getStars());
review.setDateReviewed(incoming.getDateReviewed());
review.setComments(incoming.getComments());
menuItemReviewRepository.save(review);
return review;
}
/**
* Delete a menu item review. Accessible only to users with the role "ROLE_ADMIN".
*
* @param id the id of the menu item review to delete
* @return a message indicating the review was deleted
*/
@Operation(summary = "Delete a menu item review")
@PreAuthorize("hasRole('ROLE_ADMIN')")
@DeleteMapping("")
public Object deleteMenuItemReview(@Parameter(name = "id") @RequestParam Long id) {
MenuItemReview review =
menuItemReviewRepository
.findById(id)
.orElseThrow(() -> new EntityNotFoundException(MenuItemReview.class, id));
menuItemReviewRepository.delete(review);
return genericMessage("MenuItemReview with id %s deleted".formatted(id));
}
}