From 245f3ce6b9b925da2fd4dcd7d08785f0faa7534d Mon Sep 17 00:00:00 2001 From: Minseo Cho Date: Wed, 11 Oct 2023 13:34:16 +0900 Subject: [PATCH 1/9] =?UTF-8?q?=F0=9F=94=A7=20fix:=20plan=20=EC=A1=B0?= =?UTF-8?q?=ED=9A=8C=20=EC=8B=9C=20=EC=A2=8C=ED=91=9C=EA=B0=92=20=EB=B0=98?= =?UTF-8?q?=ED=99=98?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit ๐Ÿ”ง fix: plan ์กฐํšŒ ์‹œ ์ขŒํ‘œ๊ฐ’ ๋ฐ˜ํ™˜ --- .../java/snap/api/plan/dto/response/PlanFullResponseDto.java | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/snapspot-api/src/main/java/snap/api/plan/dto/response/PlanFullResponseDto.java b/snapspot-api/src/main/java/snap/api/plan/dto/response/PlanFullResponseDto.java index f328d20..d188fe8 100644 --- a/snapspot-api/src/main/java/snap/api/plan/dto/response/PlanFullResponseDto.java +++ b/snapspot-api/src/main/java/snap/api/plan/dto/response/PlanFullResponseDto.java @@ -34,6 +34,8 @@ public class PlanFullResponseDto { private Long price; private String placeName; private String placeAddress; + private String x; + private String y; private Status status; private List messages; @@ -51,7 +53,8 @@ public PlanFullResponseDto(Plan plan, Member member, List messageList) this.price = plan.getPrice(); this.placeName = plan.getPlaceName(); this.placeAddress = plan.getPlaceAddress(); - // this.message = plan.getMessage(); + this.x = plan.getX(); + this.y = plan.getY(); this.status = plan.getStatus(); this.messages = messageList.stream() .map(message -> new MessageResponseDto(message, member)) From b7b90e8d4a2a00be7fb4f50e9da28dc66725e3bc Mon Sep 17 00:00:00 2001 From: Minseo Cho Date: Wed, 11 Oct 2023 13:36:55 +0900 Subject: [PATCH 2/9] =?UTF-8?q?=F0=9F=8E=A8=20style:=20=EB=B9=88=20?= =?UTF-8?q?=EC=A4=84=20=EC=82=AD=EC=A0=9C?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- build.gradle | 1 - 1 file changed, 1 deletion(-) diff --git a/build.gradle b/build.gradle index 32c410e..d0b3c6f 100644 --- a/build.gradle +++ b/build.gradle @@ -4,7 +4,6 @@ buildscript { } } - plugins { id 'java' id 'org.springframework.boot' version '2.7.13' From 25a15d2dc30348fb168f410ae8110d232441484d Mon Sep 17 00:00:00 2001 From: Minseo Cho Date: Sat, 14 Oct 2023 18:17:38 +0900 Subject: [PATCH 3/9] =?UTF-8?q?=E2=9C=A8=20feat:=20BaseTimeEntity=20?= =?UTF-8?q?=EC=B6=94=EA=B0=80?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../src/main/java/snap/ApiApplication.java | 2 ++ .../domains/global/entity/BaseTimeEntity.java | 22 +++++++++++++++++++ .../snap/domains/message/entity/Message.java | 4 +++- .../java/snap/domains/plan/entity/Plan.java | 3 ++- 4 files changed, 29 insertions(+), 2 deletions(-) create mode 100644 snapspot-domain/src/main/java/snap/domains/global/entity/BaseTimeEntity.java diff --git a/snapspot-api/src/main/java/snap/ApiApplication.java b/snapspot-api/src/main/java/snap/ApiApplication.java index 4cf18b9..28d74a4 100644 --- a/snapspot-api/src/main/java/snap/ApiApplication.java +++ b/snapspot-api/src/main/java/snap/ApiApplication.java @@ -3,11 +3,13 @@ import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.boot.autoconfigure.domain.EntityScan; +import org.springframework.data.jpa.repository.config.EnableJpaAuditing; import org.springframework.data.jpa.repository.config.EnableJpaRepositories; import javax.annotation.PostConstruct; import java.util.TimeZone; +@EnableJpaAuditing @EntityScan(basePackages = {"snap"}) @EnableJpaRepositories(basePackages = {"snap"}) @SpringBootApplication diff --git a/snapspot-domain/src/main/java/snap/domains/global/entity/BaseTimeEntity.java b/snapspot-domain/src/main/java/snap/domains/global/entity/BaseTimeEntity.java new file mode 100644 index 0000000..97ef6ee --- /dev/null +++ b/snapspot-domain/src/main/java/snap/domains/global/entity/BaseTimeEntity.java @@ -0,0 +1,22 @@ +package snap.domains.global.entity; + +import lombok.Getter; +import org.springframework.data.annotation.CreatedDate; +import org.springframework.data.annotation.LastModifiedDate; +import org.springframework.data.jpa.domain.support.AuditingEntityListener; + +import javax.persistence.*; +import java.time.LocalDateTime; + +@Getter +@MappedSuperclass +@EntityListeners(AuditingEntityListener.class) +public class BaseTimeEntity { + @CreatedDate + @Column(updatable = false, columnDefinition = "TIMESTAMP") + private LocalDateTime createdAt; + + @LastModifiedDate + @Column(columnDefinition = "TIMESTAMP") + private LocalDateTime modifiedAt; +} diff --git a/snapspot-domain/src/main/java/snap/domains/message/entity/Message.java b/snapspot-domain/src/main/java/snap/domains/message/entity/Message.java index ce9379b..5394b3a 100644 --- a/snapspot-domain/src/main/java/snap/domains/message/entity/Message.java +++ b/snapspot-domain/src/main/java/snap/domains/message/entity/Message.java @@ -4,14 +4,16 @@ import lombok.Builder; import lombok.Getter; import lombok.NoArgsConstructor; +import snap.domains.global.entity.BaseTimeEntity; import snap.domains.plan.entity.Plan; import javax.persistence.*; +import java.time.LocalDateTime; @Entity @Getter @NoArgsConstructor(access = AccessLevel.PROTECTED) -public class Message { +public class Message extends BaseTimeEntity { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Long messageId; diff --git a/snapspot-domain/src/main/java/snap/domains/plan/entity/Plan.java b/snapspot-domain/src/main/java/snap/domains/plan/entity/Plan.java index 1352164..6815cfe 100644 --- a/snapspot-domain/src/main/java/snap/domains/plan/entity/Plan.java +++ b/snapspot-domain/src/main/java/snap/domains/plan/entity/Plan.java @@ -7,6 +7,7 @@ import lombok.NoArgsConstructor; import org.hibernate.annotations.GenericGenerator; import org.hibernate.annotations.Type; +import snap.domains.global.entity.BaseTimeEntity; import snap.domains.member.entity.Member; import snap.domains.photographer.entity.Photographer; import snap.domains.review.entity.Review; @@ -21,7 +22,7 @@ @Entity @Getter @NoArgsConstructor(access = AccessLevel.PROTECTED) -public class Plan { +public class Plan extends BaseTimeEntity { @Id @GeneratedValue(generator = "uuid2") @GenericGenerator(name = "uuid2", strategy = "org.hibernate.id.UUIDGenerator") From 299047cae5c1dd2dc2d0a0861f0c9eacb437d327 Mon Sep 17 00:00:00 2001 From: Minseo Cho Date: Sat, 14 Oct 2023 18:19:38 +0900 Subject: [PATCH 4/9] =?UTF-8?q?=E2=9C=A8=20feat:=20Message=20=EC=A1=B0?= =?UTF-8?q?=ED=9A=8C=20=EC=8B=9C=20=EC=83=9D=EC=84=B1=20=EC=8B=9C=EA=B0=84?= =?UTF-8?q?=20=EC=B6=94=EA=B0=80?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../main/java/snap/api/message/dto/MessageResponseDto.java | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/snapspot-api/src/main/java/snap/api/message/dto/MessageResponseDto.java b/snapspot-api/src/main/java/snap/api/message/dto/MessageResponseDto.java index 409c65e..07ab225 100644 --- a/snapspot-api/src/main/java/snap/api/message/dto/MessageResponseDto.java +++ b/snapspot-api/src/main/java/snap/api/message/dto/MessageResponseDto.java @@ -9,6 +9,8 @@ import snap.domains.message.entity.Sender; import snap.enums.Role; +import java.time.LocalDateTime; + @Getter @NoArgsConstructor(access = AccessLevel.PROTECTED) public class MessageResponseDto { @@ -16,6 +18,7 @@ public class MessageResponseDto { private Boolean isMine; private Sender sender; private String contents; + private LocalDateTime createdAt; public MessageResponseDto(Message message, Member member) { Sender sender = Sender.MEMBER; @@ -27,5 +30,6 @@ public MessageResponseDto(Message message, Member member) { this.contents = message.getContents(); this.sender = message.getSender(); this.isMine = sender.equals(message.getSender()); + this.createdAt = message.getCreatedAt(); } } From 279b9d850716bbcbaf723e7b9a16a862efd295b9 Mon Sep 17 00:00:00 2001 From: Minseo Cho Date: Sat, 14 Oct 2023 18:19:55 +0900 Subject: [PATCH 5/9] =?UTF-8?q?=E2=9C=A8=20feat:=20Plan=20=EC=A1=B0?= =?UTF-8?q?=ED=9A=8C=20=EC=8B=9C=20=EC=83=9D=EC=84=B1/=EB=B3=80=EA=B2=BD?= =?UTF-8?q?=20=EC=8B=9C=EA=B0=84=20=EC=B6=94=EA=B0=80?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../java/snap/api/plan/dto/response/PlanFullResponseDto.java | 4 ++++ .../main/java/snap/api/plan/dto/response/PlanResponseDto.java | 4 ++++ 2 files changed, 8 insertions(+) diff --git a/snapspot-api/src/main/java/snap/api/plan/dto/response/PlanFullResponseDto.java b/snapspot-api/src/main/java/snap/api/plan/dto/response/PlanFullResponseDto.java index d188fe8..3c46c1c 100644 --- a/snapspot-api/src/main/java/snap/api/plan/dto/response/PlanFullResponseDto.java +++ b/snapspot-api/src/main/java/snap/api/plan/dto/response/PlanFullResponseDto.java @@ -38,6 +38,8 @@ public class PlanFullResponseDto { private String y; private Status status; private List messages; + private LocalDateTime createdAt; + private LocalDateTime modifiedAt; @Builder public PlanFullResponseDto(Plan plan, Member member, List messageList) { @@ -59,5 +61,7 @@ public PlanFullResponseDto(Plan plan, Member member, List messageList) this.messages = messageList.stream() .map(message -> new MessageResponseDto(message, member)) .collect(Collectors.toList()); + this.createdAt = plan.getCreatedAt(); + this.modifiedAt = plan.getModifiedAt(); } } diff --git a/snapspot-api/src/main/java/snap/api/plan/dto/response/PlanResponseDto.java b/snapspot-api/src/main/java/snap/api/plan/dto/response/PlanResponseDto.java index 2a5d9ab..ab06b09 100644 --- a/snapspot-api/src/main/java/snap/api/plan/dto/response/PlanResponseDto.java +++ b/snapspot-api/src/main/java/snap/api/plan/dto/response/PlanResponseDto.java @@ -33,6 +33,8 @@ public class PlanResponseDto { private Long price; private String request; private Status status; + private LocalDateTime createdAt; + private LocalDateTime modifiedAt; @Builder public PlanResponseDto(Plan plan) { @@ -47,5 +49,7 @@ public PlanResponseDto(Plan plan) { this.wishPlace = plan.getWishPlace(); this.request = plan.getRequest(); this.status = plan.getStatus(); + this.createdAt = plan.getCreatedAt(); + this.modifiedAt = plan.getModifiedAt(); } } From baa6c7a8120676b90a5dbcb873b0f88102ed3a37 Mon Sep 17 00:00:00 2001 From: Minseo Cho Date: Sat, 14 Oct 2023 18:20:39 +0900 Subject: [PATCH 6/9] =?UTF-8?q?=F0=9F=8E=A8=20style:=20=EB=B9=88=20?= =?UTF-8?q?=EC=A4=84=20=EC=82=AD=EC=A0=9C?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../src/main/java/snap/api/message/service/MessageService.java | 3 --- .../snap/domains/plan/repository/PlanQueryDslRepository.java | 1 - 2 files changed, 4 deletions(-) diff --git a/snapspot-api/src/main/java/snap/api/message/service/MessageService.java b/snapspot-api/src/main/java/snap/api/message/service/MessageService.java index fdde756..b34ef2f 100644 --- a/snapspot-api/src/main/java/snap/api/message/service/MessageService.java +++ b/snapspot-api/src/main/java/snap/api/message/service/MessageService.java @@ -30,7 +30,6 @@ public Message createMessage(Member member, MessageRequestDto request) { } Plan plan = planDomainService.findByPlanId(request.getPlanId()); - if (!plan.getCustomer().getMemberId().equals(member.getMemberId())) { if (!plan.getPhotographer().getMember().getMemberId().equals(member.getMemberId())) { @@ -38,8 +37,6 @@ public Message createMessage(Member member, MessageRequestDto request) { } } - - return messageDomainService.createMessage( plan, request.getContents(), diff --git a/snapspot-domain/src/main/java/snap/domains/plan/repository/PlanQueryDslRepository.java b/snapspot-domain/src/main/java/snap/domains/plan/repository/PlanQueryDslRepository.java index 8b120f7..df11b29 100644 --- a/snapspot-domain/src/main/java/snap/domains/plan/repository/PlanQueryDslRepository.java +++ b/snapspot-domain/src/main/java/snap/domains/plan/repository/PlanQueryDslRepository.java @@ -21,7 +21,6 @@ public class PlanQueryDslRepository { private final EntityManager em; private final JPAQueryFactory queryFactory; - public void changePlanStatusOfToday() { LocalDateTime now = LocalDateTime.now(); now = LocalDateTime.of(now.getYear(), now.getMonth(), now.getDayOfMonth(), 0, 0, 0); From 259eb356e6a8c75003d84668c50e73ace2a12723 Mon Sep 17 00:00:00 2001 From: Minseo Cho Date: Sat, 14 Oct 2023 18:21:48 +0900 Subject: [PATCH 7/9] =?UTF-8?q?=E2=9C=A8=20feat:=20Transactional=20?= =?UTF-8?q?=EC=96=B4=EB=85=B8=ED=85=8C=EC=9D=B4=EC=85=98=20=EC=B6=94?= =?UTF-8?q?=EA=B0=80?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../src/main/java/snap/api/review/service/ReviewService.java | 1 + 1 file changed, 1 insertion(+) diff --git a/snapspot-api/src/main/java/snap/api/review/service/ReviewService.java b/snapspot-api/src/main/java/snap/api/review/service/ReviewService.java index a6b04b3..d804514 100644 --- a/snapspot-api/src/main/java/snap/api/review/service/ReviewService.java +++ b/snapspot-api/src/main/java/snap/api/review/service/ReviewService.java @@ -45,6 +45,7 @@ public List findReviewListByMember(Member member) { return reviewList.stream().map(ReviewResponseDto::new).collect(Collectors.toList()); } + @Transactional(readOnly = true) public List findReviewListByPhotographer(Photographer photographer) { return reviewDomainService.findReviewListByPhotographer(photographer) .stream().map(ReviewResponseDto::new).collect(Collectors.toList()); From 964bd8fafe41dd1e71aa099c02c4a1cab1e2a4c5 Mon Sep 17 00:00:00 2001 From: Minseo Cho Date: Sat, 14 Oct 2023 18:23:14 +0900 Subject: [PATCH 8/9] =?UTF-8?q?=E2=9C=A8=20feat:=20Plan=20=EC=A1=B0?= =?UTF-8?q?=ED=9A=8C=20=EC=8B=9C=20=EC=83=9D=EC=84=B1=20=EC=8B=9C=EA=B0=84?= =?UTF-8?q?=20=EC=B5=9C=EC=8B=A0=EC=88=9C=EC=9C=BC=EB=A1=9C=20=EC=A0=95?= =?UTF-8?q?=EB=A0=AC?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../snap/domains/plan/repository/PlanJPARepository.java | 9 ++++----- .../snap/domains/plan/service/PlanDomainService.java | 8 ++++---- 2 files changed, 8 insertions(+), 9 deletions(-) diff --git a/snapspot-domain/src/main/java/snap/domains/plan/repository/PlanJPARepository.java b/snapspot-domain/src/main/java/snap/domains/plan/repository/PlanJPARepository.java index 02c5229..de30bf5 100644 --- a/snapspot-domain/src/main/java/snap/domains/plan/repository/PlanJPARepository.java +++ b/snapspot-domain/src/main/java/snap/domains/plan/repository/PlanJPARepository.java @@ -12,15 +12,14 @@ public interface PlanJPARepository extends JpaRepository { - List findAllByCustomer(Member member); - List findAllByPhotographer(Photographer photographer); + List findAllByCustomerOrderByCreatedAtDesc(Member member); + List findAllByPhotographerOrderByCreatedAtDesc(Photographer photographer); List findAllByPhotographerAndStatus(Photographer photographer, Status status1); - List findAllByPhotographerAndStatusOrStatus(Photographer photographer, Status status1, Status status2); + List findAllByPhotographerAndStatusOrStatusOrderByCreatedAtDesc(Photographer photographer, Status status1, Status status2); + List findAllByPhotographerAndStatusOrStatusOrStatusOrderByCreatedAtDesc(Photographer photographer, Status status1, Status status2, Status status3); - List findAllByPhotographerAndStatusOrStatusOrStatus(Photographer photographer, Status status1, Status status2, Status status3); - Optional findByPlanIdAndCustomer(UUID planId, Member member); } diff --git a/snapspot-domain/src/main/java/snap/domains/plan/service/PlanDomainService.java b/snapspot-domain/src/main/java/snap/domains/plan/service/PlanDomainService.java index 1cbac17..f8046a0 100644 --- a/snapspot-domain/src/main/java/snap/domains/plan/service/PlanDomainService.java +++ b/snapspot-domain/src/main/java/snap/domains/plan/service/PlanDomainService.java @@ -78,12 +78,12 @@ public Plan updateState(Plan plan, Status status) { @Transactional(readOnly = true) public List findByPhotographer(Photographer photographer) { - return planRepository.findAllByPhotographer(photographer); + return planRepository.findAllByPhotographerOrderByCreatedAtDesc(photographer); } @Transactional(readOnly = true) public List findByMember(Member member) { - return planRepository.findAllByCustomer(member); + return planRepository.findAllByCustomerOrderByCreatedAtDesc(member); } public Plan findByPlanIdAndMember(UUID planId, Member member) { @@ -100,12 +100,12 @@ public void updateStateOfComplete() { @Transactional(readOnly = true) public List findByPhotographerAndStatus1(Photographer photographer, Status status, Status status1) { - return planRepository.findAllByPhotographerAndStatusOrStatus(photographer, status, status1); + return planRepository.findAllByPhotographerAndStatusOrStatusOrderByCreatedAtDesc(photographer, status, status1); } @Transactional(readOnly = true) public List findByPhotographerAndStatus(Photographer photographer, Status status, Status status1, Status status2) { - return planRepository.findAllByPhotographerAndStatusOrStatusOrStatus(photographer,status,status1,status2); + return planRepository.findAllByPhotographerAndStatusOrStatusOrStatusOrderByCreatedAtDesc(photographer,status,status1,status2); } public void changePlan( From cec473b04963b46548ed7ebccd19e72d221b4d84 Mon Sep 17 00:00:00 2001 From: sunnyineverywhere Date: Tue, 17 Oct 2023 21:45:32 +0900 Subject: [PATCH 9/9] =?UTF-8?q?=E2=9C=A8=20feat:=20=EC=9A=B4=EC=98=81=20?= =?UTF-8?q?=ED=99=98=EA=B2=BD=20=EB=AA=A8=EB=8B=88=ED=84=B0=EB=A7=81?= =?UTF-8?q?=EC=9D=84=20=EC=9C=84=ED=95=9C=20=EB=A1=9C=EA=B9=85?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../src/main/java/snap/api/plan/service/PlanService.java | 2 ++ 1 file changed, 2 insertions(+) diff --git a/snapspot-api/src/main/java/snap/api/plan/service/PlanService.java b/snapspot-api/src/main/java/snap/api/plan/service/PlanService.java index bdb0b7a..3d50404 100644 --- a/snapspot-api/src/main/java/snap/api/plan/service/PlanService.java +++ b/snapspot-api/src/main/java/snap/api/plan/service/PlanService.java @@ -28,6 +28,7 @@ import java.util.UUID; import java.util.stream.Collectors; +@Slf4j @Service @RequiredArgsConstructor public class PlanService { @@ -46,6 +47,7 @@ public PlanResponseDto createRequest(Member member, PlanRequestDto requestDto) { public PlanFullResponseDto createDeposit(Member member, DepositRequestDto requestDto) throws ParseException { JSONObject coordinate = kakaoClient.getCoordinateFromAddress(requestDto.getPlaceAddress()); + log.info((String) coordinate.get("x"), (String) coordinate.get("y")); Plan plan = planDomainService.createDeposit(requestDto.toEntity(), (String) coordinate.get("x"), (String) coordinate.get("y")); return new PlanFullResponseDto(plan, member, messageDomainService.findByPlanId(plan.getPlanId())); }