From 5a552eb31b3fc1b62ebc72dd4bd8d6aa5113c355 Mon Sep 17 00:00:00 2001 From: hylee Date: Fri, 19 May 2023 14:42:14 +0900 Subject: [PATCH] =?UTF-8?q?feat:=20=EB=AC=B8=EC=9E=90=EB=B0=9C=EC=86=A1=20?= =?UTF-8?q?SendRestResponse=20=EC=B6=94=EA=B0=80=20+=20=EC=83=81=ED=83=9C?= =?UTF-8?q?=EA=B0=92=20enum=20class=20=EC=B6=94=EA=B0=80?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../com/itn/mjonApi/cmn/msg/RestResponse.java | 5 +- .../itn/mjonApi/cmn/msg/SendRestResponse.java | 34 +++++++++++++ .../java/com/itn/mjonApi/cmn/msg/StatMsg.java | 40 ++++++++++++++++ .../mjon/api/send/service/SendService.java | 4 +- .../send/service/impl/SendServiceImpl.java | 48 +++++++------------ .../mjon/api/send/web/SendRestController.java | 7 +-- 6 files changed, 98 insertions(+), 40 deletions(-) create mode 100644 src/main/java/com/itn/mjonApi/cmn/msg/SendRestResponse.java create mode 100644 src/main/java/com/itn/mjonApi/cmn/msg/StatMsg.java diff --git a/src/main/java/com/itn/mjonApi/cmn/msg/RestResponse.java b/src/main/java/com/itn/mjonApi/cmn/msg/RestResponse.java index fb6fa22..2922340 100644 --- a/src/main/java/com/itn/mjonApi/cmn/msg/RestResponse.java +++ b/src/main/java/com/itn/mjonApi/cmn/msg/RestResponse.java @@ -1,7 +1,6 @@ package com.itn.mjonApi.cmn.msg; -import lombok.Getter; -import lombok.Setter; +import lombok.*; import org.springframework.http.HttpStatus; import java.time.LocalDateTime; @@ -9,7 +8,7 @@ import java.util.List; @Setter @Getter -public class RestResponse { +public class RestResponse{ //private HttpStatus status; private int resultCode; diff --git a/src/main/java/com/itn/mjonApi/cmn/msg/SendRestResponse.java b/src/main/java/com/itn/mjonApi/cmn/msg/SendRestResponse.java new file mode 100644 index 0000000..426bf05 --- /dev/null +++ b/src/main/java/com/itn/mjonApi/cmn/msg/SendRestResponse.java @@ -0,0 +1,34 @@ +package com.itn.mjonApi.cmn.msg; + +import lombok.*; + +import java.time.LocalDateTime; + +@Setter +@Getter +@NoArgsConstructor +@AllArgsConstructor +public class SendRestResponse { + + //private HttpStatus status; + private String resultCode; + + private String message; + + private LocalDateTime localDateTime; + + /* + * 200-OK : 정상접속 + * 401-Unauthorized : 인증실패 + * + * */ + + @Builder + public SendRestResponse(String resultStr) { + this.resultCode = StatMsg.valueOf(resultStr).getCode(); + this.message = StatMsg.valueOf(resultStr).getMsg(); + this.localDateTime = LocalDateTime.now(); + } + + +} diff --git a/src/main/java/com/itn/mjonApi/cmn/msg/StatMsg.java b/src/main/java/com/itn/mjonApi/cmn/msg/StatMsg.java new file mode 100644 index 0000000..4c0b27a --- /dev/null +++ b/src/main/java/com/itn/mjonApi/cmn/msg/StatMsg.java @@ -0,0 +1,40 @@ +package com.itn.mjonApi.cmn.msg; + +import lombok.Getter; + +/** + * packageName : com.itn.mjonApi.cmn.msg + * fileName : statMsg + * author : hylee + * date : 2023-05-19 + * description : + * =========================================================== + * DATE AUTHOR NOTE + * ----------------------------------------------------------- + * 2023-05-19 hylee 최초 생성 + */ + + +/** + * 사용 예시 + * + * StatMsg.valueOf("STAT1010") :: STAT1010 + * StatMsg.valueOf("STAT1010").getCode() :: 1010 + * StatMsg.valueOf("STAT1010").getMsg() :: 발신자 전화번호 사용 불가 + */ + +@Getter +public enum StatMsg { + STAT1010("1010","발신자 전화번호 사용 불가") + ,STAT1020("1020","수신자 전화번호 오류") + ; + + private final String code; + private final String msg; + + StatMsg(String code, String msg) { + this.code = code; + this.msg = msg; + } + +} diff --git a/src/main/java/com/itn/mjonApi/mjon/api/send/service/SendService.java b/src/main/java/com/itn/mjonApi/mjon/api/send/service/SendService.java index d9f7a28..f1e31ac 100644 --- a/src/main/java/com/itn/mjonApi/mjon/api/send/service/SendService.java +++ b/src/main/java/com/itn/mjonApi/mjon/api/send/service/SendService.java @@ -1,10 +1,10 @@ package com.itn.mjonApi.mjon.api.send.service; -import com.itn.mjonApi.mjon.api.send.mapper.domain.MjonResponseVO; +import com.itn.mjonApi.cmn.msg.SendRestResponse; import com.itn.mjonApi.mjon.api.send.mapper.domain.MsgRequestVO; public interface SendService { - MjonResponseVO sendMsgData(MsgRequestVO msgRequestVO) throws Exception; + SendRestResponse sendMsgData(MsgRequestVO msgRequestVO) throws Exception; } diff --git a/src/main/java/com/itn/mjonApi/mjon/api/send/service/impl/SendServiceImpl.java b/src/main/java/com/itn/mjonApi/mjon/api/send/service/impl/SendServiceImpl.java index c09ae05..539d521 100644 --- a/src/main/java/com/itn/mjonApi/mjon/api/send/service/impl/SendServiceImpl.java +++ b/src/main/java/com/itn/mjonApi/mjon/api/send/service/impl/SendServiceImpl.java @@ -1,8 +1,8 @@ package com.itn.mjonApi.mjon.api.send.service.impl; import com.itn.mjonApi.cmn.apiServer.ApiService; +import com.itn.mjonApi.cmn.msg.SendRestResponse; import com.itn.mjonApi.mjon.api.send.mapper.SendMapper; -import com.itn.mjonApi.mjon.api.send.mapper.domain.MjonResponseVO; import com.itn.mjonApi.mjon.api.send.mapper.domain.MsgRequestVO; import com.itn.mjonApi.mjon.api.send.service.SendService; import com.itn.mjonApi.util.MunjaUtil; @@ -33,34 +33,28 @@ public class SendServiceImpl implements SendService { private static final String replaseStrList = "[*이름*],[*1*],[*2*],[*3*],[*4*]"; @Override - public MjonResponseVO sendMsgData(MsgRequestVO msgRequestVO) throws Exception { - - log.info(" :: sendMsgData ::"); - - Boolean byCallFrom = sendMapper.findByCallFrom(msgRequestVO); - log.info(" :: byCallFrom ::" + byCallFrom); - if(byCallFrom){ - - } - /* - 발신번호 체크 - SELECT PHONE_NUMBER - FROM MJ_PHONE_MEMBER - WHERE 1=1 - AND USER_ID = 'goodgkdus' - AND AUTH_YN = 'Y' - AND PHM_TYPE = '01' - ORDER BY BASE_YN DESC - * */ + public SendRestResponse sendMsgData(MsgRequestVO msgRequestVO) throws Exception { //sendMsg 문자 발송 전 체크 사항 + log.info(" :: sendMsgData ::"); + //step1.발신자 전화번호 사용 가능 여부 체크(해당 사용자의 기 등록된 번호만 발송 가능) // 1010 - - + if(!sendMapper.findByCallFrom(msgRequestVO)){ + return SendRestResponse.builder() + .resultStr("STAT1010") + .build(); + } //step2.수신자 전화번호 정상 여부 체크(정상 번호에 대해서만 발송 가능) // 1020 + // 폰번호 확인 - 빈 값 -> 유효성 정규식 + if(StringUtils.isNotEmpty(this.getCallToListChk(msgRequestVO))){ + return SendRestResponse.builder() + .resultStr("STAT1010") + .build(); + } + //step3.문자 내용 정상 여부 확인 - 스미싱 문구는 발송 안됨 // 1030 @@ -82,16 +76,6 @@ public class SendServiceImpl implements SendService { /* - String message = ""; - // 폰번호 확인 - 빈 값 -> 유효성 정규식 - message = this.getCallToListChk(msgRequestVO); - if(StringUtils.isNotEmpty(message)){ - return MjonResponseVO.builder() - .result("fail") - .message(message) - .build(); - } - // 치환데이터 여부 확인 msgRequestVO.setTxtReplYn(this.getTxtReplYn(msgRequestVO)); diff --git a/src/main/java/com/itn/mjonApi/mjon/api/send/web/SendRestController.java b/src/main/java/com/itn/mjonApi/mjon/api/send/web/SendRestController.java index 34d4385..52c2f52 100644 --- a/src/main/java/com/itn/mjonApi/mjon/api/send/web/SendRestController.java +++ b/src/main/java/com/itn/mjonApi/mjon/api/send/web/SendRestController.java @@ -1,11 +1,12 @@ package com.itn.mjonApi.mjon.api.send.web; -import com.itn.mjonApi.mjon.api.send.mapper.domain.MjonResponseVO; +import com.itn.mjonApi.cmn.msg.SendRestResponse; import com.itn.mjonApi.mjon.api.send.mapper.domain.MsgRequestVO; import com.itn.mjonApi.mjon.api.send.service.SendService; import io.swagger.annotations.ApiOperation; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.http.ResponseEntity; import org.springframework.web.bind.annotation.CrossOrigin; import org.springframework.web.bind.annotation.PostMapping; import org.springframework.web.bind.annotation.RestController; @@ -48,9 +49,9 @@ public class SendRestController { @CrossOrigin("*") // 모든 요청에 접근 허용 @PostMapping("/api/send/sendMsg") @ApiOperation(value= "단문 문자 전송", notes = "같은 내용으로 여러명에게 보냄") - public MjonResponseVO sendTest(MsgRequestVO msgRequestVO) throws Exception { + public ResponseEntity sendMsg(MsgRequestVO msgRequestVO) throws Exception { - return sendService.sendMsgData(msgRequestVO); + return ResponseEntity.ok().body(sendService.sendMsgData(msgRequestVO)); }