From c2a3da1d4071f2f1d6a5beb63b8442920767584e Mon Sep 17 00:00:00 2001 From: Jack <jack.su@pollex.com.tw> Date: 星期二, 18 一月 2022 20:33:52 +0800 Subject: [PATCH] [ADD] 結案明細編輯API --- pamapi/src/main/java/com/pollex/pam/service/SendMsgService.java | 118 +++++++++++++++++++++++++++++++++++++++++++++++++---------- 1 files changed, 98 insertions(+), 20 deletions(-) diff --git a/pamapi/src/main/java/com/pollex/pam/service/SendMsgService.java b/pamapi/src/main/java/com/pollex/pam/service/SendMsgService.java index 5280732..05d8d73 100644 --- a/pamapi/src/main/java/com/pollex/pam/service/SendMsgService.java +++ b/pamapi/src/main/java/com/pollex/pam/service/SendMsgService.java @@ -1,48 +1,58 @@ package com.pollex.pam.service; -import com.fasterxml.jackson.core.JsonProcessingException; +import com.fasterxml.jackson.databind.ObjectMapper; import com.pollex.pam.config.ApplicationProperties; -import com.pollex.pam.service.dto.SMSDetail; -import com.pollex.pam.service.dto.SendSMSRequest; -import com.pollex.pam.service.dto.SendSMSResponse; +import com.pollex.pam.config.ApplicationProperties.SMS; +import com.pollex.pam.repository.ConsultantRepository; +import com.pollex.pam.service.dto.*; import com.pollex.pam.service.util.HttpRequestUtil; +import com.pollex.pam.web.rest.errors.SendEmailFailException; +import com.pollex.pam.web.rest.errors.SendSMSFailException; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.beans.factory.annotation.Autowired; -import org.springframework.http.HttpStatus; import org.springframework.http.ResponseEntity; import org.springframework.stereotype.Service; +import org.thymeleaf.spring5.SpringTemplateEngine; import java.nio.charset.StandardCharsets; -import java.security.KeyManagementException; -import java.security.KeyStoreException; -import java.security.NoSuchAlgorithmException; import java.time.LocalDateTime; import java.time.format.DateTimeFormatter; -import java.util.Base64; +import java.util.*; import java.util.Base64.Encoder; -import java.util.Collections; -import java.util.UUID; @Service public class SendMsgService { - private final static Logger log = LoggerFactory.getLogger(SendMsgService.class); + private static final Logger log = LoggerFactory.getLogger(SendMsgService.class); private final Encoder encoder = Base64.getEncoder(); + + private static final String SEND_SMS_SUCCESS_CODE = "1"; @Autowired ApplicationProperties applicationProperties; - public SendSMSResponse sendMsgBySMS(String subject, String toMobile, String content) throws Exception{ - final String SMS_URL = applicationProperties.getSms().getUrl(); + @Autowired + ConsultantRepository consultantRepository; + + @Autowired + SpringTemplateEngine springTemplateEngine; + + public SendSMSResponse sendMsgBySMS(String toMobile, String content) throws SendSMSFailException { + if(!applicationProperties.isSendNotifyMsg()) { +// return getMockSMSResponse(); + return null; + } + + SMS smsProperties = applicationProperties.getSms(); SendSMSRequest sendSMSRequest = new SendSMSRequest(); sendSMSRequest.setpKey(UUID.randomUUID().toString()); - sendSMSRequest.setSourceCode(applicationProperties.getSms().getSourceCode()); - sendSMSRequest.setSender(applicationProperties.getSms().getSender()); - sendSMSRequest.setMsgTypeSet(applicationProperties.getSms().getSmsType()); + sendSMSRequest.setSourceCode(smsProperties.getSourceCode()); + sendSMSRequest.setSender(smsProperties.getSender()); + sendSMSRequest.setMsgTypeSet(smsProperties.getSmsType()); sendSMSRequest.setSendTime(LocalDateTime.now().format(DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:00"))); - sendSMSRequest.setSubject(subject); + sendSMSRequest.setSubject(encoder.encodeToString(smsProperties.getSubject().getBytes(StandardCharsets.UTF_8))); sendSMSRequest.setActivityId(""); SMSDetail smsDetail = new SMSDetail(); @@ -51,9 +61,77 @@ sendSMSRequest.setDetail(Collections.singletonList(smsDetail)); - ResponseEntity<SendSMSResponse> responseEntity = HttpRequestUtil.postWithJson(SMS_URL, sendSMSRequest, SendSMSResponse.class); - return responseEntity.getBody(); + try { + ResponseEntity<SendSMSResponse> responseEntity = HttpRequestUtil.postWithJson(smsProperties.getUrl(), sendSMSRequest, SendSMSResponse.class); + SendSMSResponse response = responseEntity.getBody(); + + log.debug("response status code = {}", responseEntity.getStatusCode()); + log.debug("smsResponse = {}", responseEntity.getBody()); + + if(!SEND_SMS_SUCCESS_CODE.equals(response.getReturnCode())) { + throw new SendSMSFailException("sms service return code = " + response.getReturnCode() + ", error_msg = " + response.getErrorMsg()); + } + + return responseEntity.getBody(); + } catch (SendSMSFailException e) { + throw e; + } catch (Exception e) { + log.warn("send sms fail by other reason!", e); + throw new SendSMSFailException("send sms fail by other reason!"); + } } +// private SendSMSResponse getMockSMSResponse() { +// SendSMSResponse mock = new SendSMSResponse(); +// mock.set +// return null; +// } + public String sendMsgByEmail(String to, String subject, String content, boolean htmlFormat) throws SendEmailFailException{ + return sendMsgByEmail(to, subject, content, htmlFormat, Collections.emptyList(), Collections.emptyList()); + } + + public String sendMsgByEmail(String toAddress, String subject, String content, boolean htmlFormat, List<String> toCCAddress, + List<String> attachments) throws SendEmailFailException { + String fromAddress = applicationProperties.getEmail().getSenderEmail(); + + SendMailRequest sendMailRequest = new SendMailRequest(); + sendMailRequest.setSendMailAddresses(Collections.singletonList(toAddress)); + sendMailRequest.setFrom(fromAddress); + sendMailRequest.setContent(content); + sendMailRequest.setSubject(subject); + sendMailRequest.setSendCCMailAddresses(toCCAddress); + sendMailRequest.setAttachments(attachments); + sendMailRequest.setHtmlFormat(htmlFormat); + sendMailRequest.setFunctionId(applicationProperties.getEmail().getFunctionId()); + + return sendMsgByEmail(sendMailRequest); + } + + public String sendMsgByEmail(SendMailRequest sendMailRequest) throws SendEmailFailException{ + if(!applicationProperties.isSendNotifyMsg()) { + return null; + } + try { + ResponseEntity<String> responseEntity = + HttpRequestUtil.postWithJson( applicationProperties.getEmail().getUrl(), sendMailRequest, String.class); + log.debug("responseEntity = {}", responseEntity); + + String rawResponseString = responseEntity.getBody(); + SendMailResponse sendMailResponse = new ObjectMapper().readValue(rawResponseString, SendMailResponse.class); + log.debug("sendMailResponse = {}", sendMailResponse); + + if(sendMailResponse == null || sendMailResponse.getData() == null || !"ADDED".equalsIgnoreCase(sendMailResponse.getData().getMessageStatus())) { + throw new SendEmailFailException("send email service return error msg! raw response string= " + rawResponseString); + } + + return responseEntity.getBody(); + } + catch (SendEmailFailException e) { + throw e; + } catch (Exception e) { + log.warn("send email fail by other reason", e); + throw new SendEmailFailException("send email failed!"); + } + } } -- Gitblit v1.8.0