-
Notifications
You must be signed in to change notification settings - Fork 6
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Batch-v1.0.5
- Loading branch information
Showing
19 changed files
with
435 additions
and
440 deletions.
There are no files selected for viewing
120 changes: 0 additions & 120 deletions
120
DuDoong-Batch/src/main/java/band/gosrock/excel/ExcelOrderHelper.java
This file was deleted.
Oops, something went wrong.
64 changes: 64 additions & 0 deletions
64
DuDoong-Batch/src/main/java/band/gosrock/helper/SettlementEmailHelper.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,64 @@ | ||
package band.gosrock.helper; | ||
|
||
|
||
import band.gosrock.common.annotation.Helper; | ||
import band.gosrock.domain.domains.event.domain.Event; | ||
import band.gosrock.infrastructure.config.s3.S3PrivateFileService; | ||
import band.gosrock.infrastructure.config.ses.AwsSesUtils; | ||
import band.gosrock.infrastructure.config.ses.RawEmailAttachmentDto; | ||
import band.gosrock.infrastructure.config.ses.SendRawEmailDto; | ||
import javax.mail.MessagingException; | ||
import lombok.RequiredArgsConstructor; | ||
import org.thymeleaf.context.Context; | ||
import org.thymeleaf.spring5.SpringTemplateEngine; | ||
|
||
@Helper | ||
@RequiredArgsConstructor | ||
public class SettlementEmailHelper { | ||
private final SpringTemplateEngine templateEngine; | ||
|
||
private final S3PrivateFileService s3PrivateFileService; | ||
private final AwsSesUtils awsSesUtils; | ||
|
||
private RawEmailAttachmentDto getSettlementPdfAttachment(Event event) { | ||
return RawEmailAttachmentDto.builder() | ||
.fileName(event.getEventName() + "_정산서.pdf") | ||
.fileBytes(s3PrivateFileService.downloadEventSettlementPdf(event.getId())) | ||
.type("application/pdf") | ||
.build(); | ||
} | ||
|
||
private RawEmailAttachmentDto getOrderListExcelAttachment(Event event) { | ||
return RawEmailAttachmentDto.builder() | ||
.fileName(event.getEventName() + "_주문목록.xlsx") | ||
.fileBytes(s3PrivateFileService.downloadEventOrdersExcel(event.getId())) | ||
.type("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet") | ||
.build(); | ||
} | ||
|
||
public void sendToAdmin(Event event) throws MessagingException { | ||
SendRawEmailDto sendRawEmailDto = | ||
SendRawEmailDto.builder() | ||
.bodyHtml(templateEngine.process("eventSettlement", new Context())) | ||
.recipient("[email protected]") | ||
.subject(event.getEventName() + "공연 정산서 어드민 발송 ( 관리자용 )") | ||
.build(); | ||
|
||
sendRawEmailDto.addEmailAttachments(getSettlementPdfAttachment(event)); | ||
sendRawEmailDto.addEmailAttachments(getOrderListExcelAttachment(event)); | ||
awsSesUtils.sendRawEmails(sendRawEmailDto); | ||
} | ||
|
||
public void sendToHost(Event event, String hostUserEmail) throws MessagingException { | ||
SendRawEmailDto sendRawEmailDto = | ||
SendRawEmailDto.builder() | ||
.bodyHtml(templateEngine.process("eventSettlement", new Context())) | ||
.recipient(hostUserEmail) | ||
.subject(event.getEventName() + "공연 정산관련 안내") | ||
.build(); | ||
|
||
sendRawEmailDto.addEmailAttachments(getSettlementPdfAttachment(event)); | ||
sendRawEmailDto.addEmailAttachments(getOrderListExcelAttachment(event)); | ||
awsSesUtils.sendRawEmails(sendRawEmailDto); | ||
} | ||
} |
69 changes: 69 additions & 0 deletions
69
DuDoong-Batch/src/main/java/band/gosrock/helper/SettlementPdfHelper.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,69 @@ | ||
package band.gosrock.helper; | ||
|
||
|
||
import band.gosrock.common.annotation.Helper; | ||
import band.gosrock.domain.common.vo.Money; | ||
import band.gosrock.domain.domains.event.domain.Event; | ||
import band.gosrock.domain.domains.settlement.domain.EventSettlement; | ||
import band.gosrock.domain.domains.user.domain.User; | ||
import band.gosrock.dto.SettlementPDFDto; | ||
import band.gosrock.infrastructure.config.pdf.PdfRender; | ||
import band.gosrock.infrastructure.config.s3.S3PrivateFileService; | ||
import com.fasterxml.jackson.databind.ObjectMapper; | ||
import com.lowagie.text.DocumentException; | ||
import java.io.ByteArrayOutputStream; | ||
import java.io.IOException; | ||
import java.time.LocalDateTime; | ||
import java.util.Map; | ||
import lombok.RequiredArgsConstructor; | ||
import org.thymeleaf.context.Context; | ||
import org.thymeleaf.spring5.SpringTemplateEngine; | ||
|
||
@Helper | ||
@RequiredArgsConstructor | ||
public class SettlementPdfHelper { | ||
private final PdfRender pdfRender; | ||
|
||
private final ObjectMapper objectMapper; | ||
|
||
private final SpringTemplateEngine templateEngine; | ||
|
||
private final S3PrivateFileService s3PrivateFileUploadService; | ||
|
||
public void uploadPdfToS3(Event event, EventSettlement eventSettlement, User masterUser) | ||
throws DocumentException, IOException { | ||
SettlementPDFDto settlementPDFDto = getSettlementPDFDto(event, masterUser, eventSettlement); | ||
// 정산 관련 타임리프 파일. | ||
String html = templateEngine.process("settlement", getPdfHtmlContext(settlementPDFDto)); | ||
ByteArrayOutputStream outputStream = pdfRender.generatePdfFromHtml(html); | ||
s3PrivateFileUploadService.eventSettlementPdfUpload(event.getId(), outputStream); | ||
} | ||
|
||
private Context getPdfHtmlContext(SettlementPDFDto settlementPDFDto) { | ||
Map result = objectMapper.convertValue(settlementPDFDto, Map.class); | ||
|
||
Context context = new Context(null, result); | ||
context.setVariable("settlementAt", settlementPDFDto.getSettlementAt()); | ||
context.setVariable("now", settlementPDFDto.getNow()); | ||
return context; | ||
} | ||
|
||
private SettlementPDFDto getSettlementPDFDto( | ||
Event event, User masterUser, EventSettlement eventSettlement) { | ||
return SettlementPDFDto.builder() | ||
.eventTitle(event.getEventBasic().getName()) | ||
.hostName(masterUser.getProfile().getName()) | ||
.settlementAt(event.getEndAt().plusDays(6L)) | ||
.dudoongTicketAmount(eventSettlement.getDudoongAmount().toString()) | ||
.pgTicketAmount(eventSettlement.getPaymentAmount().toString()) | ||
.totalAmount(eventSettlement.getTotalSalesAmount().toString()) | ||
// 초기 두둥 자체 수수료 없음. | ||
.dudoongFee(Money.ZERO.toString()) | ||
.pgFee(eventSettlement.getPgFee().toString()) | ||
.totalFee(eventSettlement.getPgFee().toString()) | ||
.totalFeeVat(eventSettlement.getPgFeeVat().toString()) | ||
.totalSettlement(eventSettlement.getTotalAmount().toString()) | ||
.now(LocalDateTime.now()) | ||
.build(); | ||
} | ||
} |
2 changes: 1 addition & 1 deletion
2
...ava/band/gosrock/excel/ExcelOrderDto.java → ...d/gosrock/helper/excel/ExcelOrderDto.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 |
---|---|---|
@@ -1,4 +1,4 @@ | ||
package band.gosrock.excel; | ||
package band.gosrock.helper.excel; | ||
|
||
|
||
import band.gosrock.domain.common.vo.Money; | ||
|
133 changes: 133 additions & 0 deletions
133
DuDoong-Batch/src/main/java/band/gosrock/helper/excel/ExcelOrderHelper.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,133 @@ | ||
package band.gosrock.helper.excel; | ||
|
||
|
||
import java.io.ByteArrayOutputStream; | ||
import java.io.IOException; | ||
import java.lang.reflect.Field; | ||
import java.time.LocalDateTime; | ||
import java.time.format.DateTimeFormatter; | ||
import java.util.Arrays; | ||
import java.util.List; | ||
import java.util.stream.IntStream; | ||
import org.apache.poi.ss.usermodel.Cell; | ||
import org.apache.poi.ss.usermodel.CellStyle; | ||
import org.apache.poi.ss.usermodel.FillPatternType; | ||
import org.apache.poi.ss.usermodel.IndexedColors; | ||
import org.apache.poi.ss.usermodel.Row; | ||
import org.apache.poi.ss.usermodel.Sheet; | ||
import org.apache.poi.ss.usermodel.Workbook; | ||
import org.apache.poi.xssf.usermodel.XSSFFont; | ||
import org.apache.poi.xssf.usermodel.XSSFWorkbook; | ||
import org.springframework.stereotype.Component; | ||
|
||
@Component | ||
public class ExcelOrderHelper { | ||
|
||
DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm"); | ||
|
||
public ByteArrayOutputStream execute(List<ExcelOrderDto> excelOrders) { | ||
try (Workbook workbook = new XSSFWorkbook()) { | ||
Field[] declaredFields = ExcelOrderDto.class.getDeclaredFields(); | ||
|
||
List<String> fieldNames = Arrays.stream(declaredFields).map(Field::getName).toList(); | ||
Sheet sheet = workbook.createSheet("orderList"); | ||
sheet.setColumnWidth(0, 6000); | ||
sheet.setColumnWidth(1, 6000); | ||
sheet.setColumnWidth(2, 6000); | ||
sheet.setColumnWidth(3, 6000); | ||
sheet.setColumnWidth(4, 6000); | ||
sheet.setColumnWidth(5, 6000); | ||
sheet.setColumnWidth(6, 6000); | ||
sheet.setColumnWidth(7, 6000); | ||
sheet.setColumnWidth(8, 6000); | ||
// create header | ||
Row header = sheet.createRow(0); | ||
CellStyle headerStyle = workbook.createCellStyle(); | ||
headerStyle.setFillForegroundColor(IndexedColors.LIGHT_GREEN.getIndex()); | ||
headerStyle.setFillPattern(FillPatternType.SOLID_FOREGROUND); | ||
XSSFFont font = ((XSSFWorkbook) workbook).createFont(); | ||
font.setFontName("Arial"); | ||
font.setFontHeightInPoints((short) 16); | ||
font.setBold(true); | ||
headerStyle.setFont(font); | ||
|
||
Cell headerCell0 = header.createCell(0); | ||
headerCell0.setCellValue("주문번호"); | ||
headerCell0.setCellStyle(headerStyle); | ||
|
||
Cell headerCell1 = header.createCell(1); | ||
headerCell1.setCellValue("주문 방식"); | ||
headerCell1.setCellStyle(headerStyle); | ||
|
||
Cell headerCell2 = header.createCell(2); | ||
headerCell2.setCellValue("주문 상태"); | ||
headerCell2.setCellStyle(headerStyle); | ||
|
||
Cell headerCell3 = header.createCell(3); | ||
headerCell3.setCellValue("주문 이름"); | ||
headerCell3.setCellStyle(headerStyle); | ||
|
||
Cell headerCell4 = header.createCell(4); | ||
headerCell4.setCellValue("주문자 아이디"); | ||
headerCell4.setCellStyle(headerStyle); | ||
|
||
Cell headerCell5 = header.createCell(5); | ||
headerCell5.setCellValue("총액"); | ||
headerCell5.setCellStyle(headerStyle); | ||
|
||
Cell headerCell6 = header.createCell(6); | ||
headerCell6.setCellValue("티켓 수량"); | ||
headerCell6.setCellStyle(headerStyle); | ||
|
||
Cell headerCell7 = header.createCell(7); | ||
headerCell7.setCellValue("생성 일시"); | ||
headerCell7.setCellStyle(headerStyle); | ||
|
||
Cell headerCell8 = header.createCell(8); | ||
headerCell8.setCellValue("환불 일시"); | ||
headerCell8.setCellStyle(headerStyle); | ||
|
||
CellStyle style = workbook.createCellStyle(); | ||
style.setWrapText(true); | ||
IntStream.range(0, excelOrders.size()) | ||
.forEach( | ||
idx -> { | ||
Row row = sheet.createRow(idx + 1); | ||
ExcelOrderDto excelOrderDto = excelOrders.get(idx); | ||
row.createCell(0).setCellValue(excelOrderDto.getOrderNo()); | ||
|
||
row.createCell(1) | ||
.setCellValue(excelOrderDto.getOrderMethod().getKr()); | ||
|
||
row.createCell(2) | ||
.setCellValue(excelOrderDto.getOrderStatus().getKr()); | ||
|
||
row.createCell(3).setCellValue(excelOrderDto.getOrderName()); | ||
|
||
row.createCell(4).setCellValue(excelOrderDto.getUserId()); | ||
|
||
row.createCell(5) | ||
.setCellValue(excelOrderDto.getAmount().toString()); | ||
|
||
row.createCell(6).setCellValue(excelOrderDto.getQuantity()); | ||
|
||
row.createCell(7) | ||
.setCellValue( | ||
excelOrderDto.getCreatedAt().format(formatter)); | ||
|
||
LocalDateTime refundAt = excelOrderDto.getRefundAt(); | ||
row.createCell(8) | ||
.setCellValue( | ||
refundAt != null | ||
? refundAt.format(formatter) | ||
: null); | ||
}); | ||
ByteArrayOutputStream outputStream = new ByteArrayOutputStream(); | ||
workbook.write(outputStream); | ||
workbook.close(); | ||
return outputStream; | ||
} catch (IOException e) { | ||
throw new RuntimeException(e); | ||
} | ||
} | ||
} |
Oops, something went wrong.