-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[FEAT] #20 - 도메인 엔티티 작성
- Loading branch information
Showing
23 changed files
with
397 additions
and
11 deletions.
There are no files selected for viewing
Empty file.
Empty file.
90 changes: 90 additions & 0 deletions
90
src/main/java/org/sopt/seonyakServer/domain/appointment/model/Appointment.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,90 @@ | ||
package org.sopt.seonyakServer.domain.appointment.model; | ||
|
||
import jakarta.persistence.Column; | ||
import jakarta.persistence.Convert; | ||
import jakarta.persistence.Entity; | ||
import jakarta.persistence.EnumType; | ||
import jakarta.persistence.Enumerated; | ||
import jakarta.persistence.FetchType; | ||
import jakarta.persistence.GeneratedValue; | ||
import jakarta.persistence.GenerationType; | ||
import jakarta.persistence.Id; | ||
import jakarta.persistence.JoinColumn; | ||
import jakarta.persistence.ManyToOne; | ||
import jakarta.persistence.Table; | ||
import java.util.Map; | ||
import lombok.AccessLevel; | ||
import lombok.Builder; | ||
import lombok.Getter; | ||
import lombok.NoArgsConstructor; | ||
import org.sopt.seonyakServer.domain.member.model.Member; | ||
import org.sopt.seonyakServer.domain.senior.model.Senior; | ||
import org.sopt.seonyakServer.domain.util.JsonConverter; | ||
|
||
|
||
@Entity | ||
@Getter | ||
@NoArgsConstructor(access = AccessLevel.PROTECTED) | ||
@Table(name = "appointment") | ||
public class Appointment { | ||
|
||
@Id | ||
@GeneratedValue(strategy = GenerationType.IDENTITY) | ||
@Column(name = "appointment_id") | ||
private Long appointmentId; | ||
|
||
@ManyToOne(fetch = FetchType.LAZY, optional = false) | ||
@JoinColumn(name = "member_id", referencedColumnName = "member_id", nullable = false) | ||
private Member member; | ||
|
||
@ManyToOne(fetch = FetchType.LAZY, optional = false) | ||
@JoinColumn(name = "senior_id", referencedColumnName = "senior_id", nullable = false) | ||
private Senior senior; | ||
|
||
@Enumerated(EnumType.STRING) | ||
@Column(name = "appointment_status", nullable = false) | ||
private AppointmentStatus appointmentStatus; | ||
|
||
@Column(name = "time_list", columnDefinition = "jsonb", nullable = false) | ||
@Convert(converter = JsonConverter.class) | ||
private Map<String, Object> timeList; | ||
|
||
@Column(name = "topic", length = 255) | ||
private String topic; | ||
|
||
@Column(name = "personal_topic", length = 255) | ||
private String personalTopic; | ||
|
||
@Column(name = "reject_reason", length = 255) | ||
private String rejectReason; | ||
|
||
@Column(name = "google_meet_link", length = 255) | ||
private String googleMeetLink; | ||
|
||
@Builder(access = AccessLevel.PRIVATE) | ||
private Appointment( | ||
Member member, | ||
Senior senior, | ||
AppointmentStatus appointmentStatus, | ||
Map<String, Object> timeList | ||
) { | ||
this.member = member; | ||
this.senior = senior; | ||
this.appointmentStatus = appointmentStatus; | ||
this.timeList = timeList; | ||
} | ||
|
||
public static Appointment createAppointment( | ||
Member member, | ||
Senior senior, | ||
AppointmentStatus appointmentStatus, | ||
Map<String, Object> timeList | ||
) { | ||
return Appointment.builder() | ||
.member(member) | ||
.senior(senior) | ||
.appointmentStatus(appointmentStatus) | ||
.timeList(timeList) | ||
.build(); | ||
} | ||
} |
17 changes: 17 additions & 0 deletions
17
src/main/java/org/sopt/seonyakServer/domain/appointment/model/AppointmentStatus.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,17 @@ | ||
package org.sopt.seonyakServer.domain.appointment.model; | ||
|
||
import lombok.AccessLevel; | ||
import lombok.Getter; | ||
import lombok.RequiredArgsConstructor; | ||
|
||
@Getter | ||
@RequiredArgsConstructor(access = AccessLevel.PRIVATE) | ||
public enum AppointmentStatus { | ||
|
||
PENDING("PENDING"), | ||
SCHEDULED("SCHEDULED"), | ||
PAST("PAST"), | ||
REJECTED("REJECTED"); | ||
|
||
private final String appointmentStatus; | ||
} |
Empty file.
Empty file.
55 changes: 49 additions & 6 deletions
55
src/main/java/org/sopt/seonyakServer/domain/member/model/Member.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Empty file.
Empty file.
92 changes: 92 additions & 0 deletions
92
src/main/java/org/sopt/seonyakServer/domain/senior/model/Senior.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,92 @@ | ||
package org.sopt.seonyakServer.domain.senior.model; | ||
|
||
import jakarta.persistence.Column; | ||
import jakarta.persistence.Convert; | ||
import jakarta.persistence.Entity; | ||
import jakarta.persistence.GeneratedValue; | ||
import jakarta.persistence.GenerationType; | ||
import jakarta.persistence.Id; | ||
import jakarta.persistence.JoinColumn; | ||
import jakarta.persistence.OneToOne; | ||
import jakarta.persistence.Table; | ||
import java.util.Map; | ||
import lombok.AccessLevel; | ||
import lombok.Builder; | ||
import lombok.Getter; | ||
import lombok.NoArgsConstructor; | ||
import org.sopt.seonyakServer.domain.member.model.Member; | ||
import org.sopt.seonyakServer.domain.util.JsonConverter; | ||
|
||
@Entity | ||
@Getter | ||
@NoArgsConstructor(access = AccessLevel.PROTECTED) | ||
@Table(name = "senior") | ||
public class Senior { | ||
|
||
@Id | ||
@GeneratedValue(strategy = GenerationType.IDENTITY) | ||
@Column(name = "senior_id") | ||
private Long seniorId; | ||
|
||
@OneToOne(optional = false) | ||
@JoinColumn(name = "member_id", referencedColumnName = "member_id", nullable = false) | ||
private Member member; | ||
|
||
@Column(name = "business_card", nullable = false, length = 255) | ||
private String businessCard; | ||
|
||
@Column(name = "company", length = 255) | ||
private String company; | ||
|
||
@Column(name = "position", length = 255) | ||
private String position; | ||
|
||
@Column(name = "detail_position", nullable = false, length = 255) | ||
private String detailPosition; | ||
|
||
@Column(name = "level", nullable = false) | ||
private Integer level; | ||
|
||
@Column(name = "catchphrase", length = 255) | ||
private String catchphrase; | ||
|
||
@Column(name = "career", length = 255) | ||
private String career; | ||
|
||
@Column(name = "award", length = 255) | ||
private String award; | ||
|
||
@Column(name = "story", length = 255) | ||
private String story; | ||
|
||
@Column(name = "preffered_time_list", columnDefinition = "jsonb") | ||
@Convert(converter = JsonConverter.class) | ||
private Map<String, Object> prefferedTimeList; | ||
|
||
@Builder(access = AccessLevel.PRIVATE) | ||
private Senior( | ||
Member member, | ||
String businessCard, | ||
String detailPosition, | ||
Integer level | ||
) { | ||
this.member = member; | ||
this.businessCard = businessCard; | ||
this.detailPosition = detailPosition; | ||
this.level = level; | ||
} | ||
|
||
public static Senior createSenior( | ||
Member member, | ||
String businessCard, | ||
String detailPosition, | ||
Integer level | ||
) { | ||
return Senior.builder() | ||
.member(member) | ||
.businessCard(businessCard) | ||
.detailPosition(detailPosition) | ||
.level(level) | ||
.build(); | ||
} | ||
} |
Empty file.
Empty file.
Empty file.
Empty file.
60 changes: 60 additions & 0 deletions
60
src/main/java/org/sopt/seonyakServer/domain/university/model/Department.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,60 @@ | ||
package org.sopt.seonyakServer.domain.university.model; | ||
|
||
import jakarta.persistence.Column; | ||
import jakarta.persistence.Entity; | ||
import jakarta.persistence.FetchType; | ||
import jakarta.persistence.GeneratedValue; | ||
import jakarta.persistence.GenerationType; | ||
import jakarta.persistence.Id; | ||
import jakarta.persistence.JoinColumn; | ||
import jakarta.persistence.ManyToOne; | ||
import jakarta.persistence.Table; | ||
import lombok.AccessLevel; | ||
import lombok.Builder; | ||
import lombok.Getter; | ||
import lombok.NoArgsConstructor; | ||
|
||
@Entity | ||
@Getter | ||
@NoArgsConstructor(access = AccessLevel.PROTECTED) | ||
@Table(name = "department") | ||
public class Department { | ||
|
||
@Id | ||
@GeneratedValue(strategy = GenerationType.IDENTITY) | ||
@Column(name = "dept_id") | ||
private Long deptId; | ||
|
||
@ManyToOne(fetch = FetchType.LAZY, optional = false) | ||
@JoinColumn(name = "univ_id", referencedColumnName = "univ_id", nullable = false) | ||
private University university; | ||
|
||
@Column(name = "dept_name", nullable = false, length = 20) | ||
private String deptName; | ||
|
||
@Column(name = "is_closed", nullable = false) | ||
private Boolean isClosed; | ||
|
||
@Builder(access = AccessLevel.PRIVATE) | ||
private Department( | ||
final University university, | ||
final String deptName, | ||
final Boolean isClosed | ||
) { | ||
this.university = university; | ||
this.deptName = deptName; | ||
this.isClosed = isClosed; | ||
} | ||
|
||
public static Department createDepartment( | ||
final University university, | ||
final String deptName, | ||
final Boolean isClosed | ||
) { | ||
return Department.builder() | ||
.university(university) | ||
.deptName(deptName) | ||
.isClosed(isClosed) | ||
.build(); | ||
} | ||
} |
Oops, something went wrong.