Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
C
clx-performance
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
图表
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
姜武杰
clx-performance
Commits
d8d2ff21
提交
d8d2ff21
authored
12月 20, 2023
作者:
liuhaiquan
浏览文件
操作
浏览文件
下载
差异文件
Merge remote-tracking branch 'origin/v7.6_small_version_fix_20231204' into test
# Conflicts: # performance-web/src/main/java/com/clx/performance/service/impl/settle/SettlementMqHandlerServiceImpl.java
上级
8de28d44
c6e1262d
显示空白字符变更
内嵌
并排
正在显示
7 个修改的文件
包含
64 行增加
和
5 行删除
+64
-5
CarrierPageSettlementDriverVO.java
...e/vo/pc/carrier/settle/CarrierPageSettlementDriverVO.java
+3
-0
RedissonConstants.java
.../java/com/clx/performance/constant/RedissonConstants.java
+7
-0
OrderGoodsServiceImpl.java
...m/clx/performance/service/impl/OrderGoodsServiceImpl.java
+5
-1
BreakContractJobHandlerServiceImpl.java
...mpl/breakcontract/BreakContractJobHandlerServiceImpl.java
+24
-2
BreakContractSettlementDriverServiceImpl.java
...eakcontract/BreakContractSettlementDriverServiceImpl.java
+0
-1
SettlementDriverServiceImpl.java
...ance/service/impl/settle/SettlementDriverServiceImpl.java
+0
-1
SettlementMqHandlerServiceImpl.java
...e/service/impl/settle/SettlementMqHandlerServiceImpl.java
+25
-0
没有找到文件。
performance-api/src/main/java/com/clx/performance/vo/pc/carrier/settle/CarrierPageSettlementDriverVO.java
浏览文件 @
d8d2ff21
...
@@ -69,6 +69,9 @@ public class CarrierPageSettlementDriverVO {
...
@@ -69,6 +69,9 @@ public class CarrierPageSettlementDriverVO {
private
String
createTime
;
private
String
createTime
;
@ApiModelProperty
(
value
=
"结算平台 1:马上来 2:网运平台"
)
@ApiModelProperty
(
value
=
"结算平台 1:马上来 2:网运平台"
)
private
String
settlementPlatform
;
private
String
settlementPlatform
;
@ApiModelProperty
(
value
=
"支付失败原因"
)
private
String
payErrorMsg
;
...
...
performance-web/src/main/java/com/clx/performance/constant/RedissonConstants.java
浏览文件 @
d8d2ff21
...
@@ -5,5 +5,12 @@ public class RedissonConstants {
...
@@ -5,5 +5,12 @@ public class RedissonConstants {
// 接单锁
// 接单锁
public
static
final
String
ORDER_CHILD_SAVE_USER_TRUCK_LOCK
=
"clx-performance:orderChild:save:userTruck:"
;
public
static
final
String
ORDER_CHILD_SAVE_USER_TRUCK_LOCK
=
"clx-performance:orderChild:save:userTruck:"
;
public
static
final
String
ORDER_CHILD_SAVE_ORDER_GOODS_NO_LOCK
=
"clx-performance:orderChild:save:orderGoodsNo:"
;
public
static
final
String
ORDER_CHILD_SAVE_ORDER_GOODS_NO_LOCK
=
"clx-performance:orderChild:save:orderGoodsNo:"
;
//货主结算单支付锁
public
static
final
String
SETTLEMENT_OWNER_BATCH_PAY_ID_LOCK
=
"clx-performance:settlementOwner:batchPay:id:"
;
//货主违约结算单支付锁
public
static
final
String
BREAK_CONTRACT_SETTLEMENT_OWNER_BATCH_PAY_ID_LOCK
=
"clx-performance:breakContractSettlementOwner:batchPay:id:"
;
}
}
performance-web/src/main/java/com/clx/performance/service/impl/OrderGoodsServiceImpl.java
浏览文件 @
d8d2ff21
...
@@ -309,10 +309,12 @@ public class OrderGoodsServiceImpl implements OrderGoodsService {
...
@@ -309,10 +309,12 @@ public class OrderGoodsServiceImpl implements OrderGoodsService {
if
(
orderGoodsParams
.
getExtractWeight
().
compareTo
(
oldOrderGoods
.
getAlreadyTransportWeight
())
<
0
)
{
if
(
orderGoodsParams
.
getExtractWeight
().
compareTo
(
oldOrderGoods
.
getAlreadyTransportWeight
())
<
0
)
{
throw
new
ServiceSystemException
(
PerformanceResultEnum
.
HTTP_ERROR
,
"当前货单提取吨数不能小于货单已拉运吨数"
);
throw
new
ServiceSystemException
(
PerformanceResultEnum
.
HTTP_ERROR
,
"当前货单提取吨数不能小于货单已拉运吨数"
);
}
}
//考虑到借吨、恢复吨数的货单,逻辑判断实际的提取吨数
//考虑到借吨、恢复吨数的货单,逻辑判断实际的提取吨数
BigDecimal
realExtractWeight
=
oldOrderGoods
.
getResidueTransportWeight
().
compareTo
(
BigDecimal
.
ZERO
)
==
0
?
BigDecimal
realExtractWeight
=
oldOrderGoods
.
getResidueTransportWeight
().
compareTo
(
BigDecimal
.
ZERO
)
==
0
?
oldOrderGoods
.
getAlreadyTransportWeight
():
oldOrderGoods
.
getAlreadyTransportWeight
().
add
(
oldOrderGoods
.
getResidueTransportWeight
());
oldOrderGoods
.
getAlreadyTransportWeight
():
oldOrderGoods
.
getAlreadyTransportWeight
().
add
(
oldOrderGoods
.
getResidueTransportWeight
());
oldOrderGoods
.
setExtractWeight
(
realExtractWeight
);
oldOrderGoods
.
setExtractWeight
(
realExtractWeight
);
//本次提取增加或者减少的吨数 = 本次提取的吨数 - 货单原实际提取吨数
BigDecimal
answer
=
orderGoodsParams
.
getExtractWeight
().
subtract
(
realExtractWeight
);
BigDecimal
answer
=
orderGoodsParams
.
getExtractWeight
().
subtract
(
realExtractWeight
);
int
flag
=
answer
.
compareTo
(
BigDecimal
.
ZERO
);
int
flag
=
answer
.
compareTo
(
BigDecimal
.
ZERO
);
//归还吨数
//归还吨数
...
@@ -364,6 +366,7 @@ public class OrderGoodsServiceImpl implements OrderGoodsService {
...
@@ -364,6 +366,7 @@ public class OrderGoodsServiceImpl implements OrderGoodsService {
log
.
info
(
"回填吨数:{}"
,
JSONUtil
.
parse
(
rollbackOrderWeightParam
));
log
.
info
(
"回填吨数:{}"
,
JSONUtil
.
parse
(
rollbackOrderWeightParam
));
orderFeign
.
rollbackOrderWeight
(
rollbackOrderWeightParam
);
orderFeign
.
rollbackOrderWeight
(
rollbackOrderWeightParam
);
}
else
{
}
else
{
//当编辑吨数等于0 的时候,不进行拦截
orderGoodsParams
.
setResidueTransportWeight
(
oldOrderGoods
.
getResidueTransportWeight
());
orderGoodsParams
.
setResidueTransportWeight
(
oldOrderGoods
.
getResidueTransportWeight
());
}
}
...
@@ -458,7 +461,8 @@ public class OrderGoodsServiceImpl implements OrderGoodsService {
...
@@ -458,7 +461,8 @@ public class OrderGoodsServiceImpl implements OrderGoodsService {
* 限制货单更新剩余吨数不能小于35吨
* 限制货单更新剩余吨数不能小于35吨
**/
**/
private
void
limitOrderGoodsResidueWeight
(
BigDecimal
residueTransportWeight
){
private
void
limitOrderGoodsResidueWeight
(
BigDecimal
residueTransportWeight
){
if
(
residueTransportWeight
.
compareTo
(
new
BigDecimal
(
"35"
))
<
0
){
if
(
residueTransportWeight
.
compareTo
(
BigDecimal
.
ZERO
)
!=
0
&&
residueTransportWeight
.
compareTo
(
new
BigDecimal
(
"35"
))
<
0
){
throw
new
ServiceSystemException
(
PerformanceResultEnum
.
DATA_NOT_FIND
,
"当前货单剩余吨数不足35吨,无法挂单"
);
throw
new
ServiceSystemException
(
PerformanceResultEnum
.
DATA_NOT_FIND
,
"当前货单剩余吨数不足35吨,无法挂单"
);
}
}
}
}
...
...
performance-web/src/main/java/com/clx/performance/service/impl/breakcontract/BreakContractJobHandlerServiceImpl.java
浏览文件 @
d8d2ff21
package
com
.
clx
.
performance
.
service
.
impl
.
breakcontract
;
package
com
.
clx
.
performance
.
service
.
impl
.
breakcontract
;
import
com.clx.performance.constant.RedissonConstants
;
import
com.clx.performance.dao.breakcontract.BreakContractSettlementDriverDao
;
import
com.clx.performance.dao.breakcontract.BreakContractSettlementDriverDao
;
import
com.clx.performance.enums.BreakContractSettlementDriverEnum
;
import
com.clx.performance.enums.BreakContractSettlementDriverEnum
;
import
com.clx.performance.enums.PerformanceResultEnum
;
import
com.clx.performance.enums.PerformanceResultEnum
;
...
@@ -8,11 +9,16 @@ import com.clx.performance.service.breakcontract.BreakContractJobHandlerService;
...
@@ -8,11 +9,16 @@ import com.clx.performance.service.breakcontract.BreakContractJobHandlerService;
import
com.clx.performance.service.payment.PayService
;
import
com.clx.performance.service.payment.PayService
;
import
com.msl.common.exception.ServiceSystemException
;
import
com.msl.common.exception.ServiceSystemException
;
import
lombok.extern.slf4j.Slf4j
;
import
lombok.extern.slf4j.Slf4j
;
import
org.apache.commons.lang3.StringUtils
;
import
org.apache.commons.lang3.exception.ExceptionUtils
;
import
org.redisson.api.RLock
;
import
org.redisson.api.RedissonClient
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.stereotype.Service
;
import
org.springframework.stereotype.Service
;
import
org.springframework.transaction.annotation.Transactional
;
import
org.springframework.transaction.annotation.Transactional
;
import
java.util.Objects
;
import
java.util.Objects
;
import
java.util.concurrent.TimeUnit
;
@Slf4j
@Slf4j
@Service
@Service
...
@@ -24,10 +30,19 @@ public class BreakContractJobHandlerServiceImpl implements BreakContractJobHandl
...
@@ -24,10 +30,19 @@ public class BreakContractJobHandlerServiceImpl implements BreakContractJobHandl
@Autowired
@Autowired
private
PayService
payService
;
private
PayService
payService
;
@Autowired
private
RedissonClient
redissonClient
;
@Transactional
(
rollbackFor
=
Exception
.
class
)
@Transactional
(
rollbackFor
=
Exception
.
class
)
@Override
@Override
public
String
pay
(
Integer
settlementId
){
public
String
pay
(
Integer
settlementId
){
RLock
lock
=
redissonClient
.
getLock
(
RedissonConstants
.
BREAK_CONTRACT_SETTLEMENT_OWNER_BATCH_PAY_ID_LOCK
+
settlementId
);
try
{
boolean
flag
=
lock
.
tryLock
(
15
,
30
,
TimeUnit
.
SECONDS
);
if
(!
flag
)
{
//说明有别的线程发起支付操作
return
"车主违约结算单支付,支付操作频繁,稍后重试"
;
}
String
msg
=
null
;
String
msg
=
null
;
BreakContractSettlementDriver
breakContractSettlementDriver
=
breakContractSettlementDriverDao
.
getEntityByKey
(
settlementId
).
orElseThrow
(
PerformanceResultEnum
.
DATA_NOT_FIND
);
BreakContractSettlementDriver
breakContractSettlementDriver
=
breakContractSettlementDriverDao
.
getEntityByKey
(
settlementId
).
orElseThrow
(
PerformanceResultEnum
.
DATA_NOT_FIND
);
...
@@ -43,7 +58,14 @@ public class BreakContractJobHandlerServiceImpl implements BreakContractJobHandl
...
@@ -43,7 +58,14 @@ public class BreakContractJobHandlerServiceImpl implements BreakContractJobHandl
msg
=
e
.
getMessage
();
msg
=
e
.
getMessage
();
}
}
return
msg
;
return
msg
;
}
catch
(
Exception
e
){
log
.
warn
(
"结算单批量支付上锁失败,结算单ID:{},异常原因:{}"
,
settlementId
,
ExceptionUtils
.
getStackTrace
(
e
));
throw
new
ServiceSystemException
(
PerformanceResultEnum
.
TRY_LOCK_ERROR
);
}
finally
{
if
(
lock
.
isLocked
()
&&
lock
.
isHeldByCurrentThread
())
{
lock
.
unlock
();
}
}
}
}
/**
/**
...
...
performance-web/src/main/java/com/clx/performance/service/impl/breakcontract/BreakContractSettlementDriverServiceImpl.java
浏览文件 @
d8d2ff21
...
@@ -134,7 +134,6 @@ public class BreakContractSettlementDriverServiceImpl implements BreakContractSe
...
@@ -134,7 +134,6 @@ public class BreakContractSettlementDriverServiceImpl implements BreakContractSe
String
msg
=
breakContractJobHandlerService
.
pay
(
item
.
getId
());
String
msg
=
breakContractJobHandlerService
.
pay
(
item
.
getId
());
if
(
StringUtils
.
isNotBlank
(
msg
)){
if
(
StringUtils
.
isNotBlank
(
msg
)){
log
.
warn
(
"违约结算单对应的的运单编号:{} 进行结算,结算失败,返回结果:{}"
,
item
.
getChildNo
(),
msg
);
log
.
warn
(
"违约结算单对应的的运单编号:{} 进行结算,结算失败,返回结果:{}"
,
item
.
getChildNo
(),
msg
);
throw
new
ServiceSystemException
(
PerformanceResultEnum
.
DATA_NOT_FIND
,
msg
);
}
}
});
});
...
...
performance-web/src/main/java/com/clx/performance/service/impl/settle/SettlementDriverServiceImpl.java
浏览文件 @
d8d2ff21
...
@@ -65,7 +65,6 @@ public class SettlementDriverServiceImpl implements SettlementDriverService {
...
@@ -65,7 +65,6 @@ public class SettlementDriverServiceImpl implements SettlementDriverService {
String
msg
=
settlementMqHandlerService
.
paySettlementDriver
(
item
);
String
msg
=
settlementMqHandlerService
.
paySettlementDriver
(
item
);
if
(
StringUtils
.
isNotBlank
(
msg
)){
if
(
StringUtils
.
isNotBlank
(
msg
)){
log
.
warn
(
"结算单对应的的运单编号:{} 进行结算,结算失败,返回结果:{}"
,
item
.
getChildNo
(),
msg
);
log
.
warn
(
"结算单对应的的运单编号:{} 进行结算,结算失败,返回结果:{}"
,
item
.
getChildNo
(),
msg
);
throw
new
ServiceSystemException
(
PerformanceResultEnum
.
DATA_NOT_FIND
,
msg
);
}
}
});
});
}
}
...
...
performance-web/src/main/java/com/clx/performance/service/impl/settle/SettlementMqHandlerServiceImpl.java
浏览文件 @
d8d2ff21
package
com
.
clx
.
performance
.
service
.
impl
.
settle
;
package
com
.
clx
.
performance
.
service
.
impl
.
settle
;
import
com.clx.performance.config.MslPaymentConfig
;
import
com.clx.performance.config.MslPaymentConfig
;
import
com.clx.performance.constant.RedissonConstants
;
import
com.clx.performance.dao.OrderChildDao
;
import
com.clx.performance.dao.OrderChildDao
;
import
com.clx.performance.dao.OrderGoodsDao
;
import
com.clx.performance.dao.OrderGoodsDao
;
import
com.clx.performance.dao.settle.SettlementDriverDao
;
import
com.clx.performance.dao.settle.SettlementDriverDao
;
...
@@ -38,8 +39,13 @@ import com.clx.performance.vo.mq.SettlementDetailInvoiceTypeSyncMqParam;
...
@@ -38,8 +39,13 @@ import com.clx.performance.vo.mq.SettlementDetailInvoiceTypeSyncMqParam;
import
com.clx.user.vo.feign.DriverInfoFeignVo
;
import
com.clx.user.vo.feign.DriverInfoFeignVo
;
import
com.clx.user.vo.feign.OwnerInfoFeignVO
;
import
com.clx.user.vo.feign.OwnerInfoFeignVO
;
import
com.msl.common.enums.ResultCodeEnum
;
import
com.msl.common.enums.ResultCodeEnum
;
import
com.msl.common.exception.ServiceSystemException
;
import
com.msl.common.result.Result
;
import
com.msl.common.result.Result
;
import
lombok.extern.slf4j.Slf4j
;
import
lombok.extern.slf4j.Slf4j
;
import
org.apache.commons.lang3.StringUtils
;
import
org.apache.commons.lang3.exception.ExceptionUtils
;
import
org.redisson.api.RLock
;
import
org.redisson.api.RedissonClient
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.stereotype.Service
;
import
org.springframework.stereotype.Service
;
import
org.springframework.transaction.annotation.Transactional
;
import
org.springframework.transaction.annotation.Transactional
;
...
@@ -48,6 +54,7 @@ import java.math.BigDecimal;
...
@@ -48,6 +54,7 @@ import java.math.BigDecimal;
import
java.time.LocalDateTime
;
import
java.time.LocalDateTime
;
import
java.util.List
;
import
java.util.List
;
import
java.util.Objects
;
import
java.util.Objects
;
import
java.util.concurrent.TimeUnit
;
@Slf4j
@Slf4j
@Service
@Service
...
@@ -96,6 +103,9 @@ public class SettlementMqHandlerServiceImpl implements SettlementMqHandlerServic
...
@@ -96,6 +103,9 @@ public class SettlementMqHandlerServiceImpl implements SettlementMqHandlerServic
@Autowired
@Autowired
private
OrderChildSyncTransportRecordService
childSyncTransportRecordService
;
private
OrderChildSyncTransportRecordService
childSyncTransportRecordService
;
@Autowired
RedissonClient
redissonClient
;
@Override
@Override
...
@@ -225,6 +235,13 @@ public class SettlementMqHandlerServiceImpl implements SettlementMqHandlerServic
...
@@ -225,6 +235,13 @@ public class SettlementMqHandlerServiceImpl implements SettlementMqHandlerServic
* 车主结算单自动支付
* 车主结算单自动支付
*/
*/
public
String
paySettlementDriver
(
SettlementDriverDetail
detail
){
public
String
paySettlementDriver
(
SettlementDriverDetail
detail
){
RLock
lock
=
redissonClient
.
getLock
(
RedissonConstants
.
SETTLEMENT_OWNER_BATCH_PAY_ID_LOCK
+
detail
.
getId
());
try
{
boolean
flag
=
lock
.
tryLock
(
15
,
30
,
TimeUnit
.
SECONDS
);
if
(!
flag
)
{
//说明有别的线程发起支付操作
return
"车主结算单支付,操作频繁,稍后重试"
;
}
DriverInfoFeignVo
driverInfoFeignVo
=
driverService
.
getDriverInfo
(
detail
.
getDriverUserNo
()).
orElseThrow
(
ResultCodeEnum
.
FAIL
);
DriverInfoFeignVo
driverInfoFeignVo
=
driverService
.
getDriverInfo
(
detail
.
getDriverUserNo
()).
orElseThrow
(
ResultCodeEnum
.
FAIL
);
PayParam
noCheckPwd
=
null
;
PayParam
noCheckPwd
=
null
;
if
(
detail
.
getSettlementFreight
().
compareTo
(
BigDecimal
.
ZERO
)
>
0
){
if
(
detail
.
getSettlementFreight
().
compareTo
(
BigDecimal
.
ZERO
)
>
0
){
...
@@ -260,6 +277,14 @@ public class SettlementMqHandlerServiceImpl implements SettlementMqHandlerServic
...
@@ -260,6 +277,14 @@ public class SettlementMqHandlerServiceImpl implements SettlementMqHandlerServic
settlementDriverNotify
(
detail
.
getChildNo
(),
0
,
result
.
getMsg
());
settlementDriverNotify
(
detail
.
getChildNo
(),
0
,
result
.
getMsg
());
}
}
return
msg
;
return
msg
;
}
catch
(
Exception
e
){
log
.
warn
(
"货主结算单批量支付上锁失败,异常原因:{}"
,
ExceptionUtils
.
getStackTrace
(
e
));
throw
new
ServiceSystemException
(
PerformanceResultEnum
.
TRY_LOCK_ERROR
);
}
finally
{
if
(
lock
.
isLocked
()
&&
lock
.
isHeldByCurrentThread
())
{
lock
.
unlock
();
}
}
}
}
/**
/**
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论