From 545dc266e0bc33d6b3053a7820bea74f1b9e02d1 Mon Sep 17 00:00:00 2001 From: 18650502300 <18650502300@163.com> Date: Tue, 9 Jul 2024 14:18:54 +0800 Subject: [PATCH] =?UTF-8?q?1.=E8=B0=83=E6=95=B4?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../controller/app/AppVerifyController.java | 33 ++++-- .../iot/receive/ReceiveController.java | 3 +- .../controller/system/AsDeviceController.java | 18 +++- .../controller/system/SysDeptController.java | 13 +++ .../ruoyi/common/constant/IotConstants.java | 5 + .../common/constant/ServiceConstants.java | 12 ++- .../common/core/domain/entity/SysDept.java | 11 ++ .../com/ruoyi/common/enums/BusinessType.java | 4 + .../com/ruoyi/system/domain/EtFeeRule.java | 4 + .../ruoyi/system/domain/vo/RechargeVo.java | 3 + .../ruoyi/system/mapper/EtFeeRuleMapper.java | 8 ++ .../system/service/IAsDeviceService.java | 12 ++- .../system/service/IEtFeeRuleService.java | 8 ++ .../ruoyi/system/service/IWxPayService.java | 1 - .../service/impl/AsDeviceServiceImpl.java | 45 +++++++- .../service/impl/CallbackServiceImpl.java | 16 +-- .../service/impl/EtFeeRuleServiceImpl.java | 12 +++ .../service/impl/EtOrderServiceImpl.java | 101 +++++++++++------- .../service/impl/EtWithdrawServiceImpl.java | 2 +- .../java/com/ruoyi/system/task/EtTask.java | 2 +- .../mapper/system/EtFeeRuleMapper.xml | 23 ++-- .../resources/mapper/system/EtOrderMapper.xml | 1 + .../resources/mapper/system/SysDeptMapper.xml | 8 +- 23 files changed, 271 insertions(+), 74 deletions(-) diff --git a/electripper-admin/src/main/java/com/ruoyi/web/controller/app/AppVerifyController.java b/electripper-admin/src/main/java/com/ruoyi/web/controller/app/AppVerifyController.java index 1772be6..8bcec7a 100644 --- a/electripper-admin/src/main/java/com/ruoyi/web/controller/app/AppVerifyController.java +++ b/electripper-admin/src/main/java/com/ruoyi/web/controller/app/AppVerifyController.java @@ -492,11 +492,12 @@ public class AppVerifyController extends BaseController */ @Log(title = "更新车牌号", businessType = BusinessType.UPDATE) @PutMapping("/device/edit") - public AjaxResult deviceEdit(String sn, String vehicleNum) + public AjaxResult deviceEdit(String sn, String vehicleNum, String status) { AsDevice asDevice = new AsDevice(); asDevice.setSn(sn); asDevice.setVehicleNum(vehicleNum); + asDevice.setStatus(status); return toAjax(asDeviceService.updateAsDeviceBySn(asDevice)); } @@ -579,7 +580,7 @@ public class AppVerifyController extends BaseController public AjaxResult offline(String sn) { logger.info("【车辆下线请求】:{}",sn); - Boolean aBoolean =asDeviceService.offline(sn); + Boolean aBoolean =asDeviceService.offline(sn,ServiceConstants.VEHICLE_STATUS_IN_OFFLINE); return success(aBoolean); } @@ -617,11 +618,11 @@ public class AppVerifyController extends BaseController } /** - * 批量禁用/解禁 - * disable-禁用 enable-解禁 + * 批量禁用/解禁、出仓/回仓 + * disable-禁用 enable-解禁 inStash-回仓 outStash-出仓 */ @Transactional - @Log(title = "批量禁用/解禁", businessType = BusinessType.DISABLE) + @Log(title = "批量修改操作", businessType = BusinessType.DISABLE) @PostMapping("/device/disable") public AjaxResult batchDisable(String sns, String disableType) { @@ -632,12 +633,16 @@ public class AppVerifyController extends BaseController String[] smList = sns.split(","); if(ServiceConstants.BATCH_OPERATION_TYPE_DISABLE.equals(disableType)){//禁用 for(String sn:smList){ - asDeviceService.offline(sn); + asDeviceService.offline(sn,ServiceConstants.VEHICLE_STATUS_IN_OFFLINE); } - }else if(ServiceConstants.BATCH_OPERATION_TYPE_ENABLE.equals(disableType)){ + }else if(ServiceConstants.BATCH_OPERATION_TYPE_ENABLE.equals(disableType) || ServiceConstants.BATCH_OPERATION_TYPE_OUTSTASH.equals(disableType)){ for(String sn:smList){ asDeviceService.online(sn); } + }else if(ServiceConstants.BATCH_OPERATION_TYPE_INSTASH.equals(disableType)) {//回仓 + for (String sn : smList) { + asDeviceService.offline(sn,ServiceConstants.VEHICLE_STATUS_NOT_LISTING); + } }else{ throw new ServiceException("操作类型错误"); } @@ -852,4 +857,18 @@ public class AppVerifyController extends BaseController logger.info("根据token获取运营区列表:【{}】", JSON.toJSON(longs)); return success(longs); } + + /** + * 重启设备 + */ + @PostMapping("/device/reboot") + public AjaxResult reboot(String sn) + { + if(StrUtil.isBlank(sn)){ + logger.info("没有sn号参数:【sn={}】",sn); + return error("请传sn号参数"+"【sn="+sn+"】"); + } + Boolean i =asDeviceService.reboot(sn); + return success(i); + } } diff --git a/electripper-admin/src/main/java/com/ruoyi/web/controller/iot/receive/ReceiveController.java b/electripper-admin/src/main/java/com/ruoyi/web/controller/iot/receive/ReceiveController.java index 7a44b23..ed72641 100644 --- a/electripper-admin/src/main/java/com/ruoyi/web/controller/iot/receive/ReceiveController.java +++ b/electripper-admin/src/main/java/com/ruoyi/web/controller/iot/receive/ReceiveController.java @@ -212,8 +212,9 @@ public class ReceiveController { **/ boolean noRidingArea = asDeviceService.isNoRidingArea(device.getSn(), device.getAreaId()); if(noRidingArea){ + String isAdminUnlocking = device.getIsAdminUnlocking();// 是否管理员开锁 String noRidingOutage = area.getNoRidingOutage(); - if (noRidingOutage.equals("1") && value.getStatus() != 3) { // 禁行区内断电 + if (noRidingOutage.equals("1") && value.getStatus() != 3 && !isAdminUnlocking.equals("1")) { // 禁行区内断电 log.info("禁行区内断电命令--SN:" + device.getSn()); asDeviceService.sendCommand(device.getMac(), Token.getToken(), IotConstants.COMMAND_QLOSE+IotConstants.COMMAND_FREQUENCY_5, "禁行区内断电"); device.setLockStatus(ServiceConstants.LOCK_STATUS_CLOSE); diff --git a/electripper-admin/src/main/java/com/ruoyi/web/controller/system/AsDeviceController.java b/electripper-admin/src/main/java/com/ruoyi/web/controller/system/AsDeviceController.java index eff0c33..1a18fea 100644 --- a/electripper-admin/src/main/java/com/ruoyi/web/controller/system/AsDeviceController.java +++ b/electripper-admin/src/main/java/com/ruoyi/web/controller/system/AsDeviceController.java @@ -2,6 +2,7 @@ package com.ruoyi.web.controller.system; import cn.hutool.core.util.StrUtil; import com.ruoyi.common.annotation.Log; +import com.ruoyi.common.constant.ServiceConstants; import com.ruoyi.common.core.controller.BaseController; import com.ruoyi.common.core.domain.AjaxResult; import com.ruoyi.common.core.page.TableDataInfo; @@ -146,6 +147,21 @@ public class AsDeviceController extends BaseController return success(i); } + /** + * 重启 reboot + */ + @PreAuthorize("@ss.hasPermi('system:device:reboot')") + @PostMapping("/device/reboot") + public AjaxResult reboot(String mac) + { + if(StrUtil.isBlank(mac)){ + logger.info("没有sn号参数:【mac={}】",mac); + return error("请传sn号参数"+"【mac="+mac+"】"); + } + Boolean i =asDeviceService.rebootByMac(mac); + return success(i); + } + /** * 管理员开锁 */ @@ -222,7 +238,7 @@ public class AsDeviceController extends BaseController public AjaxResult offline(String sn) { logger.info("【车辆下线请求】:{}",sn); - Boolean aBoolean =asDeviceService.offline(sn); + Boolean aBoolean =asDeviceService.offline(sn, ServiceConstants.VEHICLE_STATUS_IN_OFFLINE); return success(aBoolean); } diff --git a/electripper-admin/src/main/java/com/ruoyi/web/controller/system/SysDeptController.java b/electripper-admin/src/main/java/com/ruoyi/web/controller/system/SysDeptController.java index 35d2a97..465f7d9 100644 --- a/electripper-admin/src/main/java/com/ruoyi/web/controller/system/SysDeptController.java +++ b/electripper-admin/src/main/java/com/ruoyi/web/controller/system/SysDeptController.java @@ -180,4 +180,17 @@ public class SysDeptController extends BaseController return ajax; } + /** + * 查询运营商 + */ + @GetMapping("/getDept") + public AjaxResult getDept() + { + AjaxResult ajax = AjaxResult.success(); + Long deptId = getDeptId(); + SysDept sysDept = deptService.selectDeptById(deptId); + ajax.put(AjaxResult.DATA_TAG, sysDept); + return ajax; + } + } diff --git a/electripper-common/src/main/java/com/ruoyi/common/constant/IotConstants.java b/electripper-common/src/main/java/com/ruoyi/common/constant/IotConstants.java index 964240c..4855266 100644 --- a/electripper-common/src/main/java/com/ruoyi/common/constant/IotConstants.java +++ b/electripper-common/src/main/java/com/ruoyi/common/constant/IotConstants.java @@ -131,6 +131,11 @@ public class IotConstants { */ public static final String COMMAND_FREQUENCY_3600 = "sub300@"; + /** + * 命令 重启设备 + */ + public static final String COMMAND_REBOOT = "reboot"; + /**----------------------------命令end----------------------------*/ diff --git a/electripper-common/src/main/java/com/ruoyi/common/constant/ServiceConstants.java b/electripper-common/src/main/java/com/ruoyi/common/constant/ServiceConstants.java index 5f643fa..79ee632 100644 --- a/electripper-common/src/main/java/com/ruoyi/common/constant/ServiceConstants.java +++ b/electripper-common/src/main/java/com/ruoyi/common/constant/ServiceConstants.java @@ -312,7 +312,7 @@ public class ServiceConstants { /**----------------------------工单类型end----------------------------*/ /**----------------------------批量操作类型tart----------------------------*/ - /** 批量操作类型: disable-禁用 enable-解禁 */ + /** 批量操作类型: disable-禁用 enable-解禁 inStash-回仓 outStash-出仓*/ /** * 批量操作类型:disable-禁用 */ @@ -323,6 +323,16 @@ public class ServiceConstants { */ public static final String BATCH_OPERATION_TYPE_ENABLE = "enable"; + /** + * 批量操作类型:inStash-回仓 + */ + public static final String BATCH_OPERATION_TYPE_INSTASH = "inStash"; + + /** + * 批量操作类型:outStash-出仓 + */ + public static final String BATCH_OPERATION_TYPE_OUTSTASH = "outStash"; + /**----------------------------批量操作类型end----------------------------*/ diff --git a/electripper-common/src/main/java/com/ruoyi/common/core/domain/entity/SysDept.java b/electripper-common/src/main/java/com/ruoyi/common/core/domain/entity/SysDept.java index 260b31f..5e35a7c 100644 --- a/electripper-common/src/main/java/com/ruoyi/common/core/domain/entity/SysDept.java +++ b/electripper-common/src/main/java/com/ruoyi/common/core/domain/entity/SysDept.java @@ -61,6 +61,9 @@ public class SysDept extends BaseEntity /** 平台服务费 */ private String platformServiceFee; + /** 手续费 */ + private String handlingCharge; + /** 是否开启分账 */ private String isProfitSharing; @@ -100,6 +103,14 @@ public class SysDept extends BaseEntity /** 退款回调地址 */ private String refundNotifyUrl; + public String getHandlingCharge() { + return handlingCharge; + } + + public void setHandlingCharge(String handlingCharge) { + this.handlingCharge = handlingCharge; + } + public BigDecimal getBalance() { return balance; } diff --git a/electripper-common/src/main/java/com/ruoyi/common/enums/BusinessType.java b/electripper-common/src/main/java/com/ruoyi/common/enums/BusinessType.java index 26a44ed..f989c51 100644 --- a/electripper-common/src/main/java/com/ruoyi/common/enums/BusinessType.java +++ b/electripper-common/src/main/java/com/ruoyi/common/enums/BusinessType.java @@ -123,4 +123,8 @@ public enum BusinessType * 维修处理 */ REPAIR, + /** + * 出仓 + */ + STASH, } diff --git a/electripper-system/src/main/java/com/ruoyi/system/domain/EtFeeRule.java b/electripper-system/src/main/java/com/ruoyi/system/domain/EtFeeRule.java index 28342ad..1172865 100644 --- a/electripper-system/src/main/java/com/ruoyi/system/domain/EtFeeRule.java +++ b/electripper-system/src/main/java/com/ruoyi/system/domain/EtFeeRule.java @@ -157,4 +157,8 @@ public class EtFeeRule extends BaseEntity /** 是否缴纳过押金*/ @Excel(name = "是否缴纳过押金") private Boolean isDeposit; + + /** 是否已删除*/ + @Excel(name = "是否已删除") + private String isDeleted; } diff --git a/electripper-system/src/main/java/com/ruoyi/system/domain/vo/RechargeVo.java b/electripper-system/src/main/java/com/ruoyi/system/domain/vo/RechargeVo.java index c8d632e..889813b 100644 --- a/electripper-system/src/main/java/com/ruoyi/system/domain/vo/RechargeVo.java +++ b/electripper-system/src/main/java/com/ruoyi/system/domain/vo/RechargeVo.java @@ -54,4 +54,7 @@ public class RechargeVo { @Excel(name = "充值状态:1-充值成功;2-退款成功;") private String rechargeStatus; + @Excel(name = "是否已退款") + private Boolean isRefunded; + } diff --git a/electripper-system/src/main/java/com/ruoyi/system/mapper/EtFeeRuleMapper.java b/electripper-system/src/main/java/com/ruoyi/system/mapper/EtFeeRuleMapper.java index ae38448..cc9e377 100644 --- a/electripper-system/src/main/java/com/ruoyi/system/mapper/EtFeeRuleMapper.java +++ b/electripper-system/src/main/java/com/ruoyi/system/mapper/EtFeeRuleMapper.java @@ -19,6 +19,14 @@ public interface EtFeeRuleMapper */ public EtFeeRule selectEtFeeRuleByRuleId(Long ruleId); + /** + * 查询收费方式 + * + * @param ruleId 收费方式主键 + * @return 收费方式 + */ + public EtFeeRule selectEtFeeRuleByRuleIdIncludeDelete(Long ruleId); + /** * 查询收费方式列表 * diff --git a/electripper-system/src/main/java/com/ruoyi/system/service/IAsDeviceService.java b/electripper-system/src/main/java/com/ruoyi/system/service/IAsDeviceService.java index f567513..5ec4826 100644 --- a/electripper-system/src/main/java/com/ruoyi/system/service/IAsDeviceService.java +++ b/electripper-system/src/main/java/com/ruoyi/system/service/IAsDeviceService.java @@ -162,6 +162,16 @@ public interface IAsDeviceService extends IService */ Boolean ring(String sn); + + /** + * 重启设备 + */ + Boolean rebootByMac(String mac); + /** + * 重启设备 + */ + Boolean reboot(String sn); + /** * 响铃寻车 */ @@ -220,7 +230,7 @@ public interface IAsDeviceService extends IService /** * 车辆下线 */ - Boolean offline(String sn); + Boolean offline(String sn,String status); /** * 根据条件模糊查询车辆信息 diff --git a/electripper-system/src/main/java/com/ruoyi/system/service/IEtFeeRuleService.java b/electripper-system/src/main/java/com/ruoyi/system/service/IEtFeeRuleService.java index 6035d25..cc0a754 100644 --- a/electripper-system/src/main/java/com/ruoyi/system/service/IEtFeeRuleService.java +++ b/electripper-system/src/main/java/com/ruoyi/system/service/IEtFeeRuleService.java @@ -20,6 +20,14 @@ public interface IEtFeeRuleService */ public EtFeeRule selectEtFeeRuleByRuleId(Long ruleId); + /** + * 查询收费方式 + * + * @param ruleId 收费方式主键 + * @return 收费方式 + */ + public EtFeeRule selectEtFeeRuleByRuleIdIncludeDelete(Long ruleId); + /** * 查询收费方式列表 * diff --git a/electripper-system/src/main/java/com/ruoyi/system/service/IWxPayService.java b/electripper-system/src/main/java/com/ruoyi/system/service/IWxPayService.java index 0670b39..031f46e 100644 --- a/electripper-system/src/main/java/com/ruoyi/system/service/IWxPayService.java +++ b/electripper-system/src/main/java/com/ruoyi/system/service/IWxPayService.java @@ -1,7 +1,6 @@ package com.ruoyi.system.service; import com.ruoyi.common.core.domain.entity.SysDept; -import com.ruoyi.system.domain.EtOperatingArea; import com.ruoyi.system.domain.EtOrder; import com.wechat.pay.java.service.payments.jsapi.model.PrepayWithRequestPaymentResponse; import com.wechat.pay.java.service.payments.model.Transaction; diff --git a/electripper-system/src/main/java/com/ruoyi/system/service/impl/AsDeviceServiceImpl.java b/electripper-system/src/main/java/com/ruoyi/system/service/impl/AsDeviceServiceImpl.java index 3fdefaf..e1a1eb9 100644 --- a/electripper-system/src/main/java/com/ruoyi/system/service/impl/AsDeviceServiceImpl.java +++ b/electripper-system/src/main/java/com/ruoyi/system/service/impl/AsDeviceServiceImpl.java @@ -700,7 +700,7 @@ public class AsDeviceServiceImpl extends ServiceImpl i */ @SneakyThrows @Override - public Boolean offline(String sn) { + public Boolean offline(String sn,String status) { AsDevice asDevice = asDeviceMapper.selectAsDeviceBySn(sn); if(ServiceConstants.VEHICLE_STATUS_IN_APPOINTMENT.equals(asDevice.getStatus())){ throw new ServiceException("车辆处于预约中,不能下线"); @@ -711,7 +711,7 @@ public class AsDeviceServiceImpl extends ServiceImpl i if(ServiceConstants.VEHICLE_STATUS_TEMPORARILY_LOCK.equals(asDevice.getStatus())){ throw new ServiceException("车辆临时停车中,不能下线"); } - asDevice.setStatus(ServiceConstants.VEHICLE_STATUS_IN_OFFLINE); + asDevice.setStatus(status); int device = asDeviceMapper.updateAsDevice(asDevice); if(device==0){ log.info("车辆下线状态失败"); @@ -892,6 +892,45 @@ public class AsDeviceServiceImpl extends ServiceImpl i return Boolean.TRUE; } + /** + * 重启设备 + * @param sn + * @return + */ + @SneakyThrows + @Override + public Boolean reboot(String sn) { + AsDevice asDevice = asDeviceMapper.selectAsDeviceBySn(sn); + /** 1.获取token*/ + String token = Token.getToken(); + Boolean execute = transactionTemplate.execute(e -> { + /** 2.发送命令*/ + sendCommand(asDevice.getMac(), token,IotConstants.COMMAND_PLAY1,"重启设备"); + return Boolean.TRUE; + }); + if(!execute)throw new ServiceException("重启设备失败"); + return Boolean.TRUE; + } + + /** + * 重启设备 + * @param mac + * @return + */ + @SneakyThrows + @Override + public Boolean rebootByMac(String mac) { + /** 1.获取token*/ + String token = Token.getToken(); + Boolean execute = transactionTemplate.execute(e -> { + /** 2.发送命令*/ + sendCommand(mac, token,IotConstants.COMMAND_REBOOT,"重启设备"); + return Boolean.TRUE; + }); + if(!execute)throw new ServiceException("重启设备失败"); + return Boolean.TRUE; + } + /** * 响铃寻车 * @param mac @@ -1300,7 +1339,7 @@ public class AsDeviceServiceImpl extends ServiceImpl i String type = order.getType(); if(type.equals("1")){//骑行订单,正常骑行(包含预约费),计时收费,根据开锁时间、起步价和起步时长、时长费和时长分钟等参数,如果有预约,还要加上预约费计算费用,还要判断封顶费用(根据开锁时间) Long ruleId = order.getRuleId(); - EtFeeRule rule = etFeeRuleService.selectEtFeeRuleByRuleId(ruleId); + EtFeeRule rule = etFeeRuleService.selectEtFeeRuleByRuleIdIncludeDelete(ruleId); if(ObjectUtil.isNull(rule)){ throw new ServiceException("计费规则不存在"); } diff --git a/electripper-system/src/main/java/com/ruoyi/system/service/impl/CallbackServiceImpl.java b/electripper-system/src/main/java/com/ruoyi/system/service/impl/CallbackServiceImpl.java index 20e73bd..724cb77 100644 --- a/electripper-system/src/main/java/com/ruoyi/system/service/impl/CallbackServiceImpl.java +++ b/electripper-system/src/main/java/com/ruoyi/system/service/impl/CallbackServiceImpl.java @@ -115,8 +115,8 @@ public class CallbackServiceImpl implements CallbackService { @Resource private EtCallbackLogMapper callbackLogMapper; - @Value("${et.handlingCharge}") - private String handlingCharge; +// @Value("${et.handlingCharge}") +// private String handlingCharge; /** @@ -389,7 +389,7 @@ public class CallbackServiceImpl implements CallbackService { * 退还押金定时任务 */ private void refundDeposit(String deposit, EtOrder order, AsUser asUser) { - EtFeeRule rule = etFeeRuleService.selectEtFeeRuleByRuleId(order.getRuleId()); + EtFeeRule rule = etFeeRuleService.selectEtFeeRuleByRuleIdIncludeDelete(order.getRuleId()); Integer autoRefundDeposit = rule.getAutoRefundDeposit(); logger.info("【微信支付回调】进入退还押金"); @@ -470,8 +470,9 @@ public class CallbackServiceImpl implements CallbackService { capitalFlow.setType(type); capitalFlow.setBusType(busType); capitalFlow.setAmount(order.getPayFee()); - logger.info("【微信支付回调--保存资金流水记录】 获取到配置手续费==============handlingCharge=====================:"+handlingCharge); - BigDecimal bigDecimal = new BigDecimal(handlingCharge).divide(new BigDecimal(1000), 6, BigDecimal.ROUND_HALF_UP); + String handlingCharge1 = sysDept.getHandlingCharge(); + logger.info("【微信支付回调--保存资金流水记录】 获取到配置手续费==============handlingCharge=====================:"+handlingCharge1); + BigDecimal bigDecimal = new BigDecimal(handlingCharge1).divide(new BigDecimal(1000), 6, BigDecimal.ROUND_HALF_UP); logger.info("【微信支付回调--保存资金流水记录】 转换后手续费==============bigDecimal=====================:"+bigDecimal); BigDecimal handlingCharge = bigDecimal.multiply(order.getPayFee()).setScale(2, BigDecimal.ROUND_HALF_UP); logger.info("【微信支付回调--保存资金流水记录】 计算出的手续费==============handlingCharge=====================:"+handlingCharge); @@ -481,10 +482,9 @@ public class CallbackServiceImpl implements CallbackService { capitalFlow.setPlatformServiceFee(platformServiceFee); capitalFlow.setHandlingCharge(handlingCharge);//手续费 if(busType.equals(ServiceConstants.ORDER_TYPE_WITHDRAW)){//提现,需要手续费,不需要平台服务费 - platformServiceFee = BigDecimal.ZERO; - BigDecimal separateAccountFee = order.getPayFee().subtract(handlingCharge).subtract(platformServiceFee); + BigDecimal separateAccountFee = order.getPayFee(); capitalFlow.setPartnerDividend(BigDecimal.ZERO); - capitalFlow.setPlatformServiceFee(platformServiceFee); + capitalFlow.setPlatformServiceFee(BigDecimal.ZERO); capitalFlow.setOperatorDividend(separateAccountFee.negate()); capitalFlow.setOperatorBalance(sysDept.getBalance().subtract(separateAccountFee)); deptService.changeDeptBalance(separateAccountFee.negate(),sysDept.getDeptId()); diff --git a/electripper-system/src/main/java/com/ruoyi/system/service/impl/EtFeeRuleServiceImpl.java b/electripper-system/src/main/java/com/ruoyi/system/service/impl/EtFeeRuleServiceImpl.java index 88de043..6e00559 100644 --- a/electripper-system/src/main/java/com/ruoyi/system/service/impl/EtFeeRuleServiceImpl.java +++ b/electripper-system/src/main/java/com/ruoyi/system/service/impl/EtFeeRuleServiceImpl.java @@ -37,6 +37,18 @@ public class EtFeeRuleServiceImpl implements IEtFeeRuleService return etFeeRuleMapper.selectEtFeeRuleByRuleId(ruleId); } + /** + * 查询收费方式 + * + * @param ruleId 收费方式主键 + * @return 收费方式 + */ + @Override + public EtFeeRule selectEtFeeRuleByRuleIdIncludeDelete(Long ruleId) + { + return etFeeRuleMapper.selectEtFeeRuleByRuleIdIncludeDelete(ruleId); + } + /** * 查询收费方式列表 * diff --git a/electripper-system/src/main/java/com/ruoyi/system/service/impl/EtOrderServiceImpl.java b/electripper-system/src/main/java/com/ruoyi/system/service/impl/EtOrderServiceImpl.java index 2d590a4..7d3d298 100644 --- a/electripper-system/src/main/java/com/ruoyi/system/service/impl/EtOrderServiceImpl.java +++ b/electripper-system/src/main/java/com/ruoyi/system/service/impl/EtOrderServiceImpl.java @@ -89,8 +89,8 @@ public class EtOrderServiceImpl implements IEtOrderService @Autowired private CallbackService callbackService; - @Value("${et.handlingCharge}") - private String handlingCharge; +// @Value("${et.handlingCharge}") +// private String handlingCharge; @Resource private EtRefundMapper etRefundMapper; @@ -108,7 +108,7 @@ public class EtOrderServiceImpl implements IEtOrderService EtOrder order = etOrderMapper.selectEtOrderByOrderId(orderId); AsDevice device = asDeviceMapper.selectAsDeviceBySn(order.getSn()); order.setDevice(device); - EtFeeRule etFeeRule = etFeeRuleService.selectEtFeeRuleByRuleId(order.getRuleId()); + EtFeeRule etFeeRule = etFeeRuleService.selectEtFeeRuleByRuleIdIncludeDelete(order.getRuleId()); order.setRule(etFeeRule); //行程记录 EtTripLog tripLog = new EtTripLog(); @@ -178,7 +178,7 @@ public class EtOrderServiceImpl implements IEtOrderService AsDevice device = asDeviceMapper.selectAsDeviceBySn(order.getSn()); order.setDevice(device); //根据规则id查询规则 - EtFeeRule etFeeRule = etFeeRuleService.selectEtFeeRuleByRuleId(order.getRuleId()); + EtFeeRule etFeeRule = etFeeRuleService.selectEtFeeRuleByRuleIdIncludeDelete(order.getRuleId()); if(ObjectUtils.isNotEmpty(etFeeRule)){ order.setRule(etFeeRule); } @@ -268,38 +268,49 @@ public class EtOrderServiceImpl implements IEtOrderService @DataScope(deptAlias = "d") public List rechargeList(EtOrder etOrder) { List rechargeVoList = new ArrayList<>(); - etOrder.setPaid(ServiceConstants.ORDER_PAY_STATUS_PAID); - etOrder.setStatus(ServiceConstants.ORDER_STATUS_ORDER_END); - List etOrders = etOrderMapper.selectEtOrderList(etOrder); - etOrders.forEach(etOrder1 -> { - RechargeVo rechargeVo = new RechargeVo(); - BeanUtils.copyProperties(etOrder1,rechargeVo); - rechargeVo.setRechargeStatus(ServiceConstants.RECHARGE_STATUS_SUCCESS); - rechargeVo.setRechargeType(ServiceConstants.ORDER_TYPE_DEPOSIT); - rechargeVo.setTotalFee(etOrder1.getPayFee()); - rechargeVoList.add(rechargeVo); - }); - //如果查询押金则增加退款记录 - EtRefund refund = new EtRefund(); - refund.setType(ServiceConstants.REFUND_TYPE_DEPOSIT); - refund.setRefundResult(Constants.SUCCESS2); - refund.setUserName(etOrder.getUserName()); - PageUtils.startPage(); - List etRefunds = etRefundMapper.selectEtRefundList(refund);; - etRefunds.forEach(etRefund -> { - AsUser asUser = asUserService.selectUserById(etRefund.getUserId()); - RechargeVo rechargeVo = new RechargeVo(); - BeanUtils.copyProperties(etRefund,rechargeVo); - rechargeVo.setOutTradeNo(etRefund.getRefundNo()); - rechargeVo.setPayTime(etRefund.getCreateTime()); - rechargeVo.setTotalFee(etRefund.getAmount()); - rechargeVo.setUserId(etRefund.getUserId()); - rechargeVo.setUserName(asUser.getUserName()); - rechargeVo.setPhonenumber(asUser.getPhonenumber()); - rechargeVo.setRechargeStatus(ServiceConstants.RECHARGE_STATUS_REFUND_SUCCESS); - rechargeVo.setRechargeType(ServiceConstants.ORDER_TYPE_DEPOSIT_REFUND); - rechargeVoList.add(rechargeVo); - }); + String status = etOrder.getStatus(); + if(StrUtil.isBlank(status) || "1".equals(status)){ + etOrder.setPaid(ServiceConstants.ORDER_PAY_STATUS_PAID); + etOrder.setStatus(ServiceConstants.ORDER_STATUS_ORDER_END); + List etOrders = etOrderMapper.selectEtOrderList(etOrder); + etOrders.forEach(etOrder1 -> { + RechargeVo rechargeVo = new RechargeVo(); + BeanUtils.copyProperties(etOrder1,rechargeVo); + rechargeVo.setRechargeStatus(ServiceConstants.RECHARGE_STATUS_SUCCESS); + rechargeVo.setRechargeType(ServiceConstants.ORDER_TYPE_DEPOSIT); + rechargeVo.setTotalFee(etOrder1.getPayFee()); + List etRefunds = etRefundMapper.selectEtRefundByOrderNo(etOrder1.getOrderNo()); + if(ObjectUtil.isNull(etRefunds) || etRefunds.size() == 0){ + rechargeVo.setIsRefunded(false); + }else{ + rechargeVo.setIsRefunded(true); + } + rechargeVoList.add(rechargeVo); + }); + } + if(StrUtil.isBlank(status) || "2".equals(status)){ + //如果查询押金则增加退款记录 + EtRefund refund = new EtRefund(); + refund.setType(ServiceConstants.REFUND_TYPE_DEPOSIT); + refund.setRefundResult(Constants.SUCCESS2); + refund.setUserName(etOrder.getUserName()); + PageUtils.startPage(); + List etRefunds = etRefundMapper.selectEtRefundList(refund);; + etRefunds.forEach(etRefund -> { + AsUser asUser = asUserService.selectUserById(etRefund.getUserId()); + RechargeVo rechargeVo = new RechargeVo(); + BeanUtils.copyProperties(etRefund,rechargeVo); + rechargeVo.setOutTradeNo(etRefund.getRefundNo()); + rechargeVo.setPayTime(etRefund.getCreateTime()); + rechargeVo.setTotalFee(etRefund.getAmount()); + rechargeVo.setUserId(etRefund.getUserId()); + rechargeVo.setUserName(asUser.getUserName()); + rechargeVo.setPhonenumber(asUser.getPhonenumber()); + rechargeVo.setRechargeStatus(ServiceConstants.RECHARGE_STATUS_REFUND_SUCCESS); + rechargeVo.setRechargeType(ServiceConstants.ORDER_TYPE_DEPOSIT_REFUND); + rechargeVoList.add(rechargeVo); + }); + } //将rechargeVoList根据payTime倒序 rechargeVoList.sort(Comparator.comparing(RechargeVo::getPayTime).reversed()); return rechargeVoList; @@ -678,6 +689,8 @@ public class EtOrderServiceImpl implements IEtOrderService String totalRefund = etOrderMapper.getTotalRefund(timeStart, timeEnd, areaId);//已退款 income.setTotalPaid(totalPaid);//已支付 //handlingFee 手续费 = 0.0054 * 已支付金额 + SysDept sysDept = wxPayService.getDeptObjByAreaId(Long.parseLong(areaId)); + String handlingCharge = sysDept.getHandlingCharge(); BigDecimal divide = new BigDecimal(handlingCharge).divide(new BigDecimal(1000), 4, RoundingMode.HALF_UP); BigDecimal handlingFee = new BigDecimal(totalPaid).multiply(divide); income.setHandlingFee(handlingFee.setScale(2, RoundingMode.HALF_UP).toString()); @@ -906,7 +919,7 @@ public class EtOrderServiceImpl implements IEtOrderService List devices = asDeviceMapper.selectAsDeviceList(device1); log.info("【收入对账】根据sn搜索出的devices:{}", JSON.toJSON(devices)); for (AsDevice device : devices) { - reconciliations.add(createReconciliationByVehicle(timeStart, timeEnd, device.getSn())); + reconciliations.add(createReconciliationByVehicle(timeStart, timeEnd, device.getSn(),device.getAreaId())); } ReconciliationVo reconciliationVo = new ReconciliationVo(); @@ -922,7 +935,8 @@ public class EtOrderServiceImpl implements IEtOrderService SysDept deptObjByAreaId = wxPayService.getDeptObjByAreaId(areaId); reconciliation.setDeptName(deptObjByAreaId.getDeptName()); reconciliation.setDay(formattedDate); - + SysDept sysDept = wxPayService.getDeptObjByAreaId(areaId); + String handlingCharge = sysDept.getHandlingCharge(); BigDecimal payFee = defaultIfNull(etOrderMapper.getPayFee(startDateStr, endDateStr, null, areaId), BigDecimal.ZERO);//新增 BigDecimal refundFee = defaultIfNull(etOrderMapper.getRefundFee(startDateStr, endDateStr, null, areaId), BigDecimal.ZERO);//退款 BigDecimal divide = new BigDecimal(handlingCharge).divide(new BigDecimal(1000), 4, RoundingMode.HALF_UP); @@ -952,13 +966,15 @@ public class EtOrderServiceImpl implements IEtOrderService return reconciliation; } - private ReconciliationVo.Reconciliation createReconciliationByVehicle(String timeStart, String timeEnd, String sn) { + private ReconciliationVo.Reconciliation createReconciliationByVehicle(String timeStart, String timeEnd, String sn,Long areaId) { ReconciliationVo.Reconciliation reconciliation = new ReconciliationVo.Reconciliation(); reconciliation.setSn(sn); BigDecimal payFee = etOrderMapper.getPayFee(timeStart, timeEnd, sn, null); reconciliation.setPayFee(payFee); BigDecimal refundFee = etOrderMapper.getRefundFee(timeStart, timeEnd, sn, null); reconciliation.setRefundFee(refundFee); + SysDept sysDept = wxPayService.getDeptObjByAreaId(areaId); + String handlingCharge = sysDept.getHandlingCharge(); BigDecimal divide = new BigDecimal(handlingCharge).divide(new BigDecimal(1000), 4, RoundingMode.HALF_UP); BigDecimal serviceFee = payFee.multiply(divide).setScale(2, RoundingMode.HALF_UP);//手续费 reconciliation.setIncome(payFee.subtract(refundFee).subtract(serviceFee)); @@ -1018,6 +1034,11 @@ public class EtOrderServiceImpl implements IEtOrderService if(dividendDetailService.isDividendComputedByOrderNo(etOrder.getOrderNo())){ throw new ServiceException("订单【{}】已经分账,不能退款"); } + SysDept sysDept = wxPayService.getDeptObjByAreaId(etOrder1.getAreaId()); + BigDecimal subtract = sysDept.getBalance().subtract(etOrder1.getTotalFee()); + if(subtract.compareTo(BigDecimal.ZERO) <= 0){ + throw new ServiceException("余额不足,不能退款"); + } /** 1.退款*/ //退款金额 BigDecimal refundAmount = new BigDecimal("0"); @@ -1120,7 +1141,7 @@ public class EtOrderServiceImpl implements IEtOrderService public List isInOrder(Long userId,String orderNo) { List inOrder = etOrderMapper.isInOrder(userId, orderNo); for(EtOrder order:inOrder){ - EtFeeRule etFeeRule = etFeeRuleService.selectEtFeeRuleByRuleId(order.getRuleId()); + EtFeeRule etFeeRule = etFeeRuleService.selectEtFeeRuleByRuleIdIncludeDelete(order.getRuleId()); if(ObjectUtil.isNotNull(etFeeRule)){ order.setRule(etFeeRule); } diff --git a/electripper-system/src/main/java/com/ruoyi/system/service/impl/EtWithdrawServiceImpl.java b/electripper-system/src/main/java/com/ruoyi/system/service/impl/EtWithdrawServiceImpl.java index 34a9d33..698c147 100644 --- a/electripper-system/src/main/java/com/ruoyi/system/service/impl/EtWithdrawServiceImpl.java +++ b/electripper-system/src/main/java/com/ruoyi/system/service/impl/EtWithdrawServiceImpl.java @@ -132,7 +132,7 @@ public class EtWithdrawServiceImpl implements IEtWithdrawService transferDetailInput.setOpenid(etWithdraw.getWxopenid()); transferDetailInputs.add(transferDetailInput); log.info("【审核通过】发起转账到零钱:{}",JSON.toJSONString(transferDetailInputs)); - // todo 暂时先不发起真实提现 + // todo 暂时先不发起真实提现 真正的提现是 // wxPayService.transfer(sysDept,etWithdraw.getWithdrawNo(),batchName,batchName,etWithdraw.getAmount(),1,transferDetailInputs); //扣余额并记录资金流水 sysDept.getBalance().subtract(etWithdraw.getAmount()); diff --git a/electripper-system/src/main/java/com/ruoyi/system/task/EtTask.java b/electripper-system/src/main/java/com/ruoyi/system/task/EtTask.java index bfdbfe7..fb268bc 100644 --- a/electripper-system/src/main/java/com/ruoyi/system/task/EtTask.java +++ b/electripper-system/src/main/java/com/ruoyi/system/task/EtTask.java @@ -105,7 +105,7 @@ public class EtTask { List orders = etOrderMapper.selectUserListFinishOrder(); log.info("已完成的订单未退还押金的的订单 = " + JSON.toJSONString(orders)); for(EtOrder order:orders){ - EtFeeRule rule = etFeeRuleService.selectEtFeeRuleByRuleId(order.getRuleId()); + EtFeeRule rule = etFeeRuleService.selectEtFeeRuleByRuleIdIncludeDelete(order.getRuleId()); if(ObjectUtil.isNull(rule)){ throw new ServiceException("骑行订单:【"+order.getOrderNo()+"】未找到该套餐【"+order.getRuleId()+"】"); } diff --git a/electripper-system/src/main/resources/mapper/system/EtFeeRuleMapper.xml b/electripper-system/src/main/resources/mapper/system/EtFeeRuleMapper.xml index 89c1272..84cfb99 100644 --- a/electripper-system/src/main/resources/mapper/system/EtFeeRuleMapper.xml +++ b/electripper-system/src/main/resources/mapper/system/EtFeeRuleMapper.xml @@ -25,6 +25,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" + @@ -40,7 +41,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" r.free_ride_time, r.rental_unit, r.riding_rule, r.riding_rule_json, r.charging_cycle, r.charging_cycle_value, r.capped_amount, r.instructions, r.create_by, r.create_time from et_fee_rule r left join sys_dept d on d.dept_id = r.dept_id - where 1 = 1 + where r.is_deleted = 0 and r.`name` like concat('%', #{name}, '%') and r.status = #{status} and r.dept_id = #{deptId} @@ -49,6 +50,11 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" + + @@ -58,7 +64,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" from et_fee_rule r left join et_area_rule ar on ar.rule_id = r.rule_id left join et_operating_area a on a.area_id = ar.area_id - where a.area_id = #{areaId} + where r.is_deleted = 0 and a.area_id = #{areaId} @@ -150,10 +156,13 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" delete from et_fee_rule where rule_id = #{ruleId} - - delete from et_fee_rule where rule_id in + + update et_fee_rule + set is_deleted = 1 + where rule_id in #{ruleId} - + + diff --git a/electripper-system/src/main/resources/mapper/system/EtOrderMapper.xml b/electripper-system/src/main/resources/mapper/system/EtOrderMapper.xml index 5333d2f..c873128 100644 --- a/electripper-system/src/main/resources/mapper/system/EtOrderMapper.xml +++ b/electripper-system/src/main/resources/mapper/system/EtOrderMapper.xml @@ -57,6 +57,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" oa.is_deposit_deduction isDepositDeduction, u.user_name AS userName, u.phonenumber AS phonenumber, + u.real_name AS realName, o.order_no, o.out_trade_no, o.user_id, diff --git a/electripper-system/src/main/resources/mapper/system/SysDeptMapper.xml b/electripper-system/src/main/resources/mapper/system/SysDeptMapper.xml index 1e952d7..7a5f52f 100644 --- a/electripper-system/src/main/resources/mapper/system/SysDeptMapper.xml +++ b/electripper-system/src/main/resources/mapper/system/SysDeptMapper.xml @@ -17,6 +17,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" + @@ -39,7 +40,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" select d.dept_id, d.parent_id, d.ancestors, d.dept_name, d.order_num, d.leader, d.phone, d.email, d.status, - d.del_flag,d.platform_service_fee, d.is_profit_sharing, d.domain, d.is_use_platform_app, d.appid, d.app_name, d.balance, d.app_secret, + d.del_flag,d.platform_service_fee, d.handling_charge, d.is_profit_sharing, d.domain, d.is_use_platform_app, d.appid, d.app_name, d.balance, d.app_secret, d.merchant_id, d.api_v3_key, d.notify_url, d.private_key_path,d.merchant_serial_number,d.refund_notify_url, d.create_by, d.create_time from sys_dept d @@ -77,7 +78,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"