Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
F
fit-finance
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
fitness-server
fit-finance
Commits
6a25cea4
Commit
6a25cea4
authored
Apr 30, 2024
by
程裕兵
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
feat:refund
parent
171749c7
Show whitespace changes
Inline
Side-by-side
Showing
12 changed files
with
102 additions
and
30 deletions
+102
-30
api/pom.xml
+1
-1
api/src/main/java/com/jiejing/fitness/finance/api/merchant/StudioMerchantApi.java
+7
-0
api/src/main/java/com/jiejing/fitness/finance/api/merchant/StudioMerchantApiFallback.java
+7
-0
api/src/main/java/com/jiejing/fitness/finance/api/merchant/request/StudioMerchantRefundRequest.java
+43
-0
app/src/main/java/com/jiejing/fitness/finance/app/controller/merchant/StudioMerchantController.java
+12
-0
pom.xml
+1
-1
service/pom.xml
+1
-1
service/src/main/java/com/jiejing/fitness/finance/service/pay/PayService.java
+3
-3
service/src/main/java/com/jiejing/fitness/finance/service/pay/convert/PayConvert.java
+4
-5
service/src/main/java/com/jiejing/fitness/finance/service/pay/impl/PayServiceImpl.java
+10
-10
service/src/main/java/com/jiejing/fitness/finance/service/pay/params/StudioMerchantRefundParams.java
+7
-8
service/src/main/java/com/jiejing/fitness/finance/service/rpc/PayRpcService.java
+6
-1
No files found.
api/pom.xml
View file @
6a25cea4
...
...
@@ -14,7 +14,7 @@
<dependencies>
<dependency>
<groupId>
com.jiejing.paycenter
</groupId>
<artifactId>
api
</artifactId>
<artifactId>
paycenter-
api
</artifactId>
<version>
0.0.1-SNAPSHOT
</version>
</dependency>
...
...
api/src/main/java/com/jiejing/fitness/finance/api/merchant/StudioMerchantApi.java
View file @
6a25cea4
...
...
@@ -14,12 +14,14 @@ import com.jiejing.fitness.finance.api.merchant.request.GetStudioMerchantApplyRe
import
com.jiejing.fitness.finance.api.merchant.request.GetStudioMerchantRequest
;
import
com.jiejing.fitness.finance.api.merchant.request.PageStudioMerchantApplyRequest
;
import
com.jiejing.fitness.finance.api.merchant.request.StudioMerchantPayRequest
;
import
com.jiejing.fitness.finance.api.merchant.request.StudioMerchantRefundRequest
;
import
com.jiejing.fitness.finance.api.merchant.request.UnbindStudioMerchantRequest
;
import
com.jiejing.fitness.finance.api.merchant.vo.StudioMerchantApplyVO
;
import
com.jiejing.fitness.finance.api.merchant.vo.StudioMerchantAuthSubChannelVO
;
import
com.jiejing.fitness.finance.api.merchant.vo.StudioMerchantBindXcxAppIdVO
;
import
com.jiejing.fitness.finance.api.merchant.vo.StudioMerchantVO
;
import
com.jiejing.paycenter.common.model.vo.PayVO
;
import
com.jiejing.paycenter.common.model.vo.RefundVO
;
import
io.swagger.annotations.ApiOperation
;
import
java.util.List
;
import
org.springframework.cloud.openfeign.FeignClient
;
...
...
@@ -94,4 +96,8 @@ public interface StudioMerchantApi {
@PostMapping
(
value
=
"/private/studioMerchant/pay"
)
JsonResult
<
PayVO
>
pay
(
StudioMerchantPayRequest
request
);
@ApiOperation
(
value
=
"退款"
,
tags
=
{
TAG
})
@PostMapping
(
value
=
"/private/studioMerchant/refund"
)
JsonResult
<
RefundVO
>
refund
(
StudioMerchantRefundRequest
request
);
}
\ No newline at end of file
api/src/main/java/com/jiejing/fitness/finance/api/merchant/StudioMerchantApiFallback.java
View file @
6a25cea4
...
...
@@ -14,12 +14,14 @@ import com.jiejing.fitness.finance.api.merchant.request.GetStudioMerchantApplyRe
import
com.jiejing.fitness.finance.api.merchant.request.GetStudioMerchantRequest
;
import
com.jiejing.fitness.finance.api.merchant.request.PageStudioMerchantApplyRequest
;
import
com.jiejing.fitness.finance.api.merchant.request.StudioMerchantPayRequest
;
import
com.jiejing.fitness.finance.api.merchant.request.StudioMerchantRefundRequest
;
import
com.jiejing.fitness.finance.api.merchant.request.UnbindStudioMerchantRequest
;
import
com.jiejing.fitness.finance.api.merchant.vo.StudioMerchantApplyVO
;
import
com.jiejing.fitness.finance.api.merchant.vo.StudioMerchantAuthSubChannelVO
;
import
com.jiejing.fitness.finance.api.merchant.vo.StudioMerchantBindXcxAppIdVO
;
import
com.jiejing.fitness.finance.api.merchant.vo.StudioMerchantVO
;
import
com.jiejing.paycenter.common.model.vo.PayVO
;
import
com.jiejing.paycenter.common.model.vo.RefundVO
;
import
feign.hystrix.FallbackFactory
;
import
java.util.List
;
import
org.springframework.stereotype.Component
;
...
...
@@ -112,6 +114,11 @@ public class StudioMerchantApiFallback implements FallbackFactory<StudioMerchant
public
JsonResult
<
PayVO
>
pay
(
StudioMerchantPayRequest
request
)
{
return
JsonResult
.
rpcError
();
}
@Override
public
JsonResult
<
RefundVO
>
refund
(
StudioMerchantRefundRequest
request
)
{
return
JsonResult
.
rpcError
();
}
};
}
}
api/src/main/java/com/jiejing/fitness/finance/api/merchant/request/StudioMerchantRefundRequest.java
0 → 100644
View file @
6a25cea4
package
com
.
jiejing
.
fitness
.
finance
.
api
.
merchant
.
request
;
import
io.swagger.annotations.ApiModel
;
import
io.swagger.annotations.ApiModelProperty
;
import
java.math.BigDecimal
;
import
javax.validation.constraints.NotBlank
;
import
javax.validation.constraints.NotNull
;
import
lombok.AllArgsConstructor
;
import
lombok.Builder
;
import
lombok.Data
;
import
lombok.NoArgsConstructor
;
/**
* @author chengyubing
* @since 2024/2/27 10:54
*/
@Data
@Builder
@AllArgsConstructor
@NoArgsConstructor
@ApiModel
(
description
=
"场馆商户退款请求"
)
public
class
StudioMerchantRefundRequest
{
@ApiModelProperty
(
value
=
"场馆ID"
,
required
=
true
)
@NotNull
(
message
=
"场馆ID不能为空"
)
private
Long
studioId
;
@ApiModelProperty
(
name
=
"退款总金额(元)"
,
required
=
true
)
@NotNull
(
message
=
"退款总金额不能为空"
)
private
BigDecimal
transAmount
;
@ApiModelProperty
(
name
=
"退款请求对应的支付流水号"
,
required
=
true
)
@NotBlank
(
message
=
"退款请求对应的支付流水号不能为空"
)
private
String
payTransNo
;
@ApiModelProperty
(
name
=
"退款原因"
,
required
=
true
)
@NotBlank
(
message
=
"退款原因不能为空"
)
private
String
refundReason
;
@ApiModelProperty
(
name
=
"上层业务退款单号"
)
private
String
orderNo
;
}
app/src/main/java/com/jiejing/fitness/finance/app/controller/merchant/StudioMerchantController.java
View file @
6a25cea4
...
...
@@ -16,6 +16,7 @@ import com.jiejing.fitness.finance.api.merchant.request.GetStudioMerchantApplyRe
import
com.jiejing.fitness.finance.api.merchant.request.GetStudioMerchantRequest
;
import
com.jiejing.fitness.finance.api.merchant.request.PageStudioMerchantApplyRequest
;
import
com.jiejing.fitness.finance.api.merchant.request.StudioMerchantPayRequest
;
import
com.jiejing.fitness.finance.api.merchant.request.StudioMerchantRefundRequest
;
import
com.jiejing.fitness.finance.api.merchant.request.UnbindStudioMerchantRequest
;
import
com.jiejing.fitness.finance.api.merchant.vo.StudioMerchantApplyVO
;
import
com.jiejing.fitness.finance.api.merchant.vo.StudioMerchantAuthSubChannelVO
;
...
...
@@ -26,7 +27,9 @@ import com.jiejing.fitness.finance.service.merchant.params.ApplyStudioMerchantPa
import
com.jiejing.fitness.finance.service.merchant.params.PageStudioMerchantApplyParams
;
import
com.jiejing.fitness.finance.service.pay.PayService
;
import
com.jiejing.fitness.finance.service.pay.params.StudioMerchantPayParams
;
import
com.jiejing.fitness.finance.service.pay.params.StudioMerchantRefundParams
;
import
com.jiejing.paycenter.common.model.vo.PayVO
;
import
com.jiejing.paycenter.common.model.vo.RefundVO
;
import
io.swagger.annotations.ApiOperation
;
import
java.util.List
;
import
javax.annotation.Resource
;
...
...
@@ -170,4 +173,13 @@ public class StudioMerchantController implements StudioMerchantApi {
StudioMerchantPayParams
params
=
BeanUtil
.
map
(
request
,
StudioMerchantPayParams
.
class
);
return
JsonResult
.
success
(
payService
.
merchantPay
(
params
));
}
@ApiOperation
(
value
=
"退款"
,
tags
=
{
TAG
})
@PostMapping
(
value
=
"/private/studioMerchant/refund"
)
@Override
public
JsonResult
<
RefundVO
>
refund
(
@RequestBody
@Valid
StudioMerchantRefundRequest
request
)
{
StudioMerchantRefundParams
params
=
BeanUtil
.
map
(
request
,
StudioMerchantRefundParams
.
class
);
return
JsonResult
.
success
(
payService
.
merchantRefund
(
params
));
}
}
pom.xml
View file @
6a25cea4
...
...
@@ -68,7 +68,7 @@
</dependency>
<dependency>
<groupId>
com.jiejing.paycenter
</groupId>
<artifactId>
api
</artifactId>
<artifactId>
paycenter-
api
</artifactId>
<version>
${pay-center.version}
</version>
</dependency>
<dependency>
...
...
service/pom.xml
View file @
6a25cea4
...
...
@@ -21,7 +21,7 @@
</dependency>
<dependency>
<groupId>
com.jiejing.paycenter
</groupId>
<artifactId>
api
</artifactId>
<artifactId>
paycenter-
api
</artifactId>
</dependency>
<dependency>
<groupId>
com.jiejing.app
</groupId>
...
...
service/src/main/java/com/jiejing/fitness/finance/service/pay/PayService.java
View file @
6a25cea4
...
...
@@ -3,12 +3,12 @@ package com.jiejing.fitness.finance.service.pay;
import
com.jiejing.fitness.finance.service.pay.params.AppPayParams
;
import
com.jiejing.fitness.finance.service.pay.params.NativePayParams
;
import
com.jiejing.fitness.finance.service.pay.params.StudioMerchantPayParams
;
import
com.jiejing.fitness.finance.service.pay.params.
Brand
MerchantRefundParams
;
import
com.jiejing.fitness.finance.service.pay.params.
Studio
MerchantRefundParams
;
import
com.jiejing.paycenter.common.enums.common.PayChannelEnums
;
import
com.jiejing.paycenter.common.model.vo.PayVO
;
import
com.jiejing.paycenter.api.pay.vo.RefundVO
;
import
com.jiejing.paycenter.common.event.PayEvent
;
import
com.jiejing.paycenter.common.event.RefundEvent
;
import
com.jiejing.paycenter.common.model.vo.RefundVO
;
import
java.util.Date
;
/**
...
...
@@ -64,7 +64,7 @@ public interface PayService {
* @param params 参数
* @return 结果
*/
RefundVO
merchantRefund
(
Brand
MerchantRefundParams
params
);
RefundVO
merchantRefund
(
Studio
MerchantRefundParams
params
);
/**
* 退款回调
...
...
service/src/main/java/com/jiejing/fitness/finance/service/pay/convert/PayConvert.java
View file @
6a25cea4
...
...
@@ -11,23 +11,22 @@ import com.jiejing.common.utils.text.StringUtil;
import
com.jiejing.fitness.enums.finance.BrandCashierTransStateEnum
;
import
com.jiejing.fitness.enums.finance.BrandCashierTransTypeEnum
;
import
com.jiejing.fitness.finance.repository.entity.MerchantSettleRecord
;
import
com.jiejing.fitness.finance.repository.entity.PartyToMerchant
;
import
com.jiejing.fitness.finance.repository.entity.StudioCashierRecord
;
import
com.jiejing.fitness.finance.repository.entity.StudioCheckSettleRecord
;
import
com.jiejing.fitness.finance.repository.entity.StudioMerchantApply
;
import
com.jiejing.fitness.finance.repository.entity.StudioSettleRecord
;
import
com.jiejing.fitness.finance.service.enums.FinanceErrorEnums
;
import
com.jiejing.fitness.finance.service.pay.params.
Brand
MerchantRefundParams
;
import
com.jiejing.fitness.finance.service.pay.params.
Studio
MerchantRefundParams
;
import
com.jiejing.fitness.finance.service.pay.params.StudioMerchantPayParams
;
import
com.jiejing.fitness.finance.service.utils.FeeUtil
;
import
com.jiejing.fitness.finance.service.utils.MoneyUtil
;
import
com.jiejing.paycenter.common.model.vo.MerchantVO
;
import
com.jiejing.paycenter.common.model.vo.PayVO
;
import
com.jiejing.paycenter.common.model.vo.RefundVO
;
import
com.jiejing.paycenter.common.model.vo.SettleVO
;
import
com.jiejing.paycenter.common.model.vo.SubChannelVO
;
import
com.jiejing.paycenter.api.pay.request.PayRequest
;
import
com.jiejing.paycenter.api.pay.request.RefundPayRequest
;
import
com.jiejing.paycenter.api.pay.vo.RefundVO
;
import
com.jiejing.paycenter.common.enums.common.TransStateEnums
;
import
com.jiejing.paycenter.common.enums.merchant.SubChannelEnums
;
import
com.jiejing.paycenter.common.enums.merchant.SubChannelOpenTypeEnums
;
...
...
@@ -185,7 +184,7 @@ public class PayConvert {
return
convertTransState
(
PayStateEnums
.
getByCode
(
state
));
}
public
static
StudioCashierRecord
convertRefundInit
(
Brand
MerchantRefundParams
params
,
public
static
StudioCashierRecord
convertRefundInit
(
Studio
MerchantRefundParams
params
,
StudioCashierRecord
pay
,
BigDecimal
historyRefundActualAmount
)
{
StudioCashierRecord
record
=
BeanUtil
.
map
(
pay
,
StudioCashierRecord
.
class
);
record
.
setId
(
IdWorker
.
getId
());
...
...
@@ -207,7 +206,7 @@ public class PayConvert {
return
record
;
}
public
static
RefundPayRequest
convert
(
Brand
MerchantRefundParams
params
,
StudioCashierRecord
record
)
{
public
static
RefundPayRequest
convert
(
Studio
MerchantRefundParams
params
,
StudioCashierRecord
record
)
{
RefundPayRequest
request
=
BeanUtil
.
map
(
params
,
RefundPayRequest
.
class
);
request
.
setTransNo
(
record
.
getTransNo
());
return
request
;
...
...
service/src/main/java/com/jiejing/fitness/finance/service/pay/impl/PayServiceImpl.java
View file @
6a25cea4
...
...
@@ -4,7 +4,6 @@ import static java.util.stream.Collectors.toList;
import
com.alibaba.fastjson.JSON
;
import
com.alipay.api.AlipayApiException
;
import
com.alipay.api.AlipayClient
;
import
com.alipay.api.DefaultAlipayClient
;
import
com.alipay.api.request.AlipaySystemOauthTokenRequest
;
import
com.alipay.api.response.AlipaySystemOauthTokenResponse
;
...
...
@@ -21,7 +20,6 @@ import com.jiejing.fitness.finance.repository.entity.MerchantSettleRecord;
import
com.jiejing.fitness.finance.repository.entity.StudioCashierRecord
;
import
com.jiejing.fitness.finance.repository.entity.PartyToMerchant
;
import
com.jiejing.fitness.finance.repository.entity.StudioMerchantApply
;
import
com.jiejing.fitness.finance.repository.entity.StudioSettleRecord
;
import
com.jiejing.fitness.finance.repository.service.GlobalConfigRpService
;
import
com.jiejing.fitness.finance.repository.service.MerchantSettleRecordRpService
;
import
com.jiejing.fitness.finance.repository.service.StudioCashierRecordRpService
;
...
...
@@ -37,7 +35,7 @@ import com.jiejing.fitness.finance.service.pay.PayService;
import
com.jiejing.fitness.finance.service.pay.convert.PayConvert
;
import
com.jiejing.fitness.finance.service.pay.enums.PayFailMessageReplaceEnums
;
import
com.jiejing.fitness.finance.service.pay.params.AppPayParams
;
import
com.jiejing.fitness.finance.service.pay.params.
Brand
MerchantRefundParams
;
import
com.jiejing.fitness.finance.service.pay.params.
Studio
MerchantRefundParams
;
import
com.jiejing.fitness.finance.service.pay.params.NativePayParams
;
import
com.jiejing.fitness.finance.service.pay.params.StudioMerchantPayParams
;
import
com.jiejing.fitness.finance.service.rpc.MerchantRpcService
;
...
...
@@ -57,7 +55,7 @@ import com.jiejing.paycenter.common.model.vo.MerchantVO;
import
com.jiejing.paycenter.api.pay.request.PayRequest
;
import
com.jiejing.paycenter.api.pay.request.RefundPayRequest
;
import
com.jiejing.paycenter.common.model.vo.PayVO
;
import
com.jiejing.paycenter.
api.pay
.vo.RefundVO
;
import
com.jiejing.paycenter.
common.model
.vo.RefundVO
;
import
com.jiejing.paycenter.common.event.PayEvent
;
import
com.jiejing.paycenter.common.event.RefundEvent
;
import
com.jiejing.paycenter.common.model.vo.SettleVO
;
...
...
@@ -67,8 +65,6 @@ import com.jiejing.wechat.vo.weChat.BaseAuthInfoVO;
import
com.xiaomai.event.EventAgent
;
import
java.math.BigDecimal
;
import
java.time.temporal.ChronoUnit
;
import
java.util.ArrayList
;
import
java.util.Collections
;
import
java.util.Date
;
import
java.util.HashMap
;
import
java.util.List
;
...
...
@@ -257,8 +253,10 @@ public class PayServiceImpl implements PayService {
}
@Override
public
RefundVO
merchantRefund
(
BrandMerchantRefundParams
params
)
{
StudioCashierRecord
pay
=
studioCashierRecordRpService
.
getById
(
Long
.
parseLong
(
params
.
getPayTransNo
()))
public
RefundVO
merchantRefund
(
StudioMerchantRefundParams
params
)
{
StudioCashierRecord
refund
=
transactionTemplate
.
execute
(
action
->
{
Long
payId
=
Long
.
parseLong
(
params
.
getPayTransNo
());
StudioCashierRecord
pay
=
studioCashierRecordRpService
.
getById
(
payId
)
.
orElseThrow
(()
->
new
BizException
(
FinanceErrorEnums
.
NOT_EXIST
));
BigDecimal
historyRefundActualAmount
=
studioCashierRecordRpService
.
sumRefundActualAmountByPayTransNo
(
...
...
@@ -266,11 +264,13 @@ public class PayServiceImpl implements PayService {
StudioCashierRecord
record
=
PayConvert
.
convertRefundInit
(
params
,
pay
,
historyRefundActualAmount
);
studioCashierRecordRpService
.
insert
(
record
);
return
record
;
});
RefundPayRequest
request
=
PayConvert
.
convert
(
params
,
re
cor
d
);
RefundPayRequest
request
=
PayConvert
.
convert
(
params
,
re
fun
d
);
RefundVO
vo
=
payRpcService
.
refund
(
request
);
StudioCashierRecord
toModify
=
PayConvert
.
convertRefund
(
re
cor
d
,
vo
);
StudioCashierRecord
toModify
=
PayConvert
.
convertRefund
(
re
fun
d
,
vo
);
studioCashierRecordRpService
.
updateById
(
toModify
);
return
vo
;
}
...
...
service/src/main/java/com/jiejing/fitness/finance/service/pay/params/
Brand
MerchantRefundParams.java
→
service/src/main/java/com/jiejing/fitness/finance/service/pay/params/
Studio
MerchantRefundParams.java
View file @
6a25cea4
...
...
@@ -18,21 +18,17 @@ import lombok.NoArgsConstructor;
@Builder
@AllArgsConstructor
@NoArgsConstructor
@ApiModel
(
description
=
"
品牌
商户退款Params"
)
public
class
Brand
MerchantRefundParams
{
@ApiModel
(
description
=
"
场馆
商户退款Params"
)
public
class
Studio
MerchantRefundParams
{
@ApiModelProperty
(
value
=
"场馆ID"
,
required
=
true
)
@NotNull
(
message
=
"场馆ID不能为空"
)
private
Long
studioId
;
@ApiModelProperty
(
name
=
"
支付
总金额(元)"
,
required
=
true
)
@NotNull
(
message
=
"
支付
总金额不能为空"
)
@ApiModelProperty
(
name
=
"
退款
总金额(元)"
,
required
=
true
)
@NotNull
(
message
=
"
退款
总金额不能为空"
)
private
BigDecimal
transAmount
;
@ApiModelProperty
(
name
=
"上层业务退款单号"
,
required
=
true
)
@NotBlank
(
message
=
"上层业务退款单号不能为空"
)
private
String
orderNo
;
@ApiModelProperty
(
name
=
"退款请求对应的支付流水号"
,
required
=
true
)
@NotBlank
(
message
=
"退款请求对应的支付流水号不能为空"
)
private
String
payTransNo
;
...
...
@@ -41,4 +37,7 @@ public class BrandMerchantRefundParams {
@NotBlank
(
message
=
"退款原因不能为空"
)
private
String
refundReason
;
@ApiModelProperty
(
name
=
"上层业务退款单号"
)
private
String
orderNo
;
}
service/src/main/java/com/jiejing/fitness/finance/service/rpc/PayRpcService.java
View file @
6a25cea4
package
com
.
jiejing
.
fitness
.
finance
.
service
.
rpc
;
import
com.alibaba.fastjson.JSON
;
import
com.jiejing.common.model.JsonResult
;
import
com.jiejing.paycenter.api.pay.PayApi
;
import
com.jiejing.paycenter.api.pay.request.PayRequest
;
import
com.jiejing.paycenter.api.pay.request.RefundPayRequest
;
import
com.jiejing.paycenter.api.pay.request.SyncSettleRequest
;
import
com.jiejing.paycenter.common.model.vo.PayVO
;
import
com.jiejing.paycenter.api.pay.vo.RefundVO
;
import
com.jiejing.paycenter.common.enums.common.TransStateEnums
;
import
com.jiejing.paycenter.common.enums.pay.PayStateEnums
;
import
com.jiejing.paycenter.common.model.vo.RefundVO
;
import
com.jiejing.paycenter.common.model.vo.SettleVO
;
import
java.math.BigDecimal
;
import
java.util.Date
;
import
java.util.Optional
;
import
javax.annotation.Resource
;
import
lombok.extern.slf4j.Slf4j
;
import
org.springframework.stereotype.Service
;
/**
* @author chengyubing
* @since 2024/2/27 11:12
*/
@Slf4j
@Service
public
class
PayRpcService
{
...
...
@@ -32,6 +35,7 @@ public class PayRpcService {
result
.
assertSuccess
();
return
result
.
getResult
();
}
catch
(
Exception
e
)
{
log
.
error
(
"pay occur error {}"
,
JSON
.
toJSONString
(
request
),
e
);
return
PayVO
.
builder
().
payState
(
PayStateEnums
.
FAILED
.
name
()).
failMsg
(
e
.
getMessage
()).
build
();
}
}
...
...
@@ -42,6 +46,7 @@ public class PayRpcService {
result
.
assertSuccess
();
return
result
.
getResult
();
}
catch
(
Exception
e
)
{
log
.
error
(
"refund occur error {}"
,
JSON
.
toJSONString
(
request
),
e
);
return
RefundVO
.
builder
().
refundState
(
TransStateEnums
.
FAIL
.
name
()).
failMessage
(
e
.
getMessage
()).
build
();
}
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment