feat(can-charge): 이롬넷(Payverse) 통합결제 추가
This commit is contained in:
@@ -11,8 +11,7 @@ import Combine
|
||||
import Bootpay
|
||||
|
||||
enum PaymentMethod: String {
|
||||
case card = "카드"
|
||||
case bank = "계좌이체"
|
||||
case unified = "통합 결제"
|
||||
case phone = "휴대폰"
|
||||
case kakaopay = "카카오페이"
|
||||
}
|
||||
@@ -28,9 +27,15 @@ final class CanPgPaymentViewModel: ObservableObject {
|
||||
@Published var isLoading = false
|
||||
|
||||
@Published var isShowPaymentView = false
|
||||
@Published var isShowPayversePaymentView = false
|
||||
@Published var paymentMethod: PaymentMethod? = nil
|
||||
|
||||
let payload = Payload()
|
||||
var payversePayloadJson: String = ""
|
||||
|
||||
var canResponse: GetCanResponse? = nil
|
||||
var refresh: (() -> Void)? = nil
|
||||
var afterCompletionToGoBack: Bool? = nil
|
||||
|
||||
func chargeCan(canId: Int, onSuccess: @escaping () -> Void) {
|
||||
isLoading = true
|
||||
@@ -137,4 +142,139 @@ final class CanPgPaymentViewModel: ObservableObject {
|
||||
isShowPopup = true
|
||||
}
|
||||
}
|
||||
|
||||
func payverseChargeCan(canId: Int) {
|
||||
isLoading = true
|
||||
repository.payverseChargeCan(canId: canId)
|
||||
.sink { result in
|
||||
switch result {
|
||||
case .finished:
|
||||
DEBUG_LOG("finish")
|
||||
case .failure(let error):
|
||||
ERROR_LOG(error.localizedDescription)
|
||||
}
|
||||
} receiveValue: { [unowned self] response in
|
||||
self.isLoading = false
|
||||
let responseData = response.data
|
||||
|
||||
do {
|
||||
let jsonDecoder = JSONDecoder()
|
||||
let decoded = try jsonDecoder.decode(ApiResponse<PayverseChargeResponse>.self, from: responseData)
|
||||
|
||||
if let data = decoded.data, decoded.success {
|
||||
if let payloadJson = data.payloadJson.data(using: .utf8) {
|
||||
var obj = try JSONSerialization.jsonObject(with: payloadJson, options: []) as? [String: Any] ?? [:]
|
||||
obj["returnUrl"] = "\(APPSCHEME)://payverse/result"
|
||||
obj["webhookUrl"] = "\(BASE_URL)/charge/payverse/webhook"
|
||||
obj["appScheme"] = APPSCHEME
|
||||
let merged = try JSONSerialization.data(withJSONObject: obj, options: [])
|
||||
self.payversePayloadJson = String(data: merged, encoding: .utf8)!
|
||||
self.isShowPayversePaymentView = true
|
||||
} else {
|
||||
self.errorMessage = "다시 시도해 주세요.\n계속 같은 문제가 발생할 경우 고객센터로 문의 주시기 바랍니다."
|
||||
self.isShowPopup = true
|
||||
return
|
||||
}
|
||||
} else {
|
||||
if let message = decoded.message {
|
||||
self.errorMessage = message
|
||||
} else {
|
||||
self.errorMessage = "다시 시도해 주세요.\n계속 같은 문제가 발생할 경우 고객센터로 문의 주시기 바랍니다."
|
||||
}
|
||||
|
||||
self.isShowPopup = true
|
||||
}
|
||||
} catch {
|
||||
self.errorMessage = "다시 시도해 주세요.\n계속 같은 문제가 발생할 경우 고객센터로 문의 주시기 바랍니다."
|
||||
self.isShowPopup = true
|
||||
}
|
||||
}
|
||||
.store(in: &subscription)
|
||||
}
|
||||
|
||||
func handleVerifyOpenURL(_ url: URL) {
|
||||
guard let comps = URLComponents(url: url, resolvingAgainstBaseURL: false) else {
|
||||
self.errorMessage = "다시 시도해 주세요.\n계속 같은 문제가 발생할 경우 고객센터로 문의 주시기 바랍니다."
|
||||
self.isShowPopup = true
|
||||
return
|
||||
}
|
||||
let q = comps.queryItems?.reduce(into: [String:String]()) { $0[$1.name] = $1.value } ?? [:]
|
||||
|
||||
let tid = q["tid"] ?? q["tx_id"]
|
||||
let orderId = q["orderId"]
|
||||
let resultStatus = q["resultStatus"]
|
||||
|
||||
if resultStatus == "FAILED" ||
|
||||
resultStatus == "DECLINE" ||
|
||||
orderId == nil || orderId?.trimmingCharacters(in: .whitespacesAndNewlines).isEmpty == true ||
|
||||
tid == nil || tid?.trimmingCharacters(in: .whitespacesAndNewlines).isEmpty == true {
|
||||
self.errorMessage = "다시 시도해 주세요.\n계속 같은 문제가 발생할 경우 고객센터로 문의 주시기 바랍니다."
|
||||
self.isShowPopup = true
|
||||
DispatchQueue.main.asyncAfter(deadline: .now() + 1) {
|
||||
AppState.shared.back()
|
||||
}
|
||||
return
|
||||
} else {
|
||||
payverseVerify(transactionId: tid!, orderId: orderId!)
|
||||
}
|
||||
}
|
||||
|
||||
func payverseVerify(transactionId: String, orderId: String) {
|
||||
isLoading = true
|
||||
repository.payverseVerify(transactionId: transactionId, orderId: orderId)
|
||||
.sink { result in
|
||||
switch result {
|
||||
case .finished:
|
||||
DEBUG_LOG("finish")
|
||||
case .failure(let error):
|
||||
ERROR_LOG(error.localizedDescription)
|
||||
}
|
||||
} receiveValue: { [unowned self] response in
|
||||
self.isLoading = false
|
||||
let responseData = response.data
|
||||
|
||||
do {
|
||||
let jsonDecoder = JSONDecoder()
|
||||
let decoded = try jsonDecoder.decode(ApiResponseWithoutData.self, from: responseData)
|
||||
|
||||
if decoded.success {
|
||||
if let canResponse = self.canResponse {
|
||||
let can = UserDefaults.int(forKey: .can)
|
||||
UserDefaults.set(can + canResponse.can + canResponse.rewardCan, forKey: .can)
|
||||
|
||||
if let refresh = refresh {
|
||||
refresh()
|
||||
}
|
||||
|
||||
DispatchQueue.main.asyncAfter(deadline: .now() + 1) {
|
||||
if let afterCompletionToGoBack = self.afterCompletionToGoBack, afterCompletionToGoBack {
|
||||
AppState.shared.back()
|
||||
AppState.shared.back()
|
||||
} else {
|
||||
if let refresh = self.refresh {
|
||||
AppState.shared.setAppStep(step: .canStatus(refresh: refresh))
|
||||
} else {
|
||||
AppState.shared.setAppStep(step: .canStatus(refresh: {}))
|
||||
}
|
||||
}
|
||||
}
|
||||
} else {
|
||||
AppState.shared.setAppStep(step: .canStatus(refresh: {}))
|
||||
}
|
||||
} else {
|
||||
if let message = decoded.message {
|
||||
self.errorMessage = message
|
||||
} else {
|
||||
self.errorMessage = "다시 시도해 주세요.\n계속 같은 문제가 발생할 경우 고객센터로 문의 주시기 바랍니다."
|
||||
}
|
||||
|
||||
self.isShowPopup = true
|
||||
}
|
||||
} catch {
|
||||
self.errorMessage = "다시 시도해 주세요.\n계속 같은 문제가 발생할 경우 고객센터로 문의 주시기 바랍니다."
|
||||
self.isShowPopup = true
|
||||
}
|
||||
}
|
||||
.store(in: &subscription)
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user