generated from pricelees/issue-pr-template
<!-- 제목 양식 --> <!-- [이슈번호] 작업 요약 (예시: [#10] Gitea 템플릿 생성) --> ## 📝 관련 이슈 및 PR **PR과 관련된 이슈 번호** - #7 ## ✨ 작업 내용 <!-- 어떤 작업을 했는지 알려주세요! --> 1. 808c6675 에서 작업했던 정상 / 오류를 통합하는 객체를 사용하려 했으나, Swagger-UI상에서 응답 형식에 null 필드가 포함되는 문제로 다시 정상 / 오류 별도로 분리 2. Swagger-UI(문서화, 명세) 관련 코드는 인지하기 쉽도록 ../web -> ../docs 패키지로 이전 3. 현재까지 코틀린으로 마이그레이션 된 서비스를 대상으로, 응답에 ResponseEntity를 적용하고 \@ResponseStatus 제거 ## 🧪 테스트 <!-- 어떤 테스트를 생각했고 진행했는지 알려주세요! --> 예정으로는 Issue에 작성했던 테스트까지 처리하려고 했으나, 테스트는 바로 다음에 진행 예정 ## 📚 참고 자료 및 기타 <!-- 참고한 자료, 또는 논의할 사항이 있다면 알려주세요! --> Reviewed-on: #8 Co-authored-by: pricelees <priceelees@gmail.com> Co-committed-by: pricelees <priceelees@gmail.com>
113 lines
5.0 KiB
Java
113 lines
5.0 KiB
Java
package roomescape.reservation.controller;
|
|
|
|
import java.time.LocalDate;
|
|
|
|
import org.springframework.http.HttpHeaders;
|
|
import org.springframework.http.HttpStatus;
|
|
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.RequestParam;
|
|
import org.springframework.web.bind.annotation.ResponseStatus;
|
|
import org.springframework.web.bind.annotation.RestController;
|
|
|
|
import io.swagger.v3.oas.annotations.Operation;
|
|
import io.swagger.v3.oas.annotations.Parameter;
|
|
import io.swagger.v3.oas.annotations.media.Content;
|
|
import io.swagger.v3.oas.annotations.media.Schema;
|
|
import io.swagger.v3.oas.annotations.responses.ApiResponse;
|
|
import io.swagger.v3.oas.annotations.responses.ApiResponses;
|
|
import io.swagger.v3.oas.annotations.tags.Tag;
|
|
import jakarta.servlet.http.HttpServletResponse;
|
|
import jakarta.validation.Valid;
|
|
import jakarta.validation.constraints.NotNull;
|
|
import roomescape.auth.web.support.Admin;
|
|
import roomescape.auth.web.support.LoginRequired;
|
|
import roomescape.common.dto.response.RoomescapeApiResponse;
|
|
import roomescape.common.dto.response.RoomescapeErrorResponse;
|
|
import roomescape.reservation.dto.request.ReservationTimeRequest;
|
|
import roomescape.reservation.dto.response.ReservationTimeInfosResponse;
|
|
import roomescape.reservation.dto.response.ReservationTimeResponse;
|
|
import roomescape.reservation.dto.response.ReservationTimesResponse;
|
|
import roomescape.reservation.service.ReservationTimeService;
|
|
|
|
@RestController
|
|
@Tag(name = "4. 예약 시간 API", description = "예약 시간을 조회 / 추가 / 삭제할 때 사용합니다.")
|
|
public class ReservationTimeController {
|
|
|
|
private final ReservationTimeService reservationTimeService;
|
|
|
|
public ReservationTimeController(ReservationTimeService reservationTimeService) {
|
|
this.reservationTimeService = reservationTimeService;
|
|
}
|
|
|
|
@Admin
|
|
@GetMapping("/times")
|
|
@ResponseStatus(HttpStatus.OK)
|
|
@Operation(summary = "모든 시간 조회", tags = "관리자 로그인이 필요한 API")
|
|
@ApiResponses({
|
|
@ApiResponse(responseCode = "200", description = "성공", useReturnTypeSchema = true)
|
|
})
|
|
public RoomescapeApiResponse<ReservationTimesResponse> getAllTimes() {
|
|
return RoomescapeApiResponse.success(reservationTimeService.findAllTimes());
|
|
}
|
|
|
|
@Admin
|
|
@PostMapping("/times")
|
|
@ResponseStatus(HttpStatus.CREATED)
|
|
@Operation(summary = "시간 추가", tags = "관리자 로그인이 필요한 API")
|
|
@ApiResponses({
|
|
@ApiResponse(responseCode = "201", description = "성공", useReturnTypeSchema = true),
|
|
@ApiResponse(responseCode = "409", description = "같은 시간을 추가할 수 없습니다.",
|
|
content = @Content(schema = @Schema(implementation = RoomescapeErrorResponse.class)))
|
|
})
|
|
public RoomescapeApiResponse<ReservationTimeResponse> saveTime(
|
|
@Valid @RequestBody ReservationTimeRequest reservationTimeRequest,
|
|
HttpServletResponse response
|
|
) {
|
|
ReservationTimeResponse reservationTimeResponse = reservationTimeService.addTime(reservationTimeRequest);
|
|
response.setHeader(HttpHeaders.LOCATION, "/times/" + reservationTimeResponse.id());
|
|
|
|
return RoomescapeApiResponse.success(reservationTimeResponse);
|
|
}
|
|
|
|
@Admin
|
|
@DeleteMapping("/times/{id}")
|
|
@ResponseStatus(HttpStatus.NO_CONTENT)
|
|
@Operation(summary = "시간 삭제", tags = "관리자 로그인이 필요한 API")
|
|
@ApiResponses({
|
|
@ApiResponse(responseCode = "204", description = "성공", useReturnTypeSchema = true),
|
|
@ApiResponse(responseCode = "409", description = "예약된 시간은 삭제할 수 없습니다.",
|
|
content = @Content(schema = @Schema(implementation = RoomescapeErrorResponse.class)))
|
|
})
|
|
public RoomescapeApiResponse<Void> removeTime(
|
|
@NotNull(message = "timeId는 null 또는 공백일 수 없습니다.") @PathVariable @Parameter(description = "삭제하고자 하는 시간의 ID값") Long id
|
|
) {
|
|
reservationTimeService.removeTimeById(id);
|
|
|
|
return RoomescapeApiResponse.success();
|
|
}
|
|
|
|
@LoginRequired
|
|
@GetMapping("/times/filter")
|
|
@ResponseStatus(HttpStatus.OK)
|
|
@Operation(summary = "예약 가능 여부를 포함한 모든 시간 조회", tags = "로그인이 필요한 API")
|
|
@ApiResponses({
|
|
@ApiResponse(responseCode = "200", description = "성공", useReturnTypeSchema = true)
|
|
})
|
|
public RoomescapeApiResponse<ReservationTimeInfosResponse> findAllAvailableReservationTimes(
|
|
@NotNull(message = "날짜는 null일 수 없습니다.")
|
|
@RequestParam
|
|
@Parameter(description = "yyyy-MM-dd 형식으로 입력해주세요.", example = "2024-06-10")
|
|
LocalDate date,
|
|
@NotNull(message = "themeId는 null일 수 없습니다.")
|
|
@RequestParam
|
|
@Parameter(description = "조회할 테마의 ID를 입력해주세요.", example = "1")
|
|
Long themeId
|
|
) {
|
|
return RoomescapeApiResponse.success(reservationTimeService.findAllAvailableTimesByDateAndTheme(date, themeId));
|
|
}
|
|
}
|