This repository has been archived by the owner on Aug 13, 2022. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 54
[#70] 배달 매칭 서비스 #69
Open
yyy9942
wants to merge
18
commits into
rider_info_service
Choose a base branch
from
delivery_service
base: rider_info_service
Could not load branches
Branch not found: {{ refName }}
Loading
Could not load tags
Nothing to show
Loading
Are you sure you want to change the base?
Some commits from the old base branch may be removed from the timeline,
and old review comments may become outdated.
Open
[#70] 배달 매칭 서비스 #69
Changes from 13 commits
Commits
Show all changes
18 commits
Select commit
Hold shift + click to select a range
c359d94
Merge pull request #65 from f-lab-edu/order_coupon
yyy9942 5c6b1e8
Merge pull request #64 from f-lab-edu/coupon_test
yyy9942 f7fb9c1
배달 매칭 서비스 제작
44d1eb5
배달 매칭 제작
06a9543
Merge pull request #68 from f-lab-edu/rider_info_service
yyy9942 c4d70b3
Merge pull request #71 from f-lab-edu/order_coupon
yyy9942 6de3866
리뷰 적용
yyy9942 6e5255d
푸시_서비스_적용에 적용한 리뷰를 Merge, 해당 내용으로 발생하는 오류 수정
yyy9942 ea62c9a
배달원 매칭 개발
yyy9942 c0ee25a
리뷰 반영
yyy9942 82f0018
maven에서 빌드되지 않는 버그 수정
0fa1918
리뷰 반영
yyy9942 41da68f
배달원의 배달 관련 기능 추가
yyy9942 6224def
리뷰반영
yyy9942 c945f37
오늘의 배달 수입 조회 기능 추가
da0fdce
버그 수정
5d952ca
- 리뷰 반영
yyy9942 9b49198
위치 관련 버그 수정
yyy9942 File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
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
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -3,11 +3,20 @@ | |
import com.delfood.aop.LoginCheck; | ||
import com.delfood.aop.LoginCheck.UserType; | ||
import com.delfood.aop.RiderLoginCheck; | ||
import com.delfood.dto.rider.AcceptDeliveryRequestDTO; | ||
import com.delfood.dto.rider.DeliveryRiderDTO; | ||
import com.delfood.dto.rider.AcceptDeliveryRequestDTO.RequestResult; | ||
import com.delfood.dto.rider.DeliveryInfoDTO; | ||
import com.delfood.dto.rider.RiderDTO; | ||
import com.delfood.error.exception.DuplicateException; | ||
import com.delfood.error.exception.TargetNotFoundException; | ||
import com.delfood.service.OrderService; | ||
import com.delfood.service.delivery.DeliveryService; | ||
import com.delfood.service.rider.RiderInfoService; | ||
import com.delfood.utils.SessionUtil; | ||
import com.fasterxml.jackson.core.JsonProcessingException; | ||
import com.fasterxml.jackson.databind.ObjectMapper; | ||
import java.util.List; | ||
import java.util.Objects; | ||
import javax.servlet.http.HttpSession; | ||
import lombok.Getter; | ||
|
@@ -21,6 +30,7 @@ | |
import org.springframework.web.bind.annotation.PatchMapping; | ||
import org.springframework.web.bind.annotation.PathVariable; | ||
import org.springframework.web.bind.annotation.PostMapping; | ||
import org.springframework.web.bind.annotation.PutMapping; | ||
import org.springframework.web.bind.annotation.RequestBody; | ||
import org.springframework.web.bind.annotation.RequestMapping; | ||
import org.springframework.web.bind.annotation.ResponseStatus; | ||
|
@@ -37,6 +47,12 @@ public class RiderController { | |
@Autowired | ||
private ObjectMapper objectMapper; | ||
|
||
@Autowired | ||
private DeliveryService deliveryService; | ||
|
||
@Autowired | ||
private OrderService orderService; | ||
|
||
/** | ||
* 아이디 중복 체크. | ||
* @author jun | ||
|
@@ -123,14 +139,109 @@ public void deleteRiderAccount(HttpSession session, String password) { | |
SessionUtil.logoutRider(session); | ||
} | ||
|
||
/** | ||
* 라이더의 메일 주소를 변경한다. | ||
* @param session 현제 세션 | ||
* @param request 요청 정보 | ||
*/ | ||
@PatchMapping("mail") | ||
public void updateMail(HttpSession session, @RequestBody UpdateMailRequest request) { | ||
String id = SessionUtil.getLoginRiderId(session); | ||
riderInfoService.changeMail(id, request.getPassword(), request.getUpdateMail()); | ||
} | ||
|
||
/** | ||
* 주문에 대한 배달 매칭 요청을 진행한다. | ||
* @param request 요청 정보 | ||
* @param session 현재 세션 | ||
* @return | ||
*/ | ||
@PostMapping("delivery/accept") | ||
@LoginCheck(type = UserType.RIDER) | ||
public AcceptDeliveryRequestDTO deliveryAccept(@RequestBody DeliveryAcceptRequest request, | ||
HttpSession session) { | ||
String riderId = SessionUtil.getLoginRiderId(session); | ||
return deliveryService.acceptDeliveryRequest(riderId, request.getOrderId()); | ||
} | ||
|
||
|
||
/** | ||
* 해당 주문의 배달을 완료했다는 요청을 받는다. | ||
* @author jun | ||
* @param request 요청 정보 | ||
* @param session 현제 세션 | ||
*/ | ||
@PatchMapping("delivery/complete") | ||
@LoginCheck(type = UserType.RIDER) | ||
public void deliveryComplete(@RequestBody DeliveryCompleteRequest request, HttpSession session) { | ||
String riderId = SessionUtil.getLoginRiderId(session); | ||
if (deliveryService.isRiderOrder(riderId, request.getOrderId()) == false) { | ||
log.info("주문 완료 권한 없음. 주문 아이디 : {}, 라이더 아이디 : {}", request.getOrderId(), riderId); | ||
throw new IllegalArgumentException("해당 라이더가 배달중인 주문이 아닙니다. 권한이 없습니다."); | ||
} | ||
deliveryService.deliveryComplete(request.getOrderId()); | ||
} | ||
|
||
/** | ||
* 라이더의 현제 위치 정보를 업데이트한다. | ||
* 새로운 정보를 덧씌우는 것이기 때문에 put으로 매핑하였다. | ||
* @author jun | ||
* @param info 요청 정보 | ||
* @param session 현재 세션 | ||
*/ | ||
@PutMapping("delivery/available") | ||
@LoginCheck(type = UserType.RIDER) | ||
public void updateDeliveryRiderInfo(DeliveryRiderDTO info, HttpSession session) { | ||
String riderId = SessionUtil.getLoginRiderId(session); | ||
|
||
if (riderInfoService.hasDelivery(riderId)) { | ||
throw new DuplicateException("이미 진행중인 배달이 있습니다. 한번에 하나의 배달만 가능합니다."); | ||
} | ||
|
||
deliveryService.updateRider(info); | ||
} | ||
|
||
/** | ||
* 라이더를 배당 매칭 대기 명단에서 제거한다. | ||
* @author jun | ||
* @param session 현재 세션 | ||
*/ | ||
@DeleteMapping("delivery/available") | ||
@LoginCheck(type = UserType.RIDER) | ||
public void deletDeliveryRiderInfo(HttpSession session) { | ||
String riderId = SessionUtil.getLoginRiderId(session); | ||
deliveryService.delete(riderId); | ||
} | ||
|
||
/** | ||
* 라이더의 모든 배달 현황을 확인한다. | ||
* @param session 현제 세션 | ||
* @return | ||
*/ | ||
@GetMapping("delivery/{orderId}") | ||
@LoginCheck(type = UserType.RIDER) | ||
public List<DeliveryInfoDTO> getAllDeliveryList( | ||
@PathVariable(name = "orderId", required = false, value = "0") Long lastViewedOrderId, | ||
HttpSession session) { | ||
String riderId = SessionUtil.getLoginRiderId(session); | ||
return deliveryService.getMyAllDeliveries(riderId, lastViewedOrderId); | ||
} | ||
|
||
/** | ||
* 현재 배달중인 주문 정보를 확인한다. | ||
* @param session 현제 세션 | ||
* @return | ||
*/ | ||
@GetMapping("delivery") | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. 만약 배달중인 라이더의 정보를 조회할 요구사항이 생기면 |
||
@LoginCheck(type = UserType.RIDER) | ||
public DeliveryInfoDTO getCurrentDelivery(HttpSession session) { | ||
String riderId = SessionUtil.getLoginRiderId(session); | ||
DeliveryInfoDTO currentDelivery = deliveryService.getCurrentDelivery(riderId); | ||
if (Objects.isNull(currentDelivery)) { | ||
throw new TargetNotFoundException("현재 라이더님은 배달중이 아닙니다."); | ||
} | ||
return currentDelivery; | ||
} | ||
|
||
// Request | ||
@Getter | ||
private static class SignInRequest { | ||
|
@@ -140,7 +251,12 @@ private static class SignInRequest { | |
@NonNull | ||
private String password; | ||
} | ||
|
||
|
||
@Getter | ||
private static class DeliveryAcceptRequest { | ||
private Long orderId; | ||
} | ||
|
||
@Getter | ||
private static class UpdatePasswordRequest { | ||
@NonNull | ||
|
@@ -159,6 +275,11 @@ private static class UpdateMailRequest { | |
private String updateMail; | ||
} | ||
|
||
@Getter | ||
private static class DeliveryCompleteRequest { | ||
@NonNull | ||
private Long orderId; | ||
} | ||
|
||
|
||
} |
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,29 @@ | ||
package com.delfood.dao.deliveery; | ||
|
||
import com.delfood.dto.OrderDTO.OrderStatus; | ||
import com.delfood.dto.address.Position; | ||
import com.delfood.dto.rider.DeliveryRiderDTO; | ||
import java.util.List; | ||
|
||
public interface DeliveryDao { | ||
|
||
void updateRiderInfo(DeliveryRiderDTO riderInfo); | ||
|
||
boolean deleteRiderInfo(String riderId); | ||
|
||
boolean hasRiderInfo(String riderId); | ||
|
||
void deleteNonUpdatedRiders(); | ||
|
||
DeliveryRiderDTO getRiderInfo(String riderId); | ||
|
||
List<DeliveryRiderDTO> getRiderList(); | ||
|
||
void deleteAll(List<String> idList); | ||
|
||
OrderStatus getOrderStatus(Long orderId); | ||
|
||
void setOrderStatus(Long orderId, OrderStatus status); | ||
|
||
void deleteOrderStatus(Long orderId); | ||
} |
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
모습을 보니 떠오른건데 type보다는 level이 어떨까요?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
level도 생각해보았는데 뭔가 접근의 계층이 있어야 할것같은 느낌이라서요. 제가 만든 로그인은 3가지의 전혀 다른 타입이라서 일단 타입으로 해두었습니다.