generated from pricelees/issue-pr-template
<!-- 제목 양식 --> <!-- [이슈번호] 작업 요약 (예시: [#10] Gitea 템플릿 생성) --> ## 📝 관련 이슈 및 PR **PR과 관련된 이슈 번호** - #20 ## ✨ 작업 내용 <!-- 어떤 작업을 했는지 알려주세요! --> - 기존에 공통으로 사용하던 커스텀 예외를 도메인별로 분리 - 새로 정의된 예외는 ErrorCode를 지정할 때 HttpStatusCode를 지정하도록 하여 잘못된 지정에서 오는 휴먼 에러 방지 - 커스텀 예외를 적용하는 과정에서 가독성이 낮다고 느껴지는 일부 함수형 코드는 선언형으로 수정 ## 🧪 테스트 <!-- 어떤 테스트를 생각했고 진행했는지 알려주세요! --> - 테스트 중 일부 미비된 테스트 보완 후 전체 로직 테스트 완료 ## 📚 참고 자료 및 기타 <!-- 참고한 자료, 또는 논의할 사항이 있다면 알려주세요! --> 커스텀 예외도 작업이 길어져 로깅은 이후에 진행할 예정 Reviewed-on: #21 Co-authored-by: pricelees <priceelees@gmail.com> Co-committed-by: pricelees <priceelees@gmail.com>
48 lines
1.3 KiB
Kotlin
48 lines
1.3 KiB
Kotlin
package roomescape.reservation.infrastructure.persistence
|
|
|
|
import com.fasterxml.jackson.annotation.JsonIgnore
|
|
import jakarta.persistence.*
|
|
import roomescape.member.infrastructure.persistence.MemberEntity
|
|
import roomescape.theme.infrastructure.persistence.ThemeEntity
|
|
import roomescape.time.infrastructure.persistence.TimeEntity
|
|
import java.time.LocalDate
|
|
|
|
@Entity
|
|
@Table(name = "reservations")
|
|
class ReservationEntity(
|
|
@Id
|
|
@GeneratedValue(strategy = GenerationType.IDENTITY)
|
|
var id: Long? = null,
|
|
|
|
var date: LocalDate,
|
|
|
|
@ManyToOne(fetch = FetchType.LAZY)
|
|
@JoinColumn(name = "time_id", nullable = false)
|
|
var time: TimeEntity,
|
|
|
|
@ManyToOne(fetch = FetchType.LAZY)
|
|
@JoinColumn(name = "theme_id", nullable = false)
|
|
var theme: ThemeEntity,
|
|
|
|
@ManyToOne(fetch = FetchType.LAZY)
|
|
@JoinColumn(name = "member_id", nullable = false)
|
|
var member: MemberEntity,
|
|
|
|
@Enumerated(value = EnumType.STRING)
|
|
var reservationStatus: ReservationStatus
|
|
) {
|
|
@JsonIgnore
|
|
fun isWaiting(): Boolean = reservationStatus == ReservationStatus.WAITING
|
|
|
|
@JsonIgnore
|
|
fun isReservedBy(memberId: Long): Boolean {
|
|
return this.member.id == memberId
|
|
}
|
|
}
|
|
|
|
enum class ReservationStatus {
|
|
CONFIRMED,
|
|
CONFIRMED_PAYMENT_REQUIRED,
|
|
WAITING
|
|
}
|