--- src/main/java/itn/let/kakao/kakaoComm/KakaoVO.java
+++ src/main/java/itn/let/kakao/kakaoComm/KakaoVO.java
... | ... | @@ -336,30 +336,33 @@ |
| 336 | 336 |
|
| 337 | 337 |
public String ftToString() {
|
| 338 | 338 |
StringBuilder sb = new StringBuilder("KakaoFTSendVO[");
|
| 339 |
- sb.append("\n senderKey=[").append(senderKey).append("]");
|
|
| 339 |
+ sb.append("\n sendKind=[").append(getSendKind()).append("]");
|
|
| 340 |
+ sb.append("\n , senderKey=[").append(senderKey).append("]");
|
|
| 340 | 341 |
sb.append("\n , imageFileName=[").append(imageFileName).append("]");
|
| 341 | 342 |
sb.append("\n , imageType=[").append(imageType).append("]");
|
| 342 |
- sb.append("\n , imgTitle=[").append(imgTitle).append("]");
|
|
| 343 |
- sb.append("\n , imgLink=[").append(imgLink).append("]");
|
|
| 343 |
+ sb.append("\n , atchFileId=[").append(atchFileId).append("]");
|
|
| 344 |
+// sb.append("\n , imgTitle=[").append(imgTitle).append("]");
|
|
| 345 |
+// sb.append("\n , imgLink=[").append(imgLink).append("]");
|
|
| 344 | 346 |
sb.append("\n , templateContent=[").append(templateContent).append("]");
|
| 345 | 347 |
sb.append("\n , templateImageUrl=[").append(templateImageUrl).append("]");
|
| 346 |
- sb.append("\n , smsTxtArea=[").append(getSubMsgTxt()).append("]");
|
|
| 347 |
- sb.append("\n , subMsgSendYn=[").append(subMsgSendYn).append("]");
|
|
| 348 |
- sb.append("\n , subMsgTxtReplYn=[").append(subMsgTxtReplYn).append("]");
|
|
| 349 |
- sb.append("\n , subMsgType=[").append(subMsgType).append("]");
|
|
| 348 |
+// sb.append("\n , imgLink=[").append(imgLink).append("]");
|
|
| 349 |
+// sb.append("\n , smsTxtArea=[").append(getSubMsgTxt()).append("]");
|
|
| 350 |
+// sb.append("\n , subMsgSendYn=[").append(subMsgSendYn).append("]");
|
|
| 351 |
+// sb.append("\n , subMsgTxtReplYn=[").append(subMsgTxtReplYn).append("]");
|
|
| 352 |
+// sb.append("\n , subMsgType=[").append(subMsgType).append("]");
|
|
| 350 | 353 |
sb.append("\n , subMsgTxt=[").append(subMsgTxt).append("]");
|
| 354 |
+ sb.append("\n , subMsgSendYn=[").append(subMsgSendYn).append("]");
|
|
| 351 | 355 |
sb.append("\n , reserveYn=[").append(getReserveYn()).append("]");
|
| 352 |
- sb.append("\n , menuTopTab=[").append(menuTopTab).append("]");
|
|
| 353 |
- sb.append("\n , bizJsonYn=[").append(bizJsonYn).append("]");
|
|
| 354 |
- sb.append("\n , senderKey=[").append(senderKey).append("]");
|
|
| 356 |
+// sb.append("\n , menuTopTab=[").append(menuTopTab).append("]");
|
|
| 357 |
+// sb.append("\n , bizJsonYn=[").append(bizJsonYn).append("]");
|
|
| 355 | 358 |
sb.append("\n , callFrom=[").append(getCallFrom()).append("]");
|
| 356 |
- sb.append("\n , kakaoFtPrice=[").append(getEachPrice()).append("]");
|
|
| 359 |
+// sb.append("\n , kakaoFtPrice=[").append(getEachPrice()).append("]");
|
|
| 357 | 360 |
sb.append("\n , reqDate=[").append(getReqDate()).append("]");
|
| 358 |
- sb.append("\n , spamStatus=[").append(getSpamStatus()).append("]");
|
|
| 359 |
- sb.append("\n , txtReplYn=[").append(getTxtReplYn()).append("]");
|
|
| 360 |
- sb.append("\n , atSmishingYn=[").append(getAtSmishingYn()).append("]");
|
|
| 361 |
- sb.append("\n , atDelayYn=[").append(getAtDelayYn()).append("]");
|
|
| 362 |
- sb.append("\n , filePath1=[").append(getFilePath1()).append("]");
|
|
| 361 |
+// sb.append("\n , spamStatus=[").append(getSpamStatus()).append("]");
|
|
| 362 |
+// sb.append("\n , txtReplYn=[").append(getTxtReplYn()).append("]");
|
|
| 363 |
+// sb.append("\n , atSmishingYn=[").append(getAtSmishingYn()).append("]");
|
|
| 364 |
+// sb.append("\n , atDelayYn=[").append(getAtDelayYn()).append("]");
|
|
| 365 |
+// sb.append("\n , filePath1=[").append(getFilePath1()).append("]");
|
|
| 363 | 366 |
// sb.append("\n , tmpBtnSelect=[").append(getTmpBtnSelect()).append("]");
|
| 364 | 367 |
StringBuilder btnListSb = new StringBuilder("[");
|
| 365 | 368 |
if (buttonVOList != null && !buttonVOList.isEmpty()) {
|
... | ... | @@ -389,4 +392,7 @@ |
| 389 | 392 |
return sb.toString(); |
| 390 | 393 |
} |
| 391 | 394 |
|
| 395 |
+ |
|
| 396 |
+ |
|
| 397 |
+ |
|
| 392 | 398 |
} |
--- src/main/java/itn/let/kakao/user/kakaoFt/service/impl/KakaoFriendsTalkServiceImpl.java
+++ src/main/java/itn/let/kakao/user/kakaoFt/service/impl/KakaoFriendsTalkServiceImpl.java
... | ... | @@ -11,6 +11,7 @@ |
| 11 | 11 |
import javax.annotation.Resource; |
| 12 | 12 |
import javax.servlet.http.HttpServletRequest; |
| 13 | 13 |
|
| 14 |
+import org.apache.commons.lang3.StringUtils; |
|
| 14 | 15 |
import org.springframework.beans.factory.annotation.Autowired; |
| 15 | 16 |
import org.springframework.http.HttpStatus; |
| 16 | 17 |
import org.springframework.stereotype.Service; |
... | ... | @@ -80,20 +81,32 @@ |
| 80 | 81 |
log.info(" + kakaoVO.toString() :: [{}]", kakaoVO.ftToString());
|
| 81 | 82 |
|
| 82 | 83 |
|
| 84 |
+// if(1==1) {
|
|
| 85 |
+// throw new RuntimeException("강제로 발생시킨 예외");
|
|
| 86 |
+// } |
|
| 83 | 87 |
|
| 84 | 88 |
// 측정할 메소드 호출 전 시간 기록 |
| 85 | 89 |
Instant start = Instant.now(); |
| 86 | 90 |
// KakaoSendAdvcVO |
| 87 |
- |
|
| 91 |
+ |
|
| 88 | 92 |
Map<String, Object> returnMap = new HashMap<>(); |
| 93 |
+ Map<String, Object> apiReturnMap = new HashMap<>(); |
|
| 94 |
+ |
|
| 95 |
+ String userId = ""; |
|
| 96 |
+ if("A".equals(kakaoVO.getSendKind()))
|
|
| 97 |
+ {
|
|
| 98 |
+ userId = kakaoVO.getMberId(); |
|
| 99 |
+ }else {
|
|
| 100 |
+ |
|
| 101 |
+ LoginVO loginVO = EgovUserDetailsHelper.isAuthenticated() |
|
| 102 |
+ ? (LoginVO) EgovUserDetailsHelper.getAuthenticatedUser() |
|
| 103 |
+ : null; |
|
| 104 |
+ userId = loginVO == null ? "" : EgovStringUtil.isNullToString(loginVO.getId()); |
|
| 105 |
+ |
|
| 106 |
+ if (userId.equals("")) {
|
|
| 107 |
+ return new StatusResponse(HttpStatus.BAD_REQUEST, "로그인 후 이용이 가능합니다."); |
|
| 108 |
+ } |
|
| 89 | 109 |
|
| 90 |
- LoginVO loginVO = EgovUserDetailsHelper.isAuthenticated() |
|
| 91 |
- ? (LoginVO) EgovUserDetailsHelper.getAuthenticatedUser() |
|
| 92 |
- : null; |
|
| 93 |
- String userId = loginVO == null ? "" : EgovStringUtil.isNullToString(loginVO.getId()); |
|
| 94 |
- |
|
| 95 |
- if (userId.equals("")) {
|
|
| 96 |
- return new StatusResponse(HttpStatus.BAD_REQUEST, "로그인 후 이용이 가능합니다."); |
|
| 97 | 110 |
} |
| 98 | 111 |
|
| 99 | 112 |
kakaoVO.setUserId(userId); |
... | ... | @@ -106,7 +119,7 @@ |
| 106 | 119 |
request.getSession().invalidate(); |
| 107 | 120 |
// UNAUTHORIZED : 인증되지 않은 사용자가 접근하려고 할 때 |
| 108 | 121 |
return new StatusResponse(HttpStatus.UNAUTHORIZED, |
| 109 |
- "현재 고객님께서는 문자온 서비스 이용이 정지된 상태로 친구톡을 발송하실 수 없습니다. 이용정지 해제를 원하시면 고객센터로 연락주시기 바랍니다."); |
|
| 122 |
+ "현재 고객님께서는 문자온 서비스 이용이 정지된 상태로 친구톡을 발송하실 수 없습니다. 이용정지 해제를 원하시면 고객센터로 연락주시기 바랍니다.", "STAT_1070"); |
|
| 110 | 123 |
} |
| 111 | 124 |
|
| 112 | 125 |
|
... | ... | @@ -116,7 +129,7 @@ |
| 116 | 129 |
if(kakaoSendUtil.isRestrictedFriendTalkTime(kakaoSendUtil.resolveBaseDate(kakaoVO))) {
|
| 117 | 130 |
// UNAUTHORIZED : 인증되지 않은 사용자가 접근하려고 할 때 |
| 118 | 131 |
return new StatusResponse(HttpStatus.BAD_REQUEST, |
| 119 |
- "친구톡은 20시 50분부터 익일 08시까지 발송이 제한됩니다."); |
|
| 132 |
+ "친구톡은 20시 50분부터 익일 08시까지 발송이 제한됩니다.","STAT_2080"); |
|
| 120 | 133 |
} |
| 121 | 134 |
|
| 122 | 135 |
|
... | ... | @@ -139,12 +152,11 @@ |
| 139 | 152 |
return statusResponse; |
| 140 | 153 |
} |
| 141 | 154 |
|
| 142 |
- |
|
| 143 |
- |
|
| 155 |
+ |
|
| 144 | 156 |
/** @전송금액 확인 --------------------------------------------------*/ |
| 145 | 157 |
if (!kakaoSendUtil.isCashSufficient(userId, kakaoSendAdvcListVO)) {
|
| 146 | 158 |
log.error("Insufficient balance for message sending.");
|
| 147 |
- return new StatusResponse(HttpStatus.BAD_REQUEST, "문자 발송에 필요한 보유 잔액이 부족 합니다."); |
|
| 159 |
+ return new StatusResponse(HttpStatus.BAD_REQUEST, "문자 발송에 필요한 보유 잔액이 부족 합니다.", "STAT_1060"); |
|
| 148 | 160 |
} |
| 149 | 161 |
|
| 150 | 162 |
|
... | ... | @@ -162,6 +174,8 @@ |
| 162 | 174 |
// 임시 |
| 163 | 175 |
List<String> nextMsgGroupIdA = new ArrayList<>(); |
| 164 | 176 |
// 대안: entrySet() 직접 사용 |
| 177 |
+ String apiMsgGroupId = ""; |
|
| 178 |
+ String apiMsgType = ""; |
|
| 165 | 179 |
for (Map.Entry<String, List<KakaoSendAdvcVO>> entry : priceGroupedMessages.entrySet()) {
|
| 166 | 180 |
// entry 사용 |
| 167 | 181 |
|
... | ... | @@ -169,7 +183,15 @@ |
| 169 | 183 |
|
| 170 | 184 |
String nextMsgGroupId = idgenMjonMsgGroupId.getNextStringId(); |
| 171 | 185 |
groupedMsgList.forEach(t -> t.setMsgGroupId(nextMsgGroupId)); |
| 186 |
+ |
|
| 187 |
+ // api 전달 값 |
|
| 188 |
+ apiMsgGroupId = StringUtils.isNotEmpty(apiMsgGroupId) |
|
| 189 |
+ ? apiMsgGroupId + "," + nextMsgGroupId |
|
| 190 |
+ : nextMsgGroupId; |
|
| 172 | 191 |
|
| 192 |
+ apiMsgType = StringUtils.isNotEmpty(apiMsgType) |
|
| 193 |
+ ? apiMsgType + "," + kakaoSendAdvcListVO.get(0).getMsgType() |
|
| 194 |
+ : kakaoSendAdvcListVO.get(0).getMsgType(); |
|
| 173 | 195 |
|
| 174 | 196 |
// 발송 데이터 삽입 |
| 175 | 197 |
int instCnt = kakaoSendUtil.insertKakaoData_advc(groupedMsgList); |
... | ... | @@ -224,6 +246,12 @@ |
| 224 | 246 |
|
| 225 | 247 |
} |
| 226 | 248 |
|
| 249 |
+ apiReturnMap.put("resultSts", instTotalCnt);
|
|
| 250 |
+ // 그룹 ID |
|
| 251 |
+ apiReturnMap.put("msgGroupId", apiMsgGroupId);
|
|
| 252 |
+ // 메세지 타입 |
|
| 253 |
+ apiReturnMap.put("msgType", apiMsgType);
|
|
| 254 |
+ |
|
| 227 | 255 |
returnMap.put("resultSts", instTotalCnt);
|
| 228 | 256 |
returnMap.put("reserYn", kakaoVO.getReserveYn());
|
| 229 | 257 |
returnMap.put("groupIds", nextMsgGroupIdA);
|
... | ... | @@ -254,6 +282,9 @@ |
| 254 | 282 |
|
| 255 | 283 |
statusResponse.setStatus(HttpStatus.OK); |
| 256 | 284 |
statusResponse.setObject(returnMap); |
| 285 |
+ apiReturnMap.put("result", HttpStatus.OK);
|
|
| 286 |
+ apiReturnMap.put("message", "전송이 완료되었습니다.");
|
|
| 287 |
+ statusResponse.setApiReturn(apiReturnMap); |
|
| 257 | 288 |
|
| 258 | 289 |
return statusResponse; |
| 259 | 290 |
} |
Add a comment
Delete comment
Once you delete this comment, you won't be able to recover it. Are you sure you want to delete this comment?