Skip to content

Commit

Permalink
Merge pull request #33 from Digital-Hana-Starbucks/admin
Browse files Browse the repository at this point in the history
Fix: 관리자 메뉴/주문 관련 api 수정
  • Loading branch information
mummhy0811 authored May 7, 2024
2 parents bc93145 + 69cda00 commit fcee988
Show file tree
Hide file tree
Showing 6 changed files with 33 additions and 18 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,8 @@
@Builder
@Getter
public class OrderResDto {
private int userIdx;
private Integer userIdx;
private String userNickname;
private int orderIdx;
private String orderId;
private Integer totalPrice;
Expand Down
2 changes: 1 addition & 1 deletion src/main/java/com/hanaro/starbucks/entity/Orders.java
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@ public class Orders {
private LocalDateTime orderDate;

@ManyToOne
@JoinColumn(name = "user_idx")
@JoinColumn(name = "user_idx", nullable = true)
private Member user;

@OneToMany(mappedBy = "orders", cascade = CascadeType.ALL)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,9 @@
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.stereotype.Repository;

import java.util.List;

@Repository
public interface OrderRepository extends JpaRepository<Orders, Integer> {
List<Orders> findAllByOrderByOrderIdxDesc();
}
Original file line number Diff line number Diff line change
Expand Up @@ -50,6 +50,7 @@ public void deleteMenuByMenuIdx(int menuIdx) throws Exception {
if (optionalMenu.isEmpty()) {
throw new Exception("존재하지 않는 메뉴입니다.");
}
s3Uploader.deleteFile(optionalMenu.get().getMenuImage());
menuRepository.deleteById(menuIdx);
}

Expand Down
15 changes: 10 additions & 5 deletions src/main/java/com/hanaro/starbucks/service/OrderService.java
Original file line number Diff line number Diff line change
Expand Up @@ -21,13 +21,16 @@ public class OrderService {
private final OrderDetailRepository orderDetailRepository;

public List<OrderResDto> getOrders() {
List<Orders> orders = orderRepository.findAll();
List<OrderResDto> orderResDtos = orders.stream()
List<Orders> orders = orderRepository.findAllByOrderByOrderIdxDesc();
return orders.stream()
.map(order -> {
List<OrderDetail> orderDetails = order.getOrderDetails();
int totalPrice = calculateTotalPrice(orderDetails);
Integer userIdx = order.getUser() != null ? order.getUser().getUserIdx() : null;
String userNickname = order.getUser()!=null? order.getUser().getUserNickname() : null ;
return OrderResDto.builder()
.userIdx(order.getUser().getUserIdx())
.userIdx(userIdx)
.userNickname(userNickname)
.orderIdx(order.getOrderIdx())
.orderId(order.getOrderId())
.totalPrice(totalPrice)
Expand All @@ -36,13 +39,15 @@ public List<OrderResDto> getOrders() {
.build();
})
.collect(Collectors.toList());
return orderResDtos;
}

public OrderResDto getOrder(int orderIdx) {
Orders order = findOrderById(orderIdx);
Integer userIdx = order.getUser() != null ? order.getUser().getUserIdx() : null;
String userNickname = order.getUser()!=null? order.getUser().getUserNickname() : null ;
return OrderResDto.builder()
.userIdx(order.getUser().getUserIdx())
.userIdx(userIdx)
.userNickname(userNickname)
.orderIdx(order.getOrderIdx())
.orderId(order.getOrderId())
.totalPrice(calculateTotalPrice(order.getOrderDetails()))
Expand Down
27 changes: 16 additions & 11 deletions src/main/java/com/hanaro/starbucks/service/S3Uploader.java
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
package com.hanaro.starbucks.service;

import com.amazonaws.services.s3.AmazonS3;
import com.amazonaws.services.s3.model.CannedAccessControlList;
import com.amazonaws.services.s3.model.DeleteObjectRequest;
import com.amazonaws.services.s3.model.PutObjectRequest;
import lombok.RequiredArgsConstructor;
import lombok.extern.slf4j.Slf4j;
Expand All @@ -12,7 +12,7 @@
import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.UnsupportedEncodingException;
import java.net.URL;
import java.net.URLDecoder;
import java.util.UUID;

Expand All @@ -26,13 +26,12 @@ public class S3Uploader {

// MultipartFile을 전달받아 File로 전환한 후 S3에 업로드
public String upload(MultipartFile multipartFile, String dirName) throws IOException {

File uploadFile = convert(multipartFile); // 파일 변환할 수 없으면 에러
String fileName = dirName + "/" + uploadFile.getName();
String safeDirName = dirName.replace("/", "_");
String fileName = safeDirName + "/" + uploadFile.getName();

String uploadImageUrl = putS3(uploadFile, fileName);
removeNewFile(uploadFile); // 로컬에 생성된 File 삭제 (MultipartFile -> File 전환 하며 로컬에 파일 생성됨)

return uploadImageUrl; // 업로드된 파일의 S3 URL 주소 반환
}

Expand Down Expand Up @@ -68,17 +67,23 @@ private File convert(MultipartFile file) throws IOException {
}

// 파일 삭제
public void deleteFile(String fileName) {
public void deleteFile(String url) {
try {
String decodedFileName = URLDecoder.decode(fileName, "UTF-8");
// URL 객체 생성
URL s3URL = new URL(url);
String path = s3URL.getPath();

if (path.startsWith("/")) {
path = path.substring(1);
}
String decodedFileName = URLDecoder.decode(path, "UTF-8");
log.info("Deleting file from S3: " + decodedFileName);
amazonS3Client.deleteObject(bucket, decodedFileName);
} catch (UnsupportedEncodingException e) {
log.error("Error while decoding the file name: {}", e.getMessage());
amazonS3Client.deleteObject(new DeleteObjectRequest(bucket, decodedFileName));
} catch (Exception e) {
log.error("Error deleting file from S3: " + e.getMessage());
}
}


// 파일 확장자 추출
private String extractExt(String originalFilename) {
int pos = originalFilename.lastIndexOf(".");
Expand Down

0 comments on commit fcee988

Please sign in to comment.