| 1 | package edu.ucsb.cs156.dining.controllers; | |
| 2 | ||
| 3 | import edu.ucsb.cs156.dining.entities.UCSBDiningCommons; | |
| 4 | import edu.ucsb.cs156.dining.errors.EntityNotFoundException; | |
| 5 | import edu.ucsb.cs156.dining.repositories.UCSBDiningCommonsRepository; | |
| 6 | ||
| 7 | import io.swagger.v3.oas.annotations.Operation; | |
| 8 | import io.swagger.v3.oas.annotations.Parameter; | |
| 9 | import io.swagger.v3.oas.annotations.tags.Tag; | |
| 10 | import lombok.extern.slf4j.Slf4j; | |
| 11 | ||
| 12 | import org.springframework.beans.factory.annotation.Autowired; | |
| 13 | import org.springframework.security.access.prepost.PreAuthorize; | |
| 14 | import org.springframework.web.bind.annotation.DeleteMapping; | |
| 15 | import org.springframework.web.bind.annotation.GetMapping; | |
| 16 | import org.springframework.web.bind.annotation.PostMapping; | |
| 17 | import org.springframework.web.bind.annotation.PutMapping; | |
| 18 | import org.springframework.web.bind.annotation.RequestBody; | |
| 19 | import org.springframework.web.bind.annotation.RequestMapping; | |
| 20 | import org.springframework.web.bind.annotation.RequestParam; | |
| 21 | import org.springframework.web.bind.annotation.RestController; | |
| 22 | ||
| 23 | import jakarta.validation.Valid; | |
| 24 | ||
| 25 | /** | |
| 26 | * This is a REST controller for UCSBDiningCommons | |
| 27 | */ | |
| 28 | ||
| 29 | @Tag(name = "UCSBDiningCommons") | |
| 30 | @RequestMapping("/api/ucsbdiningcommons") | |
| 31 | @RestController | |
| 32 | @Slf4j | |
| 33 | public class UCSBDiningCommonsController extends ApiController { | |
| 34 | ||
| 35 | @Autowired | |
| 36 | UCSBDiningCommonsRepository ucsbDiningCommonsRepository; | |
| 37 | ||
| 38 | /** | |
| 39 | * THis method returns a list of all ucsbdiningcommons. | |
| 40 | * @return a list of all ucsbdiningcommons | |
| 41 | */ | |
| 42 | @Operation(summary= "List all ucsb dining commons") | |
| 43 | @PreAuthorize("hasRole('ROLE_USER')") | |
| 44 | @GetMapping("/all") | |
| 45 | public Iterable<UCSBDiningCommons> allCommonss() { | |
| 46 | Iterable<UCSBDiningCommons> commons = ucsbDiningCommonsRepository.findAll(); | |
| 47 |
1
1. allCommonss : replaced return value with Collections.emptyList for edu/ucsb/cs156/dining/controllers/UCSBDiningCommonsController::allCommonss → KILLED |
return commons; |
| 48 | } | |
| 49 | ||
| 50 | /** | |
| 51 | * This method returns a single diningcommons. | |
| 52 | * @param code code of the diningcommons | |
| 53 | * @return a single diningcommons | |
| 54 | */ | |
| 55 | @Operation(summary= "Get a single commons") | |
| 56 | @PreAuthorize("hasRole('ROLE_USER')") | |
| 57 | @GetMapping("") | |
| 58 | public UCSBDiningCommons getById( | |
| 59 | @Parameter(name="code") @RequestParam String code) { | |
| 60 | UCSBDiningCommons commons = ucsbDiningCommonsRepository.findById(code) | |
| 61 |
1
1. lambda$getById$0 : replaced return value with null for edu/ucsb/cs156/dining/controllers/UCSBDiningCommonsController::lambda$getById$0 → KILLED |
.orElseThrow(() -> new EntityNotFoundException(UCSBDiningCommons.class, code)); |
| 62 | ||
| 63 |
1
1. getById : replaced return value with null for edu/ucsb/cs156/dining/controllers/UCSBDiningCommonsController::getById → KILLED |
return commons; |
| 64 | } | |
| 65 | ||
| 66 | /** | |
| 67 | * This method creates a new diningcommons. Accessible only to users with the role "ROLE_ADMIN". | |
| 68 | * @param code code of the diningcommons | |
| 69 | * @param name name of the diningcommons | |
| 70 | * @param hasSackMeal whether or not the commons has sack meals | |
| 71 | * @param hasTakeOutMeal whether or not the commons has take out meals | |
| 72 | * @param hasDiningCam whether or not the commons has a dining cam | |
| 73 | * @param latitude latitude of the commons | |
| 74 | * @param longitude logitude of the commons | |
| 75 | * @return the save diningcommons | |
| 76 | */ | |
| 77 | @Operation(summary= "Create a new commons") | |
| 78 | @PreAuthorize("hasRole('ROLE_ADMIN')") | |
| 79 | @PostMapping("/post") | |
| 80 | public UCSBDiningCommons postCommons( | |
| 81 | @Parameter(name="code") @RequestParam String code, | |
| 82 | @Parameter(name="name") @RequestParam String name, | |
| 83 | @Parameter(name="hasSackMeal") @RequestParam boolean hasSackMeal, | |
| 84 | @Parameter(name="hasTakeOutMeal") @RequestParam boolean hasTakeOutMeal, | |
| 85 | @Parameter(name="hasDiningCam") @RequestParam boolean hasDiningCam, | |
| 86 | @Parameter(name="latitude") @RequestParam double latitude, | |
| 87 | @Parameter(name="longitude") @RequestParam double longitude | |
| 88 | ) | |
| 89 | { | |
| 90 | ||
| 91 | UCSBDiningCommons commons = new UCSBDiningCommons(); | |
| 92 |
1
1. postCommons : removed call to edu/ucsb/cs156/dining/entities/UCSBDiningCommons::setCode → KILLED |
commons.setCode(code); |
| 93 |
1
1. postCommons : removed call to edu/ucsb/cs156/dining/entities/UCSBDiningCommons::setName → KILLED |
commons.setName(name); |
| 94 |
1
1. postCommons : removed call to edu/ucsb/cs156/dining/entities/UCSBDiningCommons::setHasSackMeal → KILLED |
commons.setHasSackMeal(hasSackMeal); |
| 95 |
1
1. postCommons : removed call to edu/ucsb/cs156/dining/entities/UCSBDiningCommons::setHasTakeOutMeal → KILLED |
commons.setHasTakeOutMeal(hasTakeOutMeal); |
| 96 |
1
1. postCommons : removed call to edu/ucsb/cs156/dining/entities/UCSBDiningCommons::setHasDiningCam → KILLED |
commons.setHasDiningCam(hasDiningCam); |
| 97 |
1
1. postCommons : removed call to edu/ucsb/cs156/dining/entities/UCSBDiningCommons::setLatitude → KILLED |
commons.setLatitude(latitude); |
| 98 |
1
1. postCommons : removed call to edu/ucsb/cs156/dining/entities/UCSBDiningCommons::setLongitude → KILLED |
commons.setLongitude(longitude); |
| 99 | ||
| 100 | UCSBDiningCommons savedCommons = ucsbDiningCommonsRepository.save(commons); | |
| 101 | ||
| 102 |
1
1. postCommons : replaced return value with null for edu/ucsb/cs156/dining/controllers/UCSBDiningCommonsController::postCommons → KILLED |
return savedCommons; |
| 103 | } | |
| 104 | ||
| 105 | /** | |
| 106 | * Delete a diningcommons. Accessible only to users with the role "ROLE_ADMIN". | |
| 107 | * @param code code of the commons | |
| 108 | * @return a message indiciating the commons was deleted | |
| 109 | */ | |
| 110 | @Operation(summary= "Delete a UCSBDiningCommons") | |
| 111 | @PreAuthorize("hasRole('ROLE_ADMIN')") | |
| 112 | @DeleteMapping("") | |
| 113 | public Object deleteCommons( | |
| 114 | @Parameter(name="code") @RequestParam String code) { | |
| 115 | UCSBDiningCommons commons = ucsbDiningCommonsRepository.findById(code) | |
| 116 |
1
1. lambda$deleteCommons$1 : replaced return value with null for edu/ucsb/cs156/dining/controllers/UCSBDiningCommonsController::lambda$deleteCommons$1 → KILLED |
.orElseThrow(() -> new EntityNotFoundException(UCSBDiningCommons.class, code)); |
| 117 | ||
| 118 |
1
1. deleteCommons : removed call to edu/ucsb/cs156/dining/repositories/UCSBDiningCommonsRepository::delete → KILLED |
ucsbDiningCommonsRepository.delete(commons); |
| 119 |
1
1. deleteCommons : replaced return value with null for edu/ucsb/cs156/dining/controllers/UCSBDiningCommonsController::deleteCommons → KILLED |
return genericMessage("UCSBDiningCommons with id %s deleted".formatted(code)); |
| 120 | } | |
| 121 | ||
| 122 | /** | |
| 123 | * Update a single diningcommons. Accessible only to users with the role "ROLE_ADMIN". | |
| 124 | * @param code code of the diningcommons | |
| 125 | * @param incoming the new commons contents | |
| 126 | * @return the updated commons object | |
| 127 | */ | |
| 128 | @Operation(summary= "Update a single commons") | |
| 129 | @PreAuthorize("hasRole('ROLE_ADMIN')") | |
| 130 | @PutMapping("") | |
| 131 | public UCSBDiningCommons updateCommons( | |
| 132 | @Parameter(name="code") @RequestParam String code, | |
| 133 | @RequestBody @Valid UCSBDiningCommons incoming) { | |
| 134 | ||
| 135 | UCSBDiningCommons commons = ucsbDiningCommonsRepository.findById(code) | |
| 136 |
1
1. lambda$updateCommons$2 : replaced return value with null for edu/ucsb/cs156/dining/controllers/UCSBDiningCommonsController::lambda$updateCommons$2 → KILLED |
.orElseThrow(() -> new EntityNotFoundException(UCSBDiningCommons.class, code)); |
| 137 | ||
| 138 | ||
| 139 |
1
1. updateCommons : removed call to edu/ucsb/cs156/dining/entities/UCSBDiningCommons::setName → KILLED |
commons.setName(incoming.getName()); |
| 140 |
1
1. updateCommons : removed call to edu/ucsb/cs156/dining/entities/UCSBDiningCommons::setHasSackMeal → KILLED |
commons.setHasSackMeal(incoming.getHasSackMeal()); |
| 141 |
1
1. updateCommons : removed call to edu/ucsb/cs156/dining/entities/UCSBDiningCommons::setHasTakeOutMeal → KILLED |
commons.setHasTakeOutMeal(incoming.getHasTakeOutMeal()); |
| 142 |
1
1. updateCommons : removed call to edu/ucsb/cs156/dining/entities/UCSBDiningCommons::setHasDiningCam → KILLED |
commons.setHasDiningCam(incoming.getHasDiningCam()); |
| 143 |
1
1. updateCommons : removed call to edu/ucsb/cs156/dining/entities/UCSBDiningCommons::setLatitude → KILLED |
commons.setLatitude(incoming.getLatitude()); |
| 144 |
1
1. updateCommons : removed call to edu/ucsb/cs156/dining/entities/UCSBDiningCommons::setLongitude → KILLED |
commons.setLongitude(incoming.getLongitude()); |
| 145 | ||
| 146 | ucsbDiningCommonsRepository.save(commons); | |
| 147 | ||
| 148 |
1
1. updateCommons : replaced return value with null for edu/ucsb/cs156/dining/controllers/UCSBDiningCommonsController::updateCommons → KILLED |
return commons; |
| 149 | } | |
| 150 | ||
| 151 | | |
| 152 | } | |
Mutations | ||
| 47 |
1.1 |
|
| 61 |
1.1 |
|
| 63 |
1.1 |
|
| 92 |
1.1 |
|
| 93 |
1.1 |
|
| 94 |
1.1 |
|
| 95 |
1.1 |
|
| 96 |
1.1 |
|
| 97 |
1.1 |
|
| 98 |
1.1 |
|
| 102 |
1.1 |
|
| 116 |
1.1 |
|
| 118 |
1.1 |
|
| 119 |
1.1 |
|
| 136 |
1.1 |
|
| 139 |
1.1 |
|
| 140 |
1.1 |
|
| 141 |
1.1 |
|
| 142 |
1.1 |
|
| 143 |
1.1 |
|
| 144 |
1.1 |
|
| 148 |
1.1 |