xucaiqin 5 дней назад
Родитель
Сommit
b0fce1ffd1
100 измененных файлов с 5596 добавлено и 0 удалено
  1. 6 0
      sckw-modules/sckw-payment/pom.xml
  2. 30 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/config/ApplicationProperties.java
  3. 60 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/controller/NoticeController.java
  4. 47 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/controller/WalletBusinessFileController.java
  5. 224 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/controller/WalletController.java
  6. 61 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/controller/WalletPayableBalanceController.java
  7. 198 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/controller/WalletPayableController.java
  8. 58 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/controller/WalletPrepaidBalanceController.java
  9. 206 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/controller/WalletPrepaidController.java
  10. 151 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/entity/KwpWallet.java
  11. 126 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/entity/KwpWalletCash.java
  12. 124 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/entity/KwpWalletSplit.java
  13. 80 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/entity/Wallet.java
  14. 63 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/entity/WalletAccount.java
  15. 87 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/entity/WalletBalance.java
  16. 40 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/entity/WalletBankCallback.java
  17. 43 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/entity/WalletBankRequest.java
  18. 50 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/entity/WalletBusinessFile.java
  19. 92 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/entity/WalletEntInfo.java
  20. 56 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/entity/WalletEntUser.java
  21. 63 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/entity/WalletPayable.java
  22. 60 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/entity/WalletPayableApply.java
  23. 75 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/entity/WalletPayableBalance.java
  24. 62 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/entity/WalletPayablePay.java
  25. 57 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/entity/WalletPrepaid.java
  26. 72 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/entity/WalletPrepaidBalance.java
  27. 58 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/entity/WalletPrepaidRecord.java
  28. 40 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/entity/WalletRequestLog.java
  29. 35 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/enums/CashActionEnum.java
  30. 32 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/enums/CashStatusEnum.java
  31. 41 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/enums/ExecutionStatusEnum.java
  32. 31 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/enums/FreightActionEnum.java
  33. 31 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/enums/FreightStatusEnum.java
  34. 44 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/enums/OrderTypeEnum.java
  35. 42 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/enums/PayStatusEnum.java
  36. 21 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/enums/PayXwEnum.java
  37. 49 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/enums/TransactionTypeEnum.java
  38. 32 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/enums/WalletStatusEnum.java
  39. 13 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/mapper/KwpWalletCashMapper.java
  40. 13 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/mapper/KwpWalletMapper.java
  41. 13 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/mapper/KwpWalletSplitMapper.java
  42. 81 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/mapper/WalletAccountMapper.java
  43. 81 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/mapper/WalletBalanceMapper.java
  44. 81 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/mapper/WalletBankCallbackMapper.java
  45. 72 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/mapper/WalletBankRequestMapper.java
  46. 88 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/mapper/WalletBusinessFileMapper.java
  47. 81 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/mapper/WalletEntInfoMapper.java
  48. 85 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/mapper/WalletEntUserMapper.java
  49. 89 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/mapper/WalletMapper.java
  50. 91 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/mapper/WalletPayableApplyMapper.java
  51. 84 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/mapper/WalletPayableBalanceMapper.java
  52. 87 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/mapper/WalletPayableMapper.java
  53. 87 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/mapper/WalletPayablePayMapper.java
  54. 86 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/mapper/WalletPrepaidBalanceMapper.java
  55. 95 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/mapper/WalletPrepaidMapper.java
  56. 84 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/mapper/WalletPrepaidRecordMapper.java
  57. 72 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/mapper/WalletRequestLogMapper.java
  58. 86 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/CashVo.java
  59. 24 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/UpdateCash.java
  60. 21 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/dto/CashDto.java
  61. 31 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/dto/CashWalletReq.java
  62. 27 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/dto/CreateUser.java
  63. 32 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/dto/CustomSettleDto.java
  64. 22 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/dto/CustomSettleRes.java
  65. 18 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/dto/DivideDto.java
  66. 14 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/dto/DivideInfoDto.java
  67. 41 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/dto/PayDto.java
  68. 16 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/dto/Res.java
  69. 21 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/dto/SplitDto.java
  70. 15 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/dto/UserDataDto.java
  71. 16 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/dto/UserDto.java
  72. 47 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/dto/UserPara.java
  73. 39 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/dto/WithdrawDto.java
  74. 15 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/dto/WithdrawRes.java
  75. 20 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/vo/PayRes.java
  76. 71 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/vo/WalletCashVo.java
  77. 142 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/vo/WalletVo.java
  78. 19 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/vo/req/CreateUserReq.java
  79. 30 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/vo/req/ReceivedCallbackDto.java
  80. 26 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/vo/req/WalletAccountInfoQuery.java
  81. 26 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/vo/req/WalletPayableApplyPayDto.java
  82. 19 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/vo/req/WalletPayableApplyQuery.java
  83. 53 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/vo/req/WalletPayableBalanceQuery.java
  84. 24 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/vo/req/WalletPayableConfirmPayDto.java
  85. 45 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/vo/req/WalletPayableDto.java
  86. 37 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/vo/req/WalletPayableManualDto.java
  87. 34 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/vo/req/WalletPayablePayQuery.java
  88. 44 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/vo/req/WalletPayableQuery.java
  89. 30 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/vo/req/WalletPrepaidAddDto.java
  90. 52 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/vo/req/WalletPrepaidBalanceQuery.java
  91. 42 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/vo/req/WalletPrepaidDto.java
  92. 29 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/vo/req/WalletPrepaidManualDto.java
  93. 31 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/vo/req/WalletPrepaidQuery.java
  94. 36 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/vo/req/WalletPrepaidRecordQuery.java
  95. 16 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/vo/req/WalletQueryDto.java
  96. 31 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/vo/res/FinancialReportRes.java
  97. 89 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/vo/res/HttpResult.java
  98. 38 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/vo/res/WalletPayAddRes.java
  99. 28 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/vo/res/WalletPayableApplyRes.java
  100. 69 0
      sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/vo/res/WalletPayableBalanceRes.java

+ 6 - 0
sckw-modules/sckw-payment/pom.xml

@@ -119,6 +119,12 @@
             <groupId>com.github.xiaoymin</groupId>
             <groupId>com.github.xiaoymin</groupId>
             <artifactId>knife4j-openapi3-jakarta-spring-boot-starter</artifactId>
             <artifactId>knife4j-openapi3-jakarta-spring-boot-starter</artifactId>
         </dependency>
         </dependency>
+        <dependency>
+            <groupId>com.sckw</groupId>
+            <artifactId>sckw-contract-api</artifactId>
+            <version>1.0.0</version>
+            <scope>compile</scope>
+        </dependency>
 
 
 
 
     </dependencies>
     </dependencies>

+ 30 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/config/ApplicationProperties.java

@@ -0,0 +1,30 @@
+package com.sckw.payment.config;
+
+import lombok.Data;
+import org.springframework.boot.context.properties.ConfigurationProperties;
+import org.springframework.context.annotation.Configuration;
+
+@Data
+@Configuration
+@ConfigurationProperties(prefix = "sckw.payment")
+public class ApplicationProperties {
+    //报表导出根路径
+    private String bankCode;
+    //新网银行配置
+    private XWBankConfig xw;
+
+    @Data
+    public static class XWBankConfig{
+        private String url;
+        private String charge;
+        private String prefix;
+        private String appId;
+        private Integer platNo;
+        private String amtMaxOrder;
+        private String amtMaxDay;
+        private String account;
+        private String split;
+        private String cash;
+        private String refund;
+    }
+}

+ 60 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/controller/NoticeController.java

@@ -0,0 +1,60 @@
+package com.sckw.payment.controller;
+
+import com.sckw.payment.api.model.dto.common.R;
+import com.sckw.payment.pojo.dto.CashDto;
+import com.sckw.payment.pojo.dto.SplitDto;
+import com.sckw.payment.pojo.dto.UserDto;
+import com.sckw.payment.service.WalletService;
+import io.swagger.v3.oas.annotations.Operation;
+import io.swagger.v3.oas.annotations.tags.Tag;
+import jakarta.annotation.Resource;
+import lombok.extern.slf4j.Slf4j;
+import org.springframework.validation.annotation.Validated;
+import org.springframework.web.bind.annotation.PostMapping;
+import org.springframework.web.bind.annotation.RequestBody;
+import org.springframework.web.bind.annotation.RequestMapping;
+import org.springframework.web.bind.annotation.RestController;
+
+/**
+ * 通知
+ *
+ * @author xucaiqin
+ * @date 2023-08-28 15:36:48
+ */
+@Tag(name = "通知", description = "通知")
+@Validated
+@RestController
+@RequestMapping("/notice")
+@Slf4j
+public class NoticeController {
+    @Resource
+    private WalletService walletService;
+
+    /**
+     * 【接口】用户开户回调
+     */
+    @Operation(summary = "用户开户回调", description = "用户开户回调")
+    @PostMapping("/user")
+    public R<Object> createUser(@RequestBody UserDto userDto) {
+        return R.ok(walletService.userNotice(userDto));
+    }
+
+    /**
+     * 【接口】提现回调通知
+     */
+    @Operation(summary = "提现回调通知", description = "提现回调通知")
+    @PostMapping("/cash")
+    public R<Object> cash(CashDto cashDto) {
+        return R.ok(walletService.cashNotice(cashDto));
+    }
+
+    /**
+     * 【接口】清分回调通知
+     */
+    @Operation(summary = "清分回调通知", description = "清分回调通知")
+    @PostMapping("/split")
+    public R<Object> split(SplitDto splitDto) {
+        return R.ok(walletService.splitNotice(splitDto));
+    }
+
+}

+ 47 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/controller/WalletBusinessFileController.java

@@ -0,0 +1,47 @@
+package com.sckw.payment.controller;
+
+import com.sckw.core.web.response.BaseResult;
+import com.sckw.payment.service.IWalletBusinessFileService;
+import io.swagger.v3.oas.annotations.Operation;
+import io.swagger.v3.oas.annotations.Parameter;
+import io.swagger.v3.oas.annotations.Parameters;
+import io.swagger.v3.oas.annotations.tags.Tag;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.web.bind.annotation.GetMapping;
+import org.springframework.web.bind.annotation.RequestMapping;
+import org.springframework.web.bind.annotation.RequestParam;
+import org.springframework.web.bind.annotation.RestController;
+
+import java.util.List;
+
+/**
+ * 钱包_业务文件Controller
+ *
+ * @author tangys
+ * @since  2026-01-12 14:11:22
+ */
+@Tag(name = "业务文件")
+@RestController
+@RequestMapping("/walletBusinessFile")
+public class WalletBusinessFileController  {
+
+    @Autowired
+    private IWalletBusinessFileService walletBusinessFileService;
+
+
+    /**
+     * 查询凭证图片地址接口
+     *
+     */
+    @Operation(summary =  "查询凭证图片地址接口")
+    @Parameters(value = {
+            @Parameter(name = "businessId", description = "业务主键id,如预付明细主键id、待付运费明细主键id",required = true)
+    })
+    @GetMapping("/queryVouchers")
+    public BaseResult<List<String>> queryVouchers(@RequestParam String businessId) {
+        List<String> list =walletBusinessFileService.selectFileByBusinessId(businessId);
+        return BaseResult.success(list);
+    }
+
+
+}

+ 224 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/controller/WalletController.java

@@ -0,0 +1,224 @@
+package com.sckw.payment.controller;
+
+import com.sckw.core.model.enums.EntTypeEnum;
+import com.sckw.core.model.page.PageRes;
+import com.sckw.core.web.context.LoginEntHolder;
+import com.sckw.core.web.response.BaseResult;
+import com.sckw.payment.api.model.dto.TradeEntInfoResVo;
+import com.sckw.payment.api.model.dto.common.R;
+import com.sckw.payment.pojo.CashVo;
+import com.sckw.payment.pojo.UpdateCash;
+import com.sckw.payment.pojo.dto.CashWalletReq;
+import com.sckw.payment.pojo.vo.WalletCashVo;
+import com.sckw.payment.pojo.vo.WalletVo;
+import com.sckw.payment.pojo.vo.req.CreateUserReq;
+import com.sckw.payment.pojo.vo.req.WalletPayableQuery;
+import com.sckw.payment.pojo.vo.req.WalletPrepaidQuery;
+import com.sckw.payment.pojo.vo.res.HttpResult;
+import com.sckw.payment.pojo.vo.res.WalletPayableSummary;
+import com.sckw.payment.pojo.vo.res.WalletPrepaidSummary;
+import com.sckw.payment.pojo.vo.res.WalletSummary;
+import com.sckw.payment.service.IWalletPayableService;
+import com.sckw.payment.service.IWalletPrepaidService;
+import com.sckw.payment.service.WalletService;
+import io.swagger.v3.oas.annotations.Operation;
+import io.swagger.v3.oas.annotations.Parameter;
+import io.swagger.v3.oas.annotations.tags.Tag;
+import jakarta.annotation.Resource;
+import jakarta.validation.Valid;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.web.bind.annotation.*;
+
+import java.util.List;
+
+
+/**
+ * 钱包表Controller
+ *
+ * @author tangys
+ * @since 2026-01-06 11:03:35
+ */
+
+@Tag(name = "钱包管理")
+@RestController
+@RequestMapping("/wallet")
+public class WalletController  {
+
+
+    //    @Autowired
+//    private IWalletService walletService;
+    @Resource
+    private WalletService walletService;
+
+    @Autowired
+    private IWalletPrepaidService walletPrepaidService;
+
+    @Autowired
+    private IWalletPayableService walletPayableService;
+
+    /**
+     * 【接口】开户
+     *
+     * @param createUserReq 开户请求参数
+     */
+    @Operation(summary = "开户", description = "为用户开通钱包账户")
+    @PostMapping("createUser")
+    public HttpResult createUser(@RequestBody @Valid CreateUserReq createUserReq) {
+        return HttpResult.ok(walletService.createUser(createUserReq));
+    }
+
+    /**
+     * 【接口】钱包信息
+     */
+    @Operation(summary = "查询用户钱包信息", description = "查询用户钱包信息")
+    @GetMapping("/info")
+    public R<WalletVo> userInfo() {
+        return walletService.userInfo();
+    }
+
+    /**
+     * 【接口】可提现余额
+     */
+    @Operation(summary = "可提现余额", description = "可提现余额")
+    @GetMapping("/cashInfo")
+    public R<WalletCashVo> cashInfo() {
+        return walletService.cashInfo();
+    }
+
+    /**
+     * 【接口】更新预付直提开关
+     */
+    @Operation(summary = "更新预付直提开关", description = "更新预付直提开关")
+    @PostMapping("/updateCash")
+    public R<Integer> updateCash(@RequestBody @Valid UpdateCash updateCash) {
+        return R.ok(walletService.updateCash(updateCash));
+    }
+
+    @Operation(summary = "查询交易对方企业列表")
+    @GetMapping("/queryEntList")
+    public BaseResult<List<TradeEntInfoResVo>> queryEntList() {
+        return BaseResult.success(walletService.queryEntList());
+    }
+
+    /**
+     * 【接口】可提现余额分页查询
+     */
+    @Operation(summary = "可提现余额分页查询", description = "可提现余额分页查询")
+    @Parameter(name = "entId", description = "企业id", required = true)
+    @PostMapping("/cashPage")
+    public R<PageRes<CashVo>> cashPage(@RequestBody @Valid CashParaPage cashParaPage) {
+        return R.ok(walletService.cashPage(cashParaPage));
+    }
+
+    /**
+     * 【接口】提现
+     *
+     * @param cashWalletReq 提现参数
+     * @return 操作结果
+     */
+    @Operation(summary = "提现", description = "发起提现操作")
+    @PostMapping("cashOUt")
+    public R<Object> cashOUt(@RequestBody @Valid CashWalletReq cashWalletReq) {
+        return R.ok(walletService.cashOUt(cashWalletReq));
+    }
+    //1、查询钱包信息
+
+    /**
+     * 企业用户钱包查询
+     *
+     * @return
+     */
+//    @GetMapping("/queryWalletInfo")
+//    public BaseResult queryWalletInfo() {
+//        Wallet wallet = walletService.selectWalletByEntId(LoginUserHolder.getEntId());
+//        if (Objects.isNull(wallet)) {
+//            return BaseResult.success("钱包账号不存在");
+//        }
+//        return BaseResult.success(wallet);
+////        BankService bankService = BankServiceUtil.getBankService(properties.getBankCode());
+////        bankService.queryWalletInfo(wallet);
+//    }
+
+
+    //查询钱包可提现、预付余额及运费的汇总接口
+    @Operation(summary = "查询钱包可提现、预付余额及运费的汇总接口")
+    @GetMapping("/querySummary")
+    public BaseResult<WalletSummary> querySummary() {
+        WalletSummary summary = new WalletSummary();
+        String entTypes = LoginEntHolder.get().getEntTypes();
+        WalletPrepaidQuery prepaidQuery = new WalletPrepaidQuery();
+        prepaidQuery.setCurEntId(LoginEntHolder.getEntId());
+        if (entTypes.contains(String.valueOf(EntTypeEnum.SUPPLIER.getCode()))) {
+            prepaidQuery.setEntType(EntTypeEnum.SUPPLIER.getCode());
+        } else if (entTypes.contains(String.valueOf(EntTypeEnum.PURCHASER.getCode()))) {
+            prepaidQuery.setEntType(EntTypeEnum.PURCHASER.getCode());
+        }
+        R<WalletCashVo> walletCashVoR = walletService.cashInfo();
+
+        if (HttpStatus.SUCCESS == walletCashVoR.getCode()) {
+            WalletCashVo data = walletCashVoR.getData();
+            summary.setAvailableBalance(data.getCashAmount());
+            summary.setId(data.getId());
+            summary.setCashFlag(data.getCashFlag());
+        }
+        WalletPrepaidSummary prepaidSummary = walletPrepaidService.selectWalletPrepaidSummary(prepaidQuery);
+        if (prepaidSummary != null) {
+            summary.setPreBalanceTotal(prepaidSummary.getBalanceTotal());
+            summary.setPreTradingAmountTotal(prepaidSummary.getTradingAmountTotal());
+        }
+
+
+        WalletPayableQuery payableQuery = new WalletPayableQuery();
+        payableQuery.setCurEntId(LoginEntHolder.getEntId());
+        if (EntTypeEnum.consign(entTypes)) {
+            payableQuery.setFreightType(1);
+        } else if (EntTypeEnum.carrier(entTypes)) {
+            payableQuery.setFreightType(2);
+        }
+
+        WalletPayableSummary walletPayableSummary = walletPayableService.selectPayableSummary(payableQuery);
+        if (walletPayableSummary != null) {
+            summary.setFreightTotal(walletPayableSummary.getFreightTotal());
+            summary.setTradingFreightTotal(walletPayableSummary.getTradingFreightTotal());
+            summary.setPayingFreightTotal(walletPayableSummary.getPayingFreightTotal());
+        }
+
+        return BaseResult.success(summary);
+    }
+
+    /**
+     * 新增钱包
+     */
+//    @Operation(summary =  "新增保存钱包表")
+//    @PostMapping("/add")
+//    public BaseResult addSave(@RequestBody WalletInfoVo walletInfoVo) {
+//        walletInfoVo.setEntId(LoginUserHolder.getEntId());
+//        return BaseResult.success(walletService.createWallet(walletInfoVo));
+//    }
+
+    /**
+     * 修改钱包表
+     *
+     * @return ModelAndView
+     */
+
+//    @Operation(summary =  "修改保存钱包表")
+//    @PostMapping(value = "/edit/{id}")
+//    public BaseResult editSave(@PathVariable Long id) {
+//        Wallet wallet = walletService.selectWalletById(id);
+//        return toAjax(walletService.updateWallet(wallet));
+//    }
+
+
+    //    @Operation(summary =  "删除钱包表",parameters =  {
+//            @Parameter(name = "ids", description = "id,多个用英文逗号分隔",required = true)
+//    })
+//    @PostMapping("/remove")
+//    public BaseResult remove(String ids) {
+//        if (StringUtils.isBlank(ids)) {
+//            return BaseResult.failed("请选择需要删除的数据!");
+//        }
+//        List<Long> idList = Stream.of(ids.split(",")).filter(StringUtils::isNotBlank).map(String::trim).map(Long::valueOf).distinct().collect(Collectors.toList());
+//        return toAjax(walletService.deleteWalletByIds(idList));
+//    }
+}

+ 61 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/controller/WalletPayableBalanceController.java

@@ -0,0 +1,61 @@
+package com.sckw.payment.controller;
+
+import com.github.pagehelper.PageInfo;
+import com.sckw.core.model.enums.EntTypeEnum;
+import com.sckw.core.web.context.LoginEntHolder;
+import com.sckw.core.web.response.BaseResult;
+import com.sckw.core.web.response.result.PageDataResult;
+import com.sckw.payment.pojo.vo.req.WalletPayableBalanceQuery;
+import com.sckw.payment.pojo.vo.res.WalletPayableBalanceRes;
+import com.sckw.payment.service.IWalletPayableBalanceService;
+import io.swagger.v3.oas.annotations.Operation;
+import io.swagger.v3.oas.annotations.tags.Tag;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.validation.annotation.Validated;
+import org.springframework.web.bind.annotation.PostMapping;
+import org.springframework.web.bind.annotation.RequestBody;
+import org.springframework.web.bind.annotation.RequestMapping;
+import org.springframework.web.bind.annotation.RestController;
+
+import java.util.Collections;
+
+
+/**
+ * 待付/代收运费余额明细Controller
+ *
+ * @author tangys
+ * @since  2026-01-06 11:03:35
+ */
+@Tag(name  = "待付/代收运费余额明细")
+@RestController
+@RequestMapping("/walletPayableBalance")
+public class WalletPayableBalanceController  {
+
+
+    @Autowired
+    private IWalletPayableBalanceService walletPayableBalanceService;
+
+    /**
+     * 托运企业待付运费余额明细主页面
+     *
+     * @return ModelAndView
+     */
+
+    @Operation(summary =  "分页查询待付/代收运费余额明细列表")
+    @PostMapping("/list")
+    public BaseResult<PageDataResult<WalletPayableBalanceRes>> list(@RequestBody @Validated WalletPayableBalanceQuery query) {
+        PageInfo<WalletPayableBalanceRes> list = new PageInfo<>(Collections.emptyList());
+        String entTypes = LoginEntHolder.get().getEntTypes();
+        if(EntTypeEnum.consign(entTypes)){
+            query.setFreightType(1);
+        } else if (EntTypeEnum.carrier(entTypes)) {
+            query.setFreightType(2);
+        }else {
+            return BaseResult.success(PageDataResult.of(list));
+        }
+        list = walletPayableBalanceService.selectWalletPayableBalanceList(query);
+        return BaseResult.success(PageDataResult.of(list));
+    }
+
+
+}

+ 198 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/controller/WalletPayableController.java

@@ -0,0 +1,198 @@
+package com.sckw.payment.controller;
+
+import com.github.pagehelper.PageInfo;
+import com.sckw.core.model.enums.EntTypeEnum;
+import com.sckw.core.web.context.LoginEntHolder;
+import com.sckw.core.web.response.BaseResult;
+import com.sckw.core.web.response.result.PageDataResult;
+import com.sckw.payment.api.ContractFeignService;
+import com.sckw.payment.api.domain.req.TradeEntListQueryFeignDto;
+import com.sckw.payment.api.domain.res.TradeEntInfoResVo;
+import com.sckw.payment.pojo.vo.req.*;
+import com.sckw.payment.pojo.vo.res.*;
+import com.sckw.payment.service.IWalletPayableService;
+import io.swagger.v3.oas.annotations.Operation;
+import io.swagger.v3.oas.annotations.tags.Tag;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.validation.annotation.Validated;
+import org.springframework.web.bind.annotation.*;
+
+import java.util.Collections;
+import java.util.List;
+
+
+/**
+ * 待付/代收运费清单Controller
+ *
+ * @author tangys
+ * @since  2026-01-06 11:03:35
+ */
+@Tag(name  = "待付/代收运费清单")
+@RestController
+@RequestMapping("/walletPayable")
+public class WalletPayableController  {
+
+
+    @Autowired
+    private IWalletPayableService walletPayableService;
+
+    @Autowired
+    private ContractFeignService contractFeignService;
+
+
+    //查询待付或代收运费的汇总接口
+    @Operation(summary =  "查询待付或代收运费的汇总接口")
+    @GetMapping("/queryPayableSummary")
+    public BaseResult<WalletPayableSummary> queryPayableSummary() {
+        WalletPayableSummary summary = new WalletPayableSummary();
+        WalletPayableQuery query = new WalletPayableQuery();
+        query.setCurEntId(LoginEntHolder.getEntId());
+        String entTypes = LoginEntHolder.get().getEntTypes();
+        if(EntTypeEnum.consign(entTypes)){
+            query.setFreightType(1);
+        } else if (EntTypeEnum.carrier(entTypes)) {
+            query.setFreightType(2);
+        }else{
+            return BaseResult.success(summary);
+        }
+        summary = walletPayableService.selectPayableSummary(query);
+        return BaseResult.success(summary);
+    }
+
+    /**
+     * 待付运费清单主页面
+     *
+     * @return ModelAndView
+     */
+
+    @Operation(summary =  "分页查询待付运/代收费清单列表")
+    @PostMapping("/payableList")
+    public BaseResult<PageDataResult<WalletPayableRes>> payableList(@RequestBody @Validated WalletPayableQuery query) {
+        PageInfo<WalletPayableRes> list = new PageInfo<>(Collections.emptyList());
+        String entTypes = LoginEntHolder.get().getEntTypes();
+        if(EntTypeEnum.consign(entTypes)){
+            query.setFreightType(1);
+        } else if (EntTypeEnum.carrier(entTypes)) {
+            query.setFreightType(2);
+        }else {
+            return BaseResult.success(PageDataResult.of(list));
+        }
+        list = walletPayableService.selectWalletPayableList(query);
+        return BaseResult.success(PageDataResult.of(list));
+    }
+
+    /**
+     * 根据当前企业id查询采购合同对方企业id列表
+     */
+    @Operation(summary =  "查询交易对方企业列表")
+    @GetMapping("/queryTradeEntList")
+    public BaseResult<List<TradeEntInfoResVo>> queryTradeEntIds(){
+        TradeEntListQueryFeignDto queryFeignDto = new TradeEntListQueryFeignDto();
+        queryFeignDto.setCurEntId(LoginEntHolder.getEntId());
+        String entTypes = LoginEntHolder.get().getEntTypes();
+        if(EntTypeEnum.consign(entTypes)){
+            queryFeignDto.setTradeEntType(4);
+        } else if (EntTypeEnum.carrier(entTypes)) {
+            queryFeignDto.setTradeEntType(3);
+        }else {
+            return BaseResult.success(Collections.emptyList());
+        }
+        return BaseResult.success(contractFeignService.queryPayableTradeEntIds(queryFeignDto).getData());
+    }
+
+
+    /**
+     * 人工录入
+     *
+     * @return ModelAndView
+     */
+
+    @Operation(summary =  "人工录入")
+    @PostMapping("/manualEntry")
+    public BaseResult<Object> manualEntry(@RequestBody @Validated WalletPayableManualDto payableManualDto) {
+        String entTypes = LoginEntHolder.get().getEntTypes();
+        if(!entTypes.contains(String.valueOf(EntTypeEnum.LOGISTIC.getCode()))) {
+            return BaseResult.failed("当前用户非物流商,无法进行此操作");
+        }
+        return toAjax(walletPayableService.manualEntry(payableManualDto));
+    }
+
+
+
+    @Operation(summary =  "物流合同创建成功,初始化运费清单")
+    @PostMapping("/initPayable")
+    public BaseResult<Object> initPayable(@RequestBody @Validated WalletPayableDto payableAddDto) {
+        walletPayableService.initPayable(payableAddDto);
+        return BaseResult.success();
+    }
+
+    /**
+     * 运费冻结、解冻、消费类接口
+     * @param payableUpdateDto
+     * @return
+     */
+    @Operation(summary =  "运费冻结、解冻、消费")
+    @PostMapping("/updatePayable")
+    public BaseResult<Object> updatePayable(@RequestBody @Validated WalletPayableDto payableUpdateDto) {
+        walletPayableService.updatePayable(payableUpdateDto);
+        return BaseResult.success();
+    }
+
+    /**
+     * 申请付款
+     *
+     * @return ModelAndView
+     */
+
+
+    @Operation(summary = "申请付款")
+    @PostMapping("/applyPay")
+    public BaseResult<Object> applyPay(@RequestBody @Validated WalletPayableApplyPayDto applyPayDto) {
+        return toAjax(walletPayableService.applyPay(applyPayDto));
+    }
+
+    /**
+     * 查询申请付款记录列表
+     */
+    @Operation(summary = "查询申请付款记录列表")
+    @PostMapping("/applyPayList")
+    public BaseResult<List<WalletPayableApplyRes>> applyPayList(@RequestBody @Validated WalletPayableApplyQuery query) {
+        List<WalletPayableApplyRes> payableApplyRes = walletPayableService.applyPayList(query);
+        return BaseResult.success(payableApplyRes);
+    }
+
+    /**
+     * 运费确认付款
+     *
+     */
+    @Operation(summary = "运费确认付款")
+    @PostMapping("/confirmPay")
+    public BaseResult<WalletPayAddRes> confirmPay(@RequestBody @Validated WalletPayableConfirmPayDto confirmPayDto) {
+        return  walletPayableService.confirmPay(confirmPayDto);
+    }
+
+    @Operation(description = "分页查询运费支付记录列表")
+    @PostMapping("/payList")
+    public BaseResult<PageDataResult<WalletPayablePayRes>> list(@RequestBody @Validated WalletPayablePayQuery query) {
+        PageInfo<WalletPayablePayRes> list = walletPayableService.selectWalletPayablePayList(query);
+        return BaseResult.success(PageDataResult.of(list));
+    }
+
+    @Operation(summary = "付款")
+    @GetMapping("/getPayInfo")
+    public BaseResult<WalletPayAddRes> getPayInfo(@RequestParam("id") Long id) {
+        return walletPayableService.getPayInfo(id);
+    }
+
+    /**
+     * 运费到账回调接口
+     */
+    @Operation(summary = "运费到账回调接口")
+    @PostMapping("/receivedCallback")
+    public BaseResult<Object> receivedCallback(@RequestBody @Validated ReceivedCallbackDto receivedCallbackDto) {
+        walletPayableService.receivedCallback(receivedCallbackDto);
+        return BaseResult.success();
+    }
+
+
+}

+ 58 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/controller/WalletPrepaidBalanceController.java

@@ -0,0 +1,58 @@
+package com.sckw.payment.controller;
+
+import com.github.pagehelper.PageInfo;
+import com.sckw.core.model.enums.EntTypeEnum;
+import com.sckw.core.web.context.LoginEntHolder;
+import com.sckw.core.web.response.BaseResult;
+import com.sckw.core.web.response.result.PageDataResult;
+import com.sckw.payment.pojo.vo.req.WalletPrepaidBalanceQuery;
+import com.sckw.payment.pojo.vo.res.WalletPrepaidBalanceRes;
+import com.sckw.payment.service.IWalletPrepaidBalanceService;
+import io.swagger.v3.oas.annotations.Operation;
+import io.swagger.v3.oas.annotations.tags.Tag;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.validation.annotation.Validated;
+import org.springframework.web.bind.annotation.PostMapping;
+import org.springframework.web.bind.annotation.RequestBody;
+import org.springframework.web.bind.annotation.RequestMapping;
+import org.springframework.web.bind.annotation.RestController;
+
+import java.util.Collections;
+
+
+/**
+ * 待履约/预付余额明细Controller
+ *
+ * @author tangys
+ * @since  2026-01-06 11:03:35
+ */
+@Tag(name  = "待履约/预付余额明细")
+@RestController
+@RequestMapping("/walletPrepaidBalance")
+public class WalletPrepaidBalanceController  {
+
+
+    @Autowired
+    private IWalletPrepaidBalanceService walletPrepaidBalanceService;
+
+    /**
+     * 分页查询企业待履约/预付余额明细列表
+     *
+     */
+
+    @Operation(summary =  "分页查询企业待履约/预付余额明细列表")
+    @PostMapping("/prepaidBalanceList")
+    public BaseResult<PageDataResult<WalletPrepaidBalanceRes>> prepaidBalanceList(@RequestBody @Validated WalletPrepaidBalanceQuery query) {
+        PageInfo<WalletPrepaidBalanceRes> list = new PageInfo<>(Collections.emptyList());
+        String entTypes = LoginEntHolder.get().getEntTypes();
+        if(entTypes.contains(String.valueOf(EntTypeEnum.SUPPLIER.getCode()))){
+            query.setEntType(EntTypeEnum.SUPPLIER.getCode());
+        }else if(entTypes.contains(String.valueOf(EntTypeEnum.PURCHASER.getCode()))){
+            query.setEntType(EntTypeEnum.PURCHASER.getCode());
+        }else{
+            return BaseResult.success(PageDataResult.of(list));
+        }
+        list = walletPrepaidBalanceService.selectWalletPrepaidBalanceList(query);
+        return BaseResult.success(PageDataResult.of(list));
+    }
+}

+ 206 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/controller/WalletPrepaidController.java

@@ -0,0 +1,206 @@
+package com.sckw.payment.controller;
+
+import com.github.pagehelper.PageInfo;
+import com.sckw.contract.api.model.dto.res.TradeEntInfoResVo;
+import com.sckw.core.model.enums.EntTypeEnum;
+import com.sckw.core.web.context.LoginEntHolder;
+import com.sckw.core.web.response.BaseResult;
+import com.sckw.core.web.response.result.PageDataResult;
+import com.sckw.payment.entity.WalletPrepaid;
+import com.sckw.payment.pojo.vo.req.*;
+import com.sckw.payment.pojo.vo.res.*;
+import com.sckw.payment.service.IWalletPrepaidService;
+import io.swagger.v3.oas.annotations.Operation;
+import io.swagger.v3.oas.annotations.tags.Tag;
+import jakarta.servlet.http.HttpServletResponse;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.validation.annotation.Validated;
+import org.springframework.web.bind.annotation.*;
+
+import java.math.BigDecimal;
+import java.util.Collections;
+import java.util.List;
+
+
+/**
+ * 待履约/预付清单Controller
+ *
+ * @author tangys
+ * @since 2026-01-06 11:03:35
+ */
+@Tag(name = "待履约/预付清单")
+@RestController
+@RequestMapping("/walletPrepaid")
+public class WalletPrepaidController  {
+
+
+    @Autowired
+    private IWalletPrepaidService walletPrepaidService;
+
+    /**
+     * 查询财务报表数据
+     */
+    @Operation(summary = "查询财务报表数据")
+    @PostMapping("/queryFinancialReport")
+    public BaseResult<List<FinancialReportRes>> queryFinancialReport(@RequestBody @Validated WalletPrepaidBalanceQuery query) {
+        List<FinancialReportRes> reportList = walletPrepaidService.queryFinancialReport(query);
+        return BaseResult.success(reportList);
+    }
+
+    /**
+     * 导出财务报表
+     */
+    @Operation(summary = "导出财务报表")
+    @PostMapping("/exportFinancialReport")
+    public void exportFinancialReport(@RequestBody @Validated WalletPrepaidBalanceQuery query, HttpServletResponse response) {
+        walletPrepaidService.exportFinancialReport(query, response);
+    }
+
+    //查询待履约或预付的汇总接口
+    @Operation(summary = "查询待履约或预付的汇总接口")
+    @GetMapping("/queryPrepaidSummary")
+    public BaseResult<WalletPrepaidSummary> queryPrepaidSummary() {
+        WalletPrepaidSummary summary = new WalletPrepaidSummary();
+        String entTypes = LoginEntHolder.get().getEntTypes();
+        WalletPrepaidQuery query = new WalletPrepaidQuery();
+        query.setCurEntId(LoginEntHolder.getEntId());
+        if (entTypes.contains(String.valueOf(EntTypeEnum.SUPPLIER.getCode()))) {
+            query.setEntType(EntTypeEnum.SUPPLIER.getCode());
+        } else if (entTypes.contains(String.valueOf(EntTypeEnum.PURCHASER.getCode()))) {
+            query.setEntType(EntTypeEnum.PURCHASER.getCode());
+        } else {
+            return BaseResult.success(summary);
+        }
+        summary = walletPrepaidService.selectWalletPrepaidSummary(query);
+        return BaseResult.success(summary);
+    }
+
+    /**
+     * 分页查询待履约/预付清单列表
+     */
+
+    @Operation(summary = "分页查询待履约/预付清单列表")
+    @PostMapping("/prepaidList")
+    public BaseResult<PageDataResult<WalletPrepaidRes>> prepaidList(@RequestBody @Validated WalletPrepaidQuery query) {
+        PageInfo<WalletPrepaidRes> list = new PageInfo<>(Collections.emptyList());
+        String entTypes = LoginEntHolder.get().getEntTypes();
+        if (entTypes.contains(String.valueOf(EntTypeEnum.SUPPLIER.getCode()))) {
+            query.setEntType(EntTypeEnum.SUPPLIER.getCode());
+        } else if (entTypes.contains(String.valueOf(EntTypeEnum.PURCHASER.getCode()))) {
+            query.setEntType(EntTypeEnum.PURCHASER.getCode());
+        } else {
+            return BaseResult.success(PageDataResult.of(list));
+        }
+
+        list = walletPrepaidService.selectWalletPrepaidList(query);
+        return BaseResult.success(PageDataResult.of(list));
+    }
+
+    /**
+     * 查询采购企业在对应供应企业的预付余额
+     */
+
+    @Operation(summary = "查询采购企业在对应供应企业的预付余额")
+    @GetMapping("/queryPrepaidBalance")
+    public BaseResult<BigDecimal> queryPrepaidBalance(@RequestParam("supEntId") Long supEntId) {
+        WalletPrepaid prepaid = walletPrepaidService.queryPrepaidBalance(supEntId);
+        BigDecimal preBalance = BigDecimal.ZERO;
+        if (prepaid != null) {
+            preBalance = prepaid.getPreBalance();
+        }
+        return BaseResult.success(preBalance);
+    }
+
+
+    @Operation(summary = "贸易合同创建成功,初始化预付清单")
+    @PostMapping("/initPrepaidBalance")
+    public BaseResult<Object> initPrepaidBalance(@RequestBody @Validated WalletPrepaidDto prepaidDto) {
+        walletPrepaidService.initPrepaidBalance(prepaidDto);
+        return BaseResult.success();
+    }
+
+    /**
+     * 预付清单冻结、解冻、消费接口
+     *
+     * @param prepaidDto
+     * @return
+     */
+    @Operation(summary = "预付清单冻结、解冻、消费接口")
+    @PostMapping("/updatePrepaidBalance")
+    BaseResult<Boolean> updatePrepaidBalance(@RequestBody WalletPrepaidDto prepaidDto) {
+        walletPrepaidService.updatePrepaidBalance(prepaidDto);
+        return BaseResult.success();
+    }
+
+    /**
+     * 根据当前企业id查询采购合同对方企业id列表
+     */
+    @Operation(summary = "查询交易对方企业列表")
+    @GetMapping("/queryTradeEntList")
+    public BaseResult<List<TradeEntInfoResVo>> queryTradeEntIds() {
+        return BaseResult.success(walletPrepaidService.queryPrepaidTradeEntIds());
+    }
+
+    /**
+     * 人工录入
+     *
+     * @return ModelAndView
+     */
+
+    @Operation(summary = "人工录入")
+    @PostMapping("/manualEntry")
+    public BaseResult<Object> manualEntry(@RequestBody @Validated WalletPrepaidManualDto performanceAddDto) {
+        String entTypes = LoginEntHolder.get().getEntTypes();
+        if (!entTypes.contains(String.valueOf(EntTypeEnum.SUPPLIER.getCode()))) {
+            return BaseResult.failed("当前用户非供应商,无法进行此操作");
+        }
+        return BaseResult.success(walletPrepaidService.manualEntry(performanceAddDto));
+    }
+
+    /**
+     * 预付
+     *
+     * @return ModelAndView
+     */
+
+
+    @Operation(summary = "预付")
+    @PostMapping("/prepay")
+    public BaseResult<WalletPayAddRes> prepay(@RequestBody @Validated WalletPrepaidAddDto prepaidAddDto) {
+        return walletPrepaidService.insertWalletPrepaidRecord(prepaidAddDto);
+    }
+
+
+    @Operation(summary = "分页查询预付支付记录列表")
+    @PostMapping("/prepayList")
+    public BaseResult<PageDataResult<WalletPrepaidRecordRes>> list(@RequestBody @Validated WalletPrepaidRecordQuery query) {
+        PageInfo<WalletPrepaidRecordRes> list = walletPrepaidService.selectWalletPrepaidRecordList(query);
+        return BaseResult.success(PageDataResult.of(list));
+    }
+
+    @Operation(summary = "付款")
+    @GetMapping("/getPayInfo")
+    public BaseResult<WalletPayAddRes> getPayInfo(@RequestParam("id") Long id) {
+        return walletPrepaidService.getPayInfo(id);
+    }
+
+    /**
+     * 预付到账回调接口
+     */
+    @Operation(summary = "预付到账回调接口")
+    @PostMapping("/receivedCallback")
+    public BaseResult<Object> receivedCallback(@RequestBody @Validated ReceivedCallbackDto receivedCallbackDto) {
+        walletPrepaidService.receivedCallback(receivedCallbackDto);
+        return BaseResult.success();
+    }
+
+    /**
+     * BI大屏预付余额:系统内所有供应商的待履约金额汇总
+     */
+    @Operation(summary = "BI大屏预付余额")
+    @GetMapping("/queryAllSupplierPrepaidSummary")
+    public BaseResult<BigDecimal> queryAllSupplierPrepaidSummary() {
+        BigDecimal summary = walletPrepaidService.selectAllSupplierPrepaidSummary();
+        return BaseResult.success(summary);
+    }
+}

+ 151 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/entity/KwpWallet.java

@@ -0,0 +1,151 @@
+package com.sckw.payment.entity;
+
+import com.baomidou.mybatisplus.annotation.IdType;
+import com.baomidou.mybatisplus.annotation.TableField;
+import com.baomidou.mybatisplus.annotation.TableId;
+import com.baomidou.mybatisplus.annotation.TableName;
+import io.swagger.v3.oas.annotations.media.Schema;
+import lombok.Data;
+
+import java.time.LocalDateTime;
+
+/**
+ * 钱包表
+ *
+ * @author xucaiqin
+ * @date 2026-03-26 14:33:23
+ */
+@Schema(description = "钱包表")
+@Data
+@TableName(value = "kwp_wallet")
+public class KwpWallet {
+    /**
+     * 主键
+     */
+    @TableId(value = "id", type = IdType.AUTO)
+    @Schema(description = "主键")
+    private Long id;
+
+    /**
+     * 企业id
+     */
+    @TableField(value = "ent_id")
+    @Schema(description = "企业id")
+    private Long entId;
+
+    /**
+     * uid
+     */
+    @TableField(value = "`uid`")
+    @Schema(description = "uid")
+    private String uid;
+
+    /**
+     * 企业类型 1供应商,2采购商 3物流
+     */
+    @TableField(value = "ent_type")
+    @Schema(description = "企业类型")
+    private Integer entType;
+
+    /**
+     * 提现金额
+     */
+    @TableField(value = "cash_amount")
+    @Schema(description = "提现金额")
+    private Long cashAmount;
+
+    /**
+     * 预付余额
+     */
+    @TableField(value = "prepay_amount")
+    @Schema(description = "预付余额")
+    private Long prepayAmount;
+
+    /**
+     * 交易中金额
+     */
+    @TableField(value = "dealing_amount")
+    @Schema(description = "交易中金额")
+    private Long dealingAmount;
+
+    /**
+     * 运费金额
+     */
+    @TableField(value = "freight_amount")
+    @Schema(description = "运费金额")
+    private Long freightAmount;
+
+    /**
+     * 进行中金额
+     */
+    @TableField(value = "processing_amount")
+    @Schema(description = "进行中金额")
+    private Long processingAmount;
+
+    /**
+     * 付款中金额
+     */
+    @TableField(value = "paying_amount")
+    @Schema(description = "付款中金额")
+    private Long payingAmount;
+
+    /**
+     * 渠道
+     */
+    @TableField(value = "channel")
+    @Schema(description = "渠道")
+    private String channel;
+
+    /**
+     * 状态 1-开户中 2-开户成功
+     */
+    @TableField(value = "`status`")
+    @Schema(description = "状态 1-开户中 2-开户成功")
+    private Integer status;
+
+    @Schema(description = "预付直提 1-否 2-是")
+    @TableField(value = "cash_flag")
+    private Integer cashFlag;
+
+    /**
+     * 备注
+     */
+    @TableField(value = "remark")
+    @Schema(description = "备注")
+    private String remark;
+
+    /**
+     * 创建人
+     */
+    @TableField(value = "create_by")
+    @Schema(description = "创建人")
+    private Long createBy;
+
+    /**
+     * 创建时间
+     */
+    @TableField(value = "create_time")
+    @Schema(description = "创建时间")
+    private LocalDateTime createTime;
+
+    /**
+     * 更新人
+     */
+    @TableField(value = "update_by")
+    @Schema(description = "更新人")
+    private Long updateBy;
+
+    /**
+     * 更新时间
+     */
+    @TableField(value = "update_time")
+    @Schema(description = "更新时间")
+    private LocalDateTime updateTime;
+
+    /**
+     * 0-正常 1-删除
+     */
+    @TableField(value = "del_flag")
+    @Schema(description = "0-正常 1-删除")
+    private Integer delFlag;
+}

+ 126 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/entity/KwpWalletCash.java

@@ -0,0 +1,126 @@
+package com.sckw.payment.entity;
+
+import com.baomidou.mybatisplus.annotation.IdType;
+import com.baomidou.mybatisplus.annotation.TableField;
+import com.baomidou.mybatisplus.annotation.TableId;
+import com.baomidou.mybatisplus.annotation.TableName;
+import io.swagger.v3.oas.annotations.media.Schema;
+import lombok.Data;
+
+import java.time.LocalDateTime;
+
+/**
+ * 提现记录表
+ *
+ * @author xucaiqin
+ * @date 2026-03-26 14:32:05
+ */
+@Schema(description = "提现记录表")
+@Data
+@TableName(value = "kwp_wallet_cash")
+public class KwpWalletCash {
+    /**
+     * 主键
+     */
+    @TableId(value = "id", type = IdType.AUTO)
+    @Schema(description = "主键")
+    private Long id;
+
+    /**
+     * 付款方 对方企业,可空
+     */
+    @TableField(value = "from_ent")
+    @Schema(description = "付款方")
+    private Long fromEnt;
+
+    /**
+     * 收款方 (必填)
+     */
+    @TableField(value = "to_ent")
+    @Schema(description = "收款方")
+    private Long toEnt;
+
+    /**
+     * 订单号
+     */
+    @TableField(value = "order_no")
+    @Schema(description = "订单号")
+    private String orderNo;
+
+    /**
+     * 操作 1-提现 2-预付 3-支付 3-收益
+     */
+    @TableField(value = "`action`")
+    @Schema(description = "操作 1-提现 2-预付 3-支付 3-收益")
+    private Integer action;
+
+    /**
+     * 交易金额
+     */
+    @TableField(value = "amount")
+    @Schema(description = "交易金额")
+    private Long amount;
+
+    /**
+     * 可提现金额
+     */
+    @TableField(value = "cash_amount")
+    @Schema(description = "可提现金额")
+    private Long cashAmount;
+
+    /**
+     * 凭证
+     */
+    @TableField(value = "img")
+    @Schema(description = "凭证")
+    private String img;
+
+    /**
+     * 备注
+     */
+    @TableField(value = "remark")
+    @Schema(description = "备注")
+    private String remark;
+
+    /**
+     * 状态 1-成功 2-失败 3-提现中
+     */
+    @TableField(value = "`status`")
+    @Schema(description = "状态")
+    private Integer status;
+
+    /**
+     * 创建人
+     */
+    @TableField(value = "create_by")
+    @Schema(description = "创建人")
+    private Long createBy;
+
+    /**
+     * 创建时间
+     */
+    @TableField(value = "create_time")
+    @Schema(description = "创建时间")
+    private LocalDateTime createTime;
+
+    /**
+     * 更新人
+     */
+    @TableField(value = "update_by")
+    @Schema(description = "更新人")
+    private Long updateBy;
+
+    /**
+     * 更新时间
+     */
+    @TableField(value = "update_time")
+    @Schema(description = "更新时间")
+    private LocalDateTime updateTime;
+
+    /**
+     * 0-正常 1-删除
+     */
+    @TableField(value = "del_flag")
+    @Schema(description = "0-正常 1-删除")
+    private Integer delFlag;
+}

+ 124 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/entity/KwpWalletSplit.java

@@ -0,0 +1,124 @@
+package com.sckw.payment.entity;
+
+import com.baomidou.mybatisplus.annotation.IdType;
+import com.baomidou.mybatisplus.annotation.TableField;
+import com.baomidou.mybatisplus.annotation.TableId;
+import com.baomidou.mybatisplus.annotation.TableName;
+import io.swagger.v3.oas.annotations.media.Schema;
+import lombok.Data;
+
+import java.math.BigDecimal;
+import java.time.LocalDateTime;
+
+/**
+ * 清分表
+ *
+ * @author xucaiqin
+ * @date 2026-04-08 11:25:38
+ */
+@Data
+@Schema(description = "清分表")
+@TableName(value = "kwp_wallet_split")
+public class KwpWalletSplit {
+    /**
+     * 主键
+     */
+    @TableId(value = "id", type = IdType.AUTO)
+    @Schema(description = "主键")
+    private Long id;
+
+    /**
+     * 付款方
+     */
+    @TableField(value = "from_ent")
+    @Schema(description = "付款方")
+    private Long fromEnt;
+
+    /**
+     * 收款方
+     */
+    @TableField(value = "to_ent")
+    @Schema(description = "收款方")
+    private Long toEnt;
+
+    /**
+     * 支付订单号
+     */
+    @TableField(value = "pay_order_no")
+    @Schema(description = "支付订单号")
+    private String payOrderNo;
+
+    /**
+     * 订单号
+     */
+    @TableField(value = "order_no")
+    @Schema(description = "订单号")
+    private String orderNo;
+
+    /**
+     * 操作 1-预付 2-支付
+     */
+    @TableField(value = "`action`")
+    @Schema(description = "操作 1-预付 2-支付")
+    private Integer action;
+
+    /**
+     * 交易金额
+     */
+    @TableField(value = "money")
+    @Schema(description = "交易金额")
+    private BigDecimal money;
+
+    @TableField(value = "img")
+    @Schema(description = "图片")
+    private String img;
+    /**
+     * 备注
+     */
+    @TableField(value = "remark")
+    @Schema(description = "备注")
+    private String remark;
+
+    /**
+     * 状态 1-已提交 2-清分成功 3-清分失败
+     */
+    @TableField(value = "`status`")
+    @Schema(description = "状态 1-已提交 2-清分成功 3-清分失败")
+    private Integer status;
+
+    /**
+     * 创建人
+     */
+    @TableField(value = "create_by")
+    @Schema(description = "创建人")
+    private Long createBy;
+
+    /**
+     * 创建时间
+     */
+    @TableField(value = "create_time")
+    @Schema(description = "创建时间")
+    private LocalDateTime createTime;
+
+    /**
+     * 更新人
+     */
+    @TableField(value = "update_by")
+    @Schema(description = "更新人")
+    private Long updateBy;
+
+    /**
+     * 更新时间
+     */
+    @TableField(value = "update_time")
+    @Schema(description = "更新时间")
+    private LocalDateTime updateTime;
+
+    /**
+     * 0-正常 1-删除
+     */
+    @TableField(value = "del_flag")
+    @Schema(description = "0-正常 1-删除")
+    private Integer delFlag;
+
+}

+ 80 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/entity/Wallet.java

@@ -0,0 +1,80 @@
+package com.sckw.payment.entity;
+
+import com.fasterxml.jackson.annotation.JsonFormat;
+import io.swagger.v3.oas.annotations.media.Schema;
+import lombok.Data;
+
+import java.util.Date;
+
+/**
+ * 钱包表(wallet)
+ *
+ * @author tangys
+ * @since  2026-01-06 10:28:02
+ */
+@Data
+public class Wallet {
+
+	/** id */
+    @Schema(description = "id")
+    private Long id;
+	/** 企业用户id */
+    @Schema(description = "企业用户id")
+    private Long entId;
+	/** 流水号 */
+    @Schema(description = "流水号")
+    private String tranNo;
+	/** 开户响应流水号 */
+    @Schema(description = "开户响应流水号")
+    private String openacctNo;
+	/** 新网用户id */
+    @Schema(description = "新网用户id")
+    private String customerNo;
+	/** 认证id */
+    @Schema(description = "认证id")
+    private String authId;
+	/** 结算账户 */
+    @Schema(description = "结算账户")
+    private String settleAcct;
+	/** 余额账户 */
+    @Schema(description = "余额账户")
+    private String balanceAcct;
+	/** 免密账户 */
+    @Schema(description = "免密账户")
+    private String unPwdAcct;
+	/** 企业对公户开户行名 */
+    @Schema(description = "企业对公户开户行名")
+    private String bankName;
+	/** 企业对公户开户行号 */
+    @Schema(description = "企业对公户开户行号")
+    private String bankCode;
+	/** 企业对公账户号 */
+    @Schema(description = "企业对公账户号")
+    private String bankCardNo;
+	/** 中台通知地址 */
+    @Schema(description = "中台通知地址")
+    private String noticeUrl;
+	/** 中台通知状态 1-未通知 2-通知成功 3-通知失败 */
+    @Schema(description = "中台通知状态 1-未通知 2-通知成功 3-通知失败")
+    private Integer noticeFlag;
+	/** 审核状态 1-提交信息 2-小额验证 3-人工审核 4-联系人认证 5-法人认证 6-开户成功 7-开户失败 */
+    @Schema(description = "审核状态 1-提交信息 2-小额验证 3-人工审核 4-联系人认证 5-法人认证 6-开户成功 7-开户失败")
+    private Integer auditFlag;
+	/** 备注 */
+    @Schema(description = "备注")
+    private String remark;
+	/** 结算授权状态 0-待提交 1-提交申请 2-审核通过 3-审核失败 */
+    @Schema(description = "结算授权状态 0-待提交 1-提交申请 2-审核通过 3-审核失败")
+    private Integer settleFlag;
+	/** 创建时间 */
+    @Schema(description = "创建时间")
+    @JsonFormat(timezone = "GMT+8", pattern = "yyyy-MM-dd HH:mm:ss")
+    private Date createTime;
+	/** 更新时间 */
+    @Schema(description = "更新时间")
+    @JsonFormat(timezone = "GMT+8", pattern = "yyyy-MM-dd HH:mm:ss")
+    private Date updateTime;
+	/** 删除标识 0-正常 1-删除 */
+    @Schema(description = "删除标识 0-正常 1-删除")
+    private Integer delFlag;
+}

+ 63 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/entity/WalletAccount.java

@@ -0,0 +1,63 @@
+package com.sckw.payment.entity;
+
+import com.fasterxml.jackson.annotation.JsonFormat;
+import io.swagger.v3.oas.annotations.media.Schema;
+import lombok.Data;
+
+import java.math.BigDecimal;
+import java.util.Date;
+
+/**
+ * 钱包账户表(wallet_account)
+ *
+ * @author tangys
+ * @since  2026-01-06 10:28:02
+ */
+@Data
+public class WalletAccount {
+
+	/** 主键id */
+    @Schema(description = "主键id")
+    private Long id;
+	/** 企业ID,一个企业一个钱包 */
+    @Schema(description = "企业ID,一个企业一个钱包")
+    private Long entId;
+	/** 银行侧提现钱包编号 */
+    @Schema(description = "银行侧提现钱包编号")
+    private String bWithdrawWalletNo;
+	/** 银行侧冻结钱包编号 */
+    @Schema(description = "银行侧冻结钱包编号")
+    private String bFreezeWalletNo;
+	/** 可用余额 */
+    @Schema(description = "可用余额")
+    private BigDecimal availableBalance;
+	/** 冻结余额 */
+    @Schema(description = "冻结余额")
+    private BigDecimal frozenBalance;
+	/** 版本号(用于乐观锁) */
+    @Schema(description = "版本号(用于乐观锁)")
+    private Integer version;
+	/** 钱包状态0-初始化 1-正常 2-冻结 3-注销 */
+    @Schema(description = "钱包状态0-初始化 1-正常 2-冻结 3-注销")
+    private Integer status;
+	/** 备注 */
+    @Schema(description = "备注")
+    private String remark;
+	/** 删除标记(0-未删除,1-已删除) */
+    @Schema(description = "删除标记(0-未删除,1-已删除)")
+    private Integer delFlag;
+	/** 创建人id */
+    @Schema(description = "创建人id")
+    private Long createBy;
+	/** 创建时间 */
+    @Schema(description = "创建时间")
+    @JsonFormat(timezone = "GMT+8", pattern = "yyyy-MM-dd HH:mm:ss")
+    private Date createTime;
+	/** 更新人id */
+    @Schema(description = "更新人id")
+    private Long updateBy;
+	/** 更新时间 */
+    @Schema(description = "更新时间")
+    @JsonFormat(timezone = "GMT+8", pattern = "yyyy-MM-dd HH:mm:ss")
+    private Date updateTime;
+}

+ 87 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/entity/WalletBalance.java

@@ -0,0 +1,87 @@
+package com.sckw.payment.entity;
+
+import com.fasterxml.jackson.annotation.JsonFormat;
+import io.swagger.v3.oas.annotations.media.Schema;
+import lombok.Data;
+
+import java.math.BigDecimal;
+import java.util.Date;
+
+/**
+ * 钱包余额明细表(wallet_balance)
+ *
+ * @author tangys
+ * @since  2026-01-12 16:24:22
+ */
+@Data
+public class WalletBalance {
+
+	/** 明细主键 */
+    @Schema(description = "明细主键")
+    private Long id;
+	/** 关联订单编号 */
+    @Schema(description = "关联订单编号")
+    private String orderNo;
+	/** 关联订单类型 1-充值订单 2-预付订单 3-提现订单 4-贸易订单 5-物流订单 */
+    @Schema(description = "关联订单类型 1-充值订单 2-预付订单 3-提现订单 4-贸易订单 5-物流订单")
+    private Integer orderType;
+	/** 企业id */
+    @Schema(description = "企业id")
+    private Long entId;
+	/** 对方企业id */
+    @Schema(description = "对方企业id")
+    private Long tradeEntId;
+	/** 交易类型 1-充值 2-预付 3-收益 4-冻结 5-解冻 6-消费 7-提现 8-支付 */
+    @Schema(description = "交易类型 1-充值 2-预付 3-收益 4-冻结 5-解冻 6-消费 7-提现 8-支付")
+    private Integer tradeType;
+	/** 交易金额 */
+    @Schema(description = "交易金额")
+    private BigDecimal tradeAmount;
+	/** 银行交易流水号 */
+    @Schema(description = "银行交易流水号")
+    private String bankSerialNo;
+	/** 变动前可用余额 */
+    @Schema(description = "变动前可用余额")
+    private BigDecimal availableBefore;
+	/** 变动后可用余额 */
+    @Schema(description = "变动后可用余额")
+    private BigDecimal availableAfter;
+	/** 变动前冻结余额 */
+    @Schema(description = "变动前冻结余额")
+    private BigDecimal frozenBefore;
+	/** 变动后冻结余额 */
+    @Schema(description = "变动后冻结余额")
+    private BigDecimal frozenAfter;
+	/** 可用预付余额 */
+    @Schema(description = "可用预付余额")
+    private BigDecimal availablePrepaid;
+	/** 对方预付余额 */
+    @Schema(description = "对方预付余额")
+    private BigDecimal counterpartyPrepaid;
+	/** 执行状态 1-进行中 2-成功 3-失败 */
+    @Schema(description = "执行状态 1-进行中 2-成功 3-失败")
+    private Integer status;
+	/** 备注 */
+    @Schema(description = "备注")
+    private String remark;
+	/** 凭证标识 0-无凭证 1-有凭证 */
+    @Schema(description = "凭证标识 0-无凭证 1-有凭证")
+    private Integer voucherFlag;
+	/** 删除标识 0-未删除 1-已删除 */
+    @Schema(description = "删除标识 0-未删除 1-已删除")
+    private Integer delFlag;
+	/** 创建人id */
+    @Schema(description = "创建人id")
+    private Long createBy;
+	/** 创建时间 */
+    @Schema(description = "创建时间")
+    @JsonFormat(timezone = "GMT+8", pattern = "yyyy-MM-dd HH:mm:ss")
+    private Date createTime;
+	/** 更新人id */
+    @Schema(description = "更新人id")
+    private Long updateBy;
+	/** 更新时间 */
+    @Schema(description = "更新时间")
+    @JsonFormat(timezone = "GMT+8", pattern = "yyyy-MM-dd HH:mm:ss")
+    private Date updateTime;
+}

+ 40 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/entity/WalletBankCallback.java

@@ -0,0 +1,40 @@
+package com.sckw.payment.entity;
+
+import com.fasterxml.jackson.annotation.JsonFormat;
+import io.swagger.v3.oas.annotations.media.Schema;
+import lombok.Data;
+
+import java.util.Date;
+
+/**
+ * 银行回调日志表(wallet_bank_callback)
+ *
+ * @author tangys
+ * @since  2026-01-06 10:28:02
+ */
+@Data
+public class WalletBankCallback {
+
+	/** 主键ID */
+    @Schema(description = "主键ID")
+    private Long id;
+	/** 关联业务单号 */
+    @Schema(description = "关联业务单号")
+    private String bizNo;
+	/** 回调类型,1-充值 2-提现 */
+    @Schema(description = "回调类型,1-充值 2-提现")
+    private Integer callbackType;
+	/** 银行原始回调内容 */
+    @Schema(description = "银行原始回调内容")
+    private String rawContent;
+	/** 备注 */
+    @Schema(description = "备注")
+    private String remark;
+	/** 处理状态:0-待处理 1-已处理 */
+    @Schema(description = "处理状态:0-待处理 1-已处理")
+    private Integer status;
+	/** 创建时间 */
+    @Schema(description = "创建时间")
+    @JsonFormat(timezone = "GMT+8", pattern = "yyyy-MM-dd HH:mm:ss")
+    private Date createdAt;
+}

+ 43 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/entity/WalletBankRequest.java

@@ -0,0 +1,43 @@
+package com.sckw.payment.entity;
+
+import com.fasterxml.jackson.annotation.JsonFormat;
+import io.swagger.v3.oas.annotations.media.Schema;
+import lombok.Data;
+
+import java.util.Date;
+
+/**
+ * 银行请求响应表(wallet_bank_request)
+ *
+ * @author tangys
+ * @since  2026-01-06 10:28:02
+ */
+@Data
+public class WalletBankRequest {
+
+	/** 主键ID */
+    @Schema(description = "主键ID")
+    private Long id;
+	/** 业务类型 */
+    @Schema(description = "业务类型")
+    private String bizType;
+	/** 关联业务单号 */
+    @Schema(description = "关联业务单号")
+    private String bizNo;
+	/** 银行请求内容 */
+    @Schema(description = "银行请求内容")
+    private String resquestContent;
+	/** 银行响应内容 */
+    @Schema(description = "银行响应内容")
+    private String responseContent;
+	/** 备注 */
+    @Schema(description = "备注")
+    private String remark;
+	/** 处理状态:0-成功 1-失败 */
+    @Schema(description = "处理状态:0-成功 1-失败")
+    private Integer status;
+	/** 创建时间 */
+    @Schema(description = "创建时间")
+    @JsonFormat(timezone = "GMT+8", pattern = "yyyy-MM-dd HH:mm:ss")
+    private Date createdAt;
+}

+ 50 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/entity/WalletBusinessFile.java

@@ -0,0 +1,50 @@
+package com.sckw.payment.entity;
+
+import com.fasterxml.jackson.annotation.JsonFormat;
+import io.swagger.v3.oas.annotations.media.Schema;
+import lombok.Data;
+
+import java.util.Date;
+
+/**
+ * 钱包_业务文件(wallet_business_file)
+ *
+ * @author tangys
+ * @since  2026-01-12 14:11:22
+ */
+@Data
+public class WalletBusinessFile {
+
+	/** 主键 */
+    @Schema(description = "主键")
+    private Long id;
+	/** 业务id */
+    @Schema(description = "业务id")
+    private Long businessId;
+	/** 文件地址 */
+    @Schema(description = "文件地址")
+    private String filePath;
+	/** 备注 */
+    @Schema(description = "备注")
+    private String remark;
+	/** 状态:0正常/1锁定 */
+    @Schema(description = "状态:0正常/1锁定")
+    private Integer status;
+	/** 删除标识(0正常/1删除) */
+    @Schema(description = "删除标识(0正常/1删除)")
+    private Integer delFlag;
+	/** 创建人 */
+    @Schema(description = "创建人")
+    private Long createBy;
+	/** 创建时间 */
+    @Schema(description = "创建时间")
+    @JsonFormat(timezone = "GMT+8", pattern = "yyyy-MM-dd HH:mm:ss")
+    private Date createTime;
+	/** 更新人 */
+    @Schema(description = "更新人")
+    private Long updateBy;
+	/** 更新时间 */
+    @Schema(description = "更新时间")
+    @JsonFormat(timezone = "GMT+8", pattern = "yyyy-MM-dd HH:mm:ss")
+    private Date updateTime;
+}

+ 92 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/entity/WalletEntInfo.java

@@ -0,0 +1,92 @@
+package com.sckw.payment.entity;
+
+import com.fasterxml.jackson.annotation.JsonFormat;
+import io.swagger.v3.oas.annotations.media.Schema;
+import lombok.Data;
+
+import java.util.Date;
+
+/**
+ * 开户企业信息表(wallet_ent_info)
+ *
+ * @author tangys
+ * @since  2026-01-07 16:59:01
+ */
+@Data
+public class WalletEntInfo {
+
+	/** id */
+    @Schema(description = "id")
+    private Long id;
+	/** 企业用户id(外键) */
+    @Schema(description = "企业用户id(外键)")
+    private Long entId;
+	/** 企业全称 */
+    @Schema(description = "企业全称")
+    private String fullName;
+	/** 企业注册地址 */
+    @Schema(description = "企业注册地址")
+    private String address;
+	/** 营业执照号 */
+    @Schema(description = "营业执照号")
+    private String licenseCode;
+	/** 依法经营证件起始日期 */
+    @Schema(description = "依法经营证件起始日期")
+    private String licenseStartDate;
+	/** 依法经营证件截止日期 */
+    @Schema(description = "依法经营证件截止日期")
+    private String licenseEndDate;
+	/** 企业实际经营地址 */
+    @Schema(description = "企业实际经营地址")
+    private String realAddress;
+	/** 依法经营证件正本开放平台文件id */
+    @Schema(description = "依法经营证件正本开放平台文件id")
+    private String licenseFileId;
+	/** 依法经营证件副本开放平台文件id */
+    @Schema(description = "依法经营证件副本开放平台文件id")
+    private String licenseFileDuplicateId;
+	/** 企业法人姓名 */
+    @Schema(description = "企业法人姓名")
+    private String legalName;
+	/** 企业法人证件号码 */
+    @Schema(description = "企业法人证件号码")
+    private String legalIdCardNo;
+	/** 企业法人手机号码 */
+    @Schema(description = "企业法人手机号码")
+    private String legalPhone;
+	/** 企业法人证件起始日期 */
+    @Schema(description = "企业法人证件起始日期")
+    private String legalStartDate;
+	/** 企业法人证件结束日期 */
+    @Schema(description = "企业法人证件结束日期")
+    private String legalEndDate;
+	/** 法人证件正面(人像面)开放平台文件id */
+    @Schema(description = "法人证件正面(人像面)开放平台文件id")
+    private String idCardFrontId;
+	/** 法人证件反面(国徽面)开放平台文件id */
+    @Schema(description = "法人证件反面(国徽面)开放平台文件id")
+    private String idCardBackId;
+	/** 联系人姓名 */
+    @Schema(description = "联系人姓名")
+    private String contactName;
+	/** 联系人手机号 */
+    @Schema(description = "联系人手机号")
+    private String contactPhone;
+	/** 联系人证件号码 */
+    @Schema(description = "联系人证件号码")
+    private String contactIdCardNo;
+	/** 联系人证件正面(人像面)开放平台文件id */
+    @Schema(description = "联系人证件正面(人像面)开放平台文件id")
+    private String contactIdCardFrontId;
+	/** 联系人证件反面(国徽面)开放平台文件id */
+    @Schema(description = "联系人证件反面(国徽面)开放平台文件id")
+    private String contactIdCardBackId;
+	/** 创建时间 */
+    @Schema(description = "创建时间")
+    @JsonFormat(timezone = "GMT+8", pattern = "yyyy-MM-dd HH:mm:ss")
+    private Date createTime;
+	/** 更新时间 */
+    @Schema(description = "更新时间")
+    @JsonFormat(timezone = "GMT+8", pattern = "yyyy-MM-dd HH:mm:ss")
+    private Date updateTime;
+}

+ 56 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/entity/WalletEntUser.java

@@ -0,0 +1,56 @@
+package com.sckw.payment.entity;
+
+import com.fasterxml.jackson.annotation.JsonFormat;
+import io.swagger.v3.oas.annotations.media.Schema;
+import lombok.Data;
+
+import java.util.Date;
+
+/**
+ * 企业股东或最终收益人(wallet_ent_user)
+ *
+ * @author tangys
+ * @since  2026-01-07 16:59:01
+ */
+@Data
+public class WalletEntUser {
+
+	/** id */
+    @Schema(description = "id")
+    private Long id;
+	/** 企业id */
+    @Schema(description = "企业id")
+    private Long entId;
+	/** 用户类型 1-股东 2-最终受益人 */
+    @Schema(description = "用户类型 1-股东 2-最终受益人")
+    private Integer type;
+	/** 姓名 */
+    @Schema(description = "姓名")
+    private String name;
+	/** 身份证号 */
+    @Schema(description = "身份证号")
+    private String idCardNo;
+	/** 身份证有效期起始日期 */
+    @Schema(description = "身份证有效期起始日期")
+    private String idCardStartDate;
+	/** 身份证有效期截止日期 */
+    @Schema(description = "身份证有效期截止日期")
+    private String idCardEndDate;
+	/** 电话 */
+    @Schema(description = "电话")
+    private String phone;
+	/** 地址 */
+    @Schema(description = "地址")
+    private String address;
+	/** 受益方式 */
+    @Schema(description = "受益方式")
+    private String incomeType;
+	/** 创建时间 */
+    @Schema(description = "创建时间")
+    @JsonFormat(timezone = "GMT+8", pattern = "yyyy-MM-dd HH:mm:ss")
+    private Date createTime;
+	/** 更新时间 */
+    @Schema(description = "更新时间")
+    @JsonFormat(timezone = "GMT+8", pattern = "yyyy-MM-dd HH:mm:ss")
+    private Date updateTime;
+}

+ 63 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/entity/WalletPayable.java

@@ -0,0 +1,63 @@
+package com.sckw.payment.entity;
+
+import com.fasterxml.jackson.annotation.JsonFormat;
+import io.swagger.v3.oas.annotations.media.Schema;
+import lombok.Data;
+
+import java.math.BigDecimal;
+import java.util.Date;
+
+/**
+ * 待付/代收运费清单(wallet_payable)
+ *
+ * @author tangys
+ * @since  2026-01-06 10:28:02
+ */
+@Data
+public class WalletPayable {
+
+	/** 待付/代收运费清单主键id */
+    @Schema(description = "待付/代收运费清单主键id")
+    private Long id;
+	/** 托运企业id */
+    @Schema(description = "托运企业id")
+    private Long consignEntId;
+	/** 承运企业id */
+    @Schema(description = "承运企业id")
+    private Long carrierEntId;
+	/** 待付/代收运费 */
+    @Schema(description = "待付运费")
+    private BigDecimal freight;
+	/** 进行中运费 */
+    @Schema(description = "进行中运费")
+    private BigDecimal tradingFreight;
+	/** 付款中运费 */
+    @Schema(description = "付款中运费")
+    private BigDecimal payingFreight;
+	/** 状态,待定 */
+    @Schema(description = "状态,待定")
+    private Integer status;
+	/** 备注 */
+    @Schema(description = "备注")
+    private String remark;
+	/** 删除标记 0-未删除 1-已删除 */
+    @Schema(description = "删除标记 0-未删除 1-已删除")
+    private Integer delFlag;
+	/** 创建人id */
+    @Schema(description = "创建人id")
+    private Long createBy;
+	/** 创建时间 */
+    @Schema(description = "创建时间")
+    @JsonFormat(timezone = "GMT+8", pattern = "yyyy-MM-dd HH:mm:ss")
+    private Date createTime;
+	/** 更新人id */
+    @Schema(description = "更新人id")
+    private Long updateBy;
+	/** 更新时间 */
+    @Schema(description = "更新时间")
+    @JsonFormat(timezone = "GMT+8", pattern = "yyyy-MM-dd HH:mm:ss")
+    private Date updateTime;
+
+    @Schema(description = "是否存在未完成申请付款记录,1-存在,0-不存在")
+    private Integer existsApply;
+}

+ 60 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/entity/WalletPayableApply.java

@@ -0,0 +1,60 @@
+package com.sckw.payment.entity;
+
+import com.fasterxml.jackson.annotation.JsonFormat;
+import io.swagger.v3.oas.annotations.media.Schema;
+import lombok.Data;
+
+import java.math.BigDecimal;
+import java.util.Date;
+
+/**
+ * 运费付款申请记录(wallet_freight_apply)
+ *
+ * @author tangys
+ * @since  2026-01-19 16:13:22
+ */
+@Data
+public class WalletPayableApply {
+
+	/** 运费付款申请记录主键id */
+    @Schema(description = "运费付款申请记录主键id")
+    private Long id;
+	/** 待付/代收运费清单id */
+    @Schema(description = "待付/代收运费清单id")
+    private Long payableId;
+	/** 申请订单号 */
+    @Schema(description = "申请订单号")
+    private String orderNo;
+	/** 申请金额 */
+    @Schema(description = "申请金额")
+    private BigDecimal applyAmount;
+	/** 支付中金额 */
+    @Schema(description = "支付中金额")
+    private BigDecimal payingAmount;
+    /** 到账金额 */
+    @Schema(description = "到账金额")
+    private BigDecimal receivedAmount;
+	/** 状态,0-未完成,1-已完成 */
+    @Schema(description = "状态,0-未完成,1-已完成")
+    private Integer status;
+	/** 备注 */
+    @Schema(description = "备注")
+    private String remark;
+	/** 删除标记 0-未删除 1-已删除 */
+    @Schema(description = "删除标记 0-未删除 1-已删除")
+    private Integer delFlag;
+	/** 创建人id */
+    @Schema(description = "创建人id")
+    private Long createBy;
+	/** 创建时间 */
+    @Schema(description = "创建时间")
+    @JsonFormat(timezone = "GMT+8", pattern = "yyyy-MM-dd HH:mm:ss")
+    private Date createTime;
+	/** 更新人id */
+    @Schema(description = "更新人id")
+    private Long updateBy;
+	/** 更新时间 */
+    @Schema(description = "更新时间")
+    @JsonFormat(timezone = "GMT+8", pattern = "yyyy-MM-dd HH:mm:ss")
+    private Date updateTime;
+}

+ 75 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/entity/WalletPayableBalance.java

@@ -0,0 +1,75 @@
+package com.sckw.payment.entity;
+
+import com.fasterxml.jackson.annotation.JsonFormat;
+import io.swagger.v3.oas.annotations.media.Schema;
+import lombok.Data;
+
+import java.math.BigDecimal;
+import java.util.Date;
+
+/**
+ * 待付/代收运费余额明细(wallet_payable_balance)
+ *
+ * @author tangys
+ * @since  2026-01-12 16:24:22
+ */
+@Data
+public class WalletPayableBalance {
+
+	/** 待付/代收运费余额明细主键id */
+    @Schema(description = "待付/代收运费余额明细主键id")
+    private Long id;
+	/** 关联订单编号 */
+    @Schema(description = "关联订单编号")
+    private String orderNo;
+	/** 订单类型 5-物流订单号 6-支付订单号 */
+    @Schema(description = "订单类型 5-物流订单号 6-支付订单号")
+    private Integer orderType;
+	/** 托运企业id */
+    @Schema(description = "托运企业id")
+    private Long consignEntId;
+	/** 承运企业id */
+    @Schema(description = "承运企业id")
+    private Long carrierEntId;
+	/** 交易类型 3-收益 4-冻结 5-解冻 6-消费 9-人工录入 10-申请付款 11-付款成功 */
+    @Schema(description = "交易类型 3-收益 4-冻结 5-解冻 6-消费 9-人工录入 10-申请付款 11-付款成功")
+    private Integer tradeType;
+	/** 交易金额 */
+    @Schema(description = "交易金额")
+    private BigDecimal tradeAmount;
+	/** 待付运费 */
+    @Schema(description = "待付/代收运费")
+    private BigDecimal freight;
+	/** 进行中运费 */
+    @Schema(description = "进行中运费")
+    private BigDecimal tradingFreight;
+	/** 付款中运费 */
+    @Schema(description = "付款中运费")
+    private BigDecimal payingFreight;
+	/** 执行状态,1-进行中 2-成功 3-失败 */
+    @Schema(description = "执行状态,1-进行中 2-成功 3-失败")
+    private Integer status;
+	/** 备注 */
+    @Schema(description = "备注")
+    private String remark;
+	/** 凭证标识 0-无凭证 1-有凭证 */
+    @Schema(description = "凭证标识 0-无凭证 1-有凭证")
+    private Integer voucherFlag;
+	/** 删除标记 0-未删除 1-已删除 */
+    @Schema(description = "删除标记 0-未删除 1-已删除")
+    private Integer delFlag;
+	/** 创建人id */
+    @Schema(description = "创建人id")
+    private Long createBy;
+	/** 创建时间 */
+    @Schema(description = "创建时间")
+    @JsonFormat(timezone = "GMT+8", pattern = "yyyy-MM-dd HH:mm:ss")
+    private Date createTime;
+	/** 更新人id */
+    @Schema(description = "更新人id")
+    private Long updateBy;
+	/** 更新时间 */
+    @Schema(description = "更新时间")
+    @JsonFormat(timezone = "GMT+8", pattern = "yyyy-MM-dd HH:mm:ss")
+    private Date updateTime;
+}

+ 62 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/entity/WalletPayablePay.java

@@ -0,0 +1,62 @@
+package com.sckw.payment.entity;
+
+import com.fasterxml.jackson.annotation.JsonFormat;
+import io.swagger.v3.oas.annotations.media.Schema;
+import lombok.Data;
+
+import java.math.BigDecimal;
+import java.util.Date;
+
+/**
+ * 运费支付记录(wallet_freight_record)
+ *
+ * @author tangys
+ * @since  2026-01-15 09:32:47
+ */
+@Data
+public class WalletPayablePay {
+
+	/** 运费支付记录主键id */
+    @Schema(description = "运费支付记录主键id")
+    private Long id;
+	/** 待付运费清单id */
+    @Schema(description = "待付运费清单id")
+    private Long payableId;
+    /** 申请订单号 */
+    @Schema(description = "申请订单号")
+    private String applyOrderNo;
+	/** 支付订单号 */
+    @Schema(description = "支付订单号")
+    private String orderNo;
+	/** 申请金额 */
+    @Schema(description = "申请金额")
+    private BigDecimal applyAmount;
+	/** 到账金额 */
+    @Schema(description = "到账金额")
+    private BigDecimal receivedAmount;
+    private String data;
+
+	/** 支付状态,0-等待支付,1-支付成功 */
+    @Schema(description = "支付状态,0-等待支付,1-支付成功")
+    private Integer status;
+	/** 备注 */
+    @Schema(description = "备注")
+    private String remark;
+	/** 删除标记 0-未删除 1-已删除 */
+    @Schema(description = "删除标记 0-未删除 1-已删除")
+    private Integer delFlag;
+	/** 创建人id */
+    @Schema(description = "创建人id")
+    private Long createBy;
+	/** 创建时间 */
+    @Schema(description = "创建时间")
+    @JsonFormat(timezone = "GMT+8", pattern = "yyyy-MM-dd HH:mm:ss")
+    private Date createTime;
+	/** 更新人id */
+    @Schema(description = "更新人id")
+    private Long updateBy;
+	/** 更新时间 */
+    @Schema(description = "更新时间")
+    @JsonFormat(timezone = "GMT+8", pattern = "yyyy-MM-dd HH:mm:ss")
+    private Date updateTime;
+}

+ 57 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/entity/WalletPrepaid.java

@@ -0,0 +1,57 @@
+package com.sckw.payment.entity;
+
+import com.fasterxml.jackson.annotation.JsonFormat;
+import io.swagger.v3.oas.annotations.media.Schema;
+import lombok.Data;
+
+import java.math.BigDecimal;
+import java.util.Date;
+
+/**
+ * 预付清单(wallet_prepaid)
+ *
+ * @author tangys
+ * @since  2026-01-06 10:28:02
+ */
+@Data
+public class WalletPrepaid {
+
+	/** 预付清单主键id */
+    @Schema(description = "预付清单主键id")
+    private Long id;
+	/** 采购商企业id */
+    @Schema(description = "采购商企业id")
+    private Long proEntId;
+	/** 供应商企业id */
+    @Schema(description = "供应商企业id")
+    private Long supEntId;
+	/** 预付余额 */
+    @Schema(description = "预付余额")
+    private BigDecimal preBalance;
+	/** 交易中金额 */
+    @Schema(description = "交易中金额")
+    private BigDecimal tradingAmount;
+	/** 状态,待定 */
+    @Schema(description = "状态,待定")
+    private Integer status;
+	/** 备注 */
+    @Schema(description = "备注")
+    private String remark;
+	/** 删除标记 0-未删除 1-已删除 */
+    @Schema(description = "删除标记 0-未删除 1-已删除")
+    private Integer delFlag;
+	/** 创建人id */
+    @Schema(description = "创建人id")
+    private Long createBy;
+	/** 创建时间 */
+    @Schema(description = "创建时间")
+    @JsonFormat(timezone = "GMT+8", pattern = "yyyy-MM-dd HH:mm:ss")
+    private Date createTime;
+	/** 更新人id */
+    @Schema(description = "更新人id")
+    private Long updateBy;
+	/** 更新时间 */
+    @Schema(description = "更新时间")
+    @JsonFormat(timezone = "GMT+8", pattern = "yyyy-MM-dd HH:mm:ss")
+    private Date updateTime;
+}

+ 72 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/entity/WalletPrepaidBalance.java

@@ -0,0 +1,72 @@
+package com.sckw.payment.entity;
+
+import com.fasterxml.jackson.annotation.JsonFormat;
+import io.swagger.v3.oas.annotations.media.Schema;
+import lombok.Data;
+
+import java.math.BigDecimal;
+import java.util.Date;
+
+/**
+ * 采购企业预付余额明细(wallet_prepaid_balance)
+ *
+ * @author tangys
+ * @since  2026-01-12 16:24:22
+ */
+@Data
+public class WalletPrepaidBalance {
+
+	/** 预付余额明细主键id */
+    @Schema(description = "预付余额明细主键id")
+    private Long id;
+	/** 关联订单编号 */
+    @Schema(description = "关联订单编号")
+    private String orderNo;
+	/** 订单类型 2-预付订单  4-贸易订单 */
+    @Schema(description = "订单类型 2-预付订单  4-贸易订单")
+    private Integer orderType;
+	/** 采购商企业id */
+    @Schema(description = "采购商企业id")
+    private Long proEntId;
+	/** 供应商企业id */
+    @Schema(description = "供应商企业id")
+    private Long supEntId;
+	/** 交易类型 2-预付 3-收益 4-冻结 5-解冻 6-消费 9-人工录入 */
+    @Schema(description = "交易类型 2-预付 3-收益 4-冻结 5-解冻 6-消费 9-人工录入")
+    private Integer tradeType;
+	/** 交易金额 */
+    @Schema(description = "交易金额")
+    private BigDecimal tradeAmount;
+	/** 预付余额 */
+    @Schema(description = "预付余额")
+    private BigDecimal preBalance;
+	/** 交易中金额 */
+    @Schema(description = "交易中金额")
+    private BigDecimal tradingAmount;
+	/** 执行状态,1-进行中 2-成功 3-失败 */
+    @Schema(description = "执行状态,1-进行中 2-成功 3-失败")
+    private Integer status;
+	/** 备注 */
+    @Schema(description = "备注")
+    private String remark;
+	/** 凭证标识 0-无凭证 1-有凭证 */
+    @Schema(description = "凭证标识 0-无凭证 1-有凭证")
+    private Integer voucherFlag;
+	/** 删除标记 0-未删除 1-已删除 */
+    @Schema(description = "删除标记 0-未删除 1-已删除")
+    private Integer delFlag;
+	/** 创建人id */
+    @Schema(description = "创建人id")
+    private Long createBy;
+	/** 创建时间 */
+    @Schema(description = "创建时间")
+    @JsonFormat(timezone = "GMT+8", pattern = "yyyy-MM-dd HH:mm:ss")
+    private Date createTime;
+	/** 更新人id */
+    @Schema(description = "更新人id")
+    private Long updateBy;
+	/** 更新时间 */
+    @Schema(description = "更新时间")
+    @JsonFormat(timezone = "GMT+8", pattern = "yyyy-MM-dd HH:mm:ss")
+    private Date updateTime;
+}

+ 58 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/entity/WalletPrepaidRecord.java

@@ -0,0 +1,58 @@
+package com.sckw.payment.entity;
+
+import com.fasterxml.jackson.annotation.JsonFormat;
+import io.swagger.v3.oas.annotations.media.Schema;
+import lombok.Data;
+
+import java.math.BigDecimal;
+import java.util.Date;
+
+/**
+ * 预付支付记录(wallet_prepaid_record)
+ *
+ * @author tangys
+ * @since  2026-01-15 09:32:47
+ */
+@Data
+public class WalletPrepaidRecord {
+
+	/** 预付支付记录主键id */
+    @Schema(description = "预付支付记录主键id")
+    private Long id;
+	/** 预付清单id */
+    @Schema(description = "预付清单id")
+    private Long prepaidId;
+	/** 支付订单号 */
+    @Schema(description = "支付订单号")
+    private String orderNo;
+	/** 预付金额 */
+    @Schema(description = "预付金额")
+    private BigDecimal prepaidAmount;
+	/** 到账金额 */
+    @Schema(description = "到账金额")
+    private BigDecimal receivedAmount;
+	/** 支付状态,0-等待支付,1-支付成功 */
+    @Schema(description = "支付状态,0-等待支付,1-支付成功")
+    private Integer status;
+    private String data;
+	/** 备注 */
+    @Schema(description = "备注")
+    private String remark;
+	/** 删除标记 0-未删除 1-已删除 */
+    @Schema(description = "删除标记 0-未删除 1-已删除")
+    private Integer delFlag;
+	/** 创建人id */
+    @Schema(description = "创建人id")
+    private Long createBy;
+	/** 创建时间 */
+    @Schema(description = "创建时间")
+    @JsonFormat(timezone = "GMT+8", pattern = "yyyy-MM-dd HH:mm:ss")
+    private Date createTime;
+	/** 更新人id */
+    @Schema(description = "更新人id")
+    private Long updateBy;
+	/** 更新时间 */
+    @Schema(description = "更新时间")
+    @JsonFormat(timezone = "GMT+8", pattern = "yyyy-MM-dd HH:mm:ss")
+    private Date updateTime;
+}

+ 40 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/entity/WalletRequestLog.java

@@ -0,0 +1,40 @@
+package com.sckw.payment.entity;
+
+import com.fasterxml.jackson.annotation.JsonFormat;
+import io.swagger.v3.oas.annotations.media.Schema;
+import lombok.Data;
+
+import java.util.Date;
+
+/**
+ * 钱包接口幂等控制表(wallet_request_log)
+ *
+ * @author tangys
+ * @since  2026-01-06 10:28:02
+ */
+@Data
+public class WalletRequestLog {
+
+	/** 主键ID */
+    @Schema(description = "主键ID")
+    private Long id;
+	/** 幂等请求号 */
+    @Schema(description = "幂等请求号")
+    private String requestId;
+	/** 业务类型 */
+    @Schema(description = "业务类型")
+    private String bizType;
+	/** 业务单号 */
+    @Schema(description = "业务单号")
+    private String bizNo;
+	/** 状态:0-INIT 1-SUCCESS 2-FAIL 3-RETRY */
+    @Schema(description = "状态:0-INIT 1-SUCCESS 2-FAIL 3-RETRY")
+    private Integer status;
+	/** 失败原因 */
+    @Schema(description = "失败原因")
+    private String lastError;
+	/** 创建时间 */
+    @Schema(description = "创建时间")
+    @JsonFormat(timezone = "GMT+8", pattern = "yyyy-MM-dd HH:mm:ss")
+    private Date createdAt;
+}

+ 35 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/enums/CashActionEnum.java

@@ -0,0 +1,35 @@
+package com.sckw.payment.enums;
+
+import lombok.AllArgsConstructor;
+import lombok.Getter;
+
+import java.util.Objects;
+
+/**
+ *
+ */
+@Getter
+@AllArgsConstructor
+public enum CashActionEnum {
+
+    CASH(1, "提现"),
+    PRE(2, "预付"),
+    PAY(3, "支付"),
+    Profit(4, "收益"),
+    consume(5, "消费"),
+    ;
+
+    private final Integer code;
+    private final String label;
+
+
+    public static String getByCode(Integer code) {
+        for (CashActionEnum value : CashActionEnum.values()) {
+            if (Objects.equals(value.getCode(), code)) {
+                return value.getLabel();
+            }
+        }
+        return "";
+    }
+
+}

+ 32 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/enums/CashStatusEnum.java

@@ -0,0 +1,32 @@
+package com.sckw.payment.enums;
+
+import lombok.AllArgsConstructor;
+import lombok.Getter;
+
+import java.util.Objects;
+
+/**
+ *
+ */
+@Getter
+@AllArgsConstructor
+public enum CashStatusEnum {
+
+    SUCCESS(1, "成功"),
+    FAIL(2, "失败"),
+    ;
+
+    private final Integer code;
+    private final String label;
+
+
+    public static String getByCode(Integer code) {
+        for (CashStatusEnum value : CashStatusEnum.values()) {
+            if (Objects.equals(value.getCode(), code)) {
+                return value.getLabel();
+            }
+        }
+        return "";
+    }
+
+}

+ 41 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/enums/ExecutionStatusEnum.java

@@ -0,0 +1,41 @@
+package com.sckw.payment.enums;
+
+import lombok.AllArgsConstructor;
+import lombok.Getter;
+
+/**
+ * 执行状态枚举
+ */
+@Getter
+@AllArgsConstructor
+public enum ExecutionStatusEnum {
+
+    IN_PROGRESS(1, "进行中"),
+    SUCCESS(2, "成功"),
+    FAILED(3, "失败");
+
+    /**
+     * 状态编码
+     */
+    private final Integer code;
+
+    /**
+     * 状态名称
+     */
+    private final String name;
+
+    /**
+     * 根据编码获取枚举值
+     *
+     * @param code 编码
+     * @return 枚举值
+     */
+    public static String getByCode(Integer code) {
+        for (ExecutionStatusEnum status : values()) {
+            if (status.getCode().equals(code)) {
+                return status.getName();
+            }
+        }
+        return null;
+    }
+}

+ 31 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/enums/FreightActionEnum.java

@@ -0,0 +1,31 @@
+package com.sckw.payment.enums;
+
+import lombok.AllArgsConstructor;
+import lombok.Getter;
+
+import java.util.Objects;
+
+/**
+ *
+ */
+@Getter
+@AllArgsConstructor
+public enum FreightActionEnum {
+
+    CASH(1, "提现"),
+    ;
+
+    private final Integer code;
+    private final String label;
+
+
+    public static String getByCode(Integer code) {
+        for (FreightActionEnum value : FreightActionEnum.values()) {
+            if (Objects.equals(value.getCode(), code)) {
+                return value.getLabel();
+            }
+        }
+        return "";
+    }
+
+}

+ 31 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/enums/FreightStatusEnum.java

@@ -0,0 +1,31 @@
+package com.sckw.payment.enums;
+
+import lombok.AllArgsConstructor;
+import lombok.Getter;
+
+import java.util.Objects;
+
+/**
+ *
+ */
+@Getter
+@AllArgsConstructor
+public enum FreightStatusEnum {
+
+    CASH(1, "提现"),
+    ;
+
+    private final Integer code;
+    private final String label;
+
+
+    public static String getByCode(Integer code) {
+        for (FreightStatusEnum value : FreightStatusEnum.values()) {
+            if (Objects.equals(value.getCode(), code)) {
+                return value.getLabel();
+            }
+        }
+        return "";
+    }
+
+}

+ 44 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/enums/OrderTypeEnum.java

@@ -0,0 +1,44 @@
+package com.sckw.payment.enums;
+
+import lombok.AllArgsConstructor;
+import lombok.Getter;
+
+/**
+ * 订单类型枚举
+ */
+@Getter
+@AllArgsConstructor
+public enum OrderTypeEnum {
+
+    RECHARGE_ORDER(1, "充值订单"),
+    PREPAYMENT_ORDER(2, "预付订单"),
+    WITHDRAWAL_ORDER(3, "提现订单"),
+    TRADE_ORDER(4, "贸易订单"),
+    LOGISTICS_ORDER(5, "物流订单"),
+    PAYMENT_ORDER(6, "支付订单");
+
+    /**
+     * 订单类型编码
+     */
+    private final Integer code;
+
+    /**
+     * 订单类型名称
+     */
+    private final String name;
+
+    /**
+     * 根据编码获取枚举值
+     *
+     * @param code 编码
+     * @return 枚举值
+     */
+    public static OrderTypeEnum getByCode(Integer code) {
+        for (OrderTypeEnum orderType : values()) {
+            if (orderType.getCode().equals(code)) {
+                return orderType;
+            }
+        }
+        return null;
+    }
+}

+ 42 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/enums/PayStatusEnum.java

@@ -0,0 +1,42 @@
+package com.sckw.payment.enums;
+
+import lombok.AllArgsConstructor;
+import lombok.Getter;
+
+/**
+ * 支付状态枚举
+ *
+ * @author tangyishan
+ * @since 2026-01-15  15:19
+ */
+@Getter
+@AllArgsConstructor
+public enum PayStatusEnum {
+    PAYABLE(0, "等待支付"),
+    PAID(1, "支付成功");
+
+    /**
+     * 状态编码
+     */
+    private final Integer code;
+
+    /**
+     * 状态名称
+     */
+    private final String name;
+
+    /**
+     * 根据编码获取枚举值
+     *
+     * @param code 编码
+     * @return 枚举值
+     */
+    public static PayStatusEnum getByCode(Integer code) {
+        for (PayStatusEnum status : values()) {
+            if (status.getCode().equals(code)) {
+                return status;
+            }
+        }
+        return null;
+    }
+}

+ 21 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/enums/PayXwEnum.java

@@ -0,0 +1,21 @@
+package com.sckw.payment.enums;
+
+import lombok.AllArgsConstructor;
+import lombok.Getter;
+
+/**
+ * @author xucaiqin
+ * @date 2023-07-21 17:53:28
+ */
+@Getter
+@AllArgsConstructor
+public enum PayXwEnum {
+    BEFORE_CREATE("/user/beforeCreate", "获取开户地址"),
+    PAY("/prePay/pay", "钱包清单"),
+    SPLIT("/pay/settle", "清分"),
+    WITHDRAW_TAKE("/pay/withdraw", "申请提现"),
+    ;
+    private final String addr;
+    private final String desc;
+
+}

+ 49 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/enums/TransactionTypeEnum.java

@@ -0,0 +1,49 @@
+package com.sckw.payment.enums;
+
+import lombok.AllArgsConstructor;
+import lombok.Getter;
+
+/**
+ * 交易类型枚举
+ */
+@Getter
+@AllArgsConstructor
+public enum TransactionTypeEnum {
+
+    RECHARGE(1, "充值"),
+    PREPAYMENT(2, "预付"),
+    INCOME(3, "收益"),
+    FREEZE(4, "冻结"),
+    UNFREEZE(5, "解冻"),
+    CONSUME(6, "消费"),
+    WITHDRAWAL(7, "提现"),
+    PAYMENT(8, "支付"),
+    MANUAL_ENTRY(9, "人工录入"),
+    APPLY_FOR_PAYMENT(10, "申请付款"),
+    PAYMENT_SUCCESS(11, "付款成功");
+
+    /**
+     * 交易类型编码
+     */
+    private final Integer code;
+
+    /**
+     * 交易类型名称
+     */
+    private final String name;
+
+    /**
+     * 根据编码获取枚举值
+     *
+     * @param code 编码
+     * @return 枚举值
+     */
+    public static String getByCode(Integer code) {
+        for (TransactionTypeEnum transactionType : values()) {
+            if (transactionType.getCode().equals(code)) {
+                return transactionType.getName();
+            }
+        }
+        return "";
+    }
+}

+ 32 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/enums/WalletStatusEnum.java

@@ -0,0 +1,32 @@
+package com.sckw.payment.enums;
+
+import lombok.AllArgsConstructor;
+import lombok.Getter;
+
+import java.util.Objects;
+
+/**
+ *
+ */
+@Getter
+@AllArgsConstructor
+public enum WalletStatusEnum {
+
+    LOAD(1, "开户中"),
+    SUCCESS(2, "开户成功"),
+    ;
+
+    private final Integer code;
+    private final String label;
+
+
+    public static String getByCode(Integer code) {
+        for (WalletStatusEnum value : WalletStatusEnum.values()) {
+            if (Objects.equals(value.getCode(), code)) {
+                return value.getLabel();
+            }
+        }
+        return "";
+    }
+
+}

+ 13 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/mapper/KwpWalletCashMapper.java

@@ -0,0 +1,13 @@
+package com.sckw.payment.mapper;
+
+import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+import com.sckw.payment.entity.KwpWalletCash;
+import org.apache.ibatis.annotations.Mapper;
+
+/**
+ * @author xucaiqin
+ * @date 2026-03-26 14:32:05
+ */
+@Mapper
+public interface KwpWalletCashMapper extends BaseMapper<KwpWalletCash> {
+}

+ 13 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/mapper/KwpWalletMapper.java

@@ -0,0 +1,13 @@
+package com.sckw.payment.mapper;
+
+import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+import com.sckw.payment.entity.KwpWallet;
+import org.apache.ibatis.annotations.Mapper;
+
+/**
+ * @author xucaiqin
+ * @date 2026-03-26 14:33:23
+ */
+@Mapper
+public interface KwpWalletMapper extends BaseMapper<KwpWallet> {
+}

+ 13 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/mapper/KwpWalletSplitMapper.java

@@ -0,0 +1,13 @@
+package com.sckw.payment.mapper;
+
+import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+import com.sckw.payment.entity.KwpWalletSplit;
+import org.apache.ibatis.annotations.Mapper;
+
+/**
+* @date 2026-04-08 11:25:38
+* @author xucaiqin
+*/
+@Mapper
+public interface KwpWalletSplitMapper extends BaseMapper<KwpWalletSplit> {
+}

+ 81 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/mapper/WalletAccountMapper.java

@@ -0,0 +1,81 @@
+package com.sckw.payment.mapper;
+
+import com.sckw.payment.entity.WalletAccount;
+import org.apache.ibatis.annotations.Mapper;
+import org.apache.ibatis.annotations.Param;
+
+import java.util.List;
+
+/**
+ * 钱包账户表Mapper接口
+ *
+ * @author tangys
+ * @since  2026-01-06 10:30:54
+ */
+@Mapper
+public interface WalletAccountMapper {
+    /**
+     * 分页查询钱包账户表列表
+     *
+     * @param walletAccount 钱包账户表
+     * @return 钱包账户表列表
+     */
+    List<WalletAccount> selectWalletAccountList(WalletAccount walletAccount);
+
+    /**
+     * 根据主键ID查询钱包账户表
+     *
+     * @param id 主键id
+     * @return 钱包账户表
+     */
+    WalletAccount selectWalletAccountById(@Param("id") Long id);
+
+    /**
+     * 根据主键ID列表查询钱包账户表列表
+     *
+     * @param idList 主键id列表
+     * @return 列表数据
+     */
+    List<WalletAccount> selectWalletAccountByIds(@Param("idList") List<Long> idList);
+
+    /**
+     * 新增钱包账户表
+     *
+     * @param walletAccount 钱包账户表
+     * @return 结果数据
+     */
+    int insertWalletAccount(WalletAccount walletAccount);
+
+    /**
+     * 修改钱包账户表
+     *
+     * @param walletAccount 钱包账户表
+     * @return 结果数据
+     */
+    int updateWalletAccount(WalletAccount walletAccount);
+
+    /**
+     * 删除钱包账户表
+     *
+     * @param id 主键id
+     * @return 结果数据
+     */
+    int deleteWalletAccountById(@Param("id") Long id);
+
+    /**
+     * 批量删除钱包账户表
+     *
+     * @param idList 主键id列表
+     * @return 结果数据
+     */
+    int deleteWalletAccountByIds(@Param("idList") List<Long> idList);
+
+    /**
+     * 批量逻辑删除钱包账户表
+     *
+     * @param idList 主键id列表
+     * @param updateBy 登录用户名
+     * @return 结果数据
+     */
+    int deleteWalletAccountLogicByIds(@Param("idList") List<Long> idList, @Param("updateBy") Long updateBy);
+}

+ 81 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/mapper/WalletBalanceMapper.java

@@ -0,0 +1,81 @@
+package com.sckw.payment.mapper;
+
+import com.sckw.payment.entity.WalletBalance;
+import org.apache.ibatis.annotations.Mapper;
+import org.apache.ibatis.annotations.Param;
+
+import java.util.List;
+
+/**
+ * 钱包余额明细表Mapper接口
+ *
+ * @author tangys
+ * @since  2026-01-12 16:24:22
+ */
+@Mapper
+public interface WalletBalanceMapper {
+    /**
+     * 分页查询钱包余额明细表列表
+     *
+     * @param walletBalance 钱包余额明细表
+     * @return 钱包余额明细表列表
+     */
+    List<WalletBalance> selectWalletBalanceList(WalletBalance walletBalance);
+
+    /**
+     * 根据主键ID查询钱包余额明细表
+     *
+     * @param id 明细主键
+     * @return 钱包余额明细表
+     */
+    WalletBalance selectWalletBalanceById(@Param("id") Long id);
+
+    /**
+     * 根据主键ID列表查询钱包余额明细表列表
+     *
+     * @param idList 明细主键列表
+     * @return 列表数据
+     */
+    List<WalletBalance> selectWalletBalanceByIds(@Param("idList") List<Long> idList);
+
+    /**
+     * 新增钱包余额明细表
+     *
+     * @param walletBalance 钱包余额明细表
+     * @return 结果数据
+     */
+    int insertWalletBalance(WalletBalance walletBalance);
+
+    /**
+     * 修改钱包余额明细表
+     *
+     * @param walletBalance 钱包余额明细表
+     * @return 结果数据
+     */
+    int updateWalletBalance(WalletBalance walletBalance);
+
+    /**
+     * 删除钱包余额明细表
+     *
+     * @param id 明细主键
+     * @return 结果数据
+     */
+    int deleteWalletBalanceById(@Param("id") Long id);
+
+    /**
+     * 批量删除钱包余额明细表
+     *
+     * @param idList 明细主键列表
+     * @return 结果数据
+     */
+    int deleteWalletBalanceByIds(@Param("idList") List<Long> idList);
+
+    /**
+     * 批量逻辑删除钱包余额明细表
+     *
+     * @param idList 明细主键列表
+     * @param loginName 登录用户名
+     * @return 结果数据
+     */
+    int deleteWalletBalanceLogicByIds(@Param("idList") List<Long> idList, @Param("loginName") String loginName);
+}

+ 81 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/mapper/WalletBankCallbackMapper.java

@@ -0,0 +1,81 @@
+package com.sckw.payment.mapper;
+
+import com.sckw.payment.entity.WalletBankCallback;
+import org.apache.ibatis.annotations.Mapper;
+import org.apache.ibatis.annotations.Param;
+
+import java.util.List;
+
+/**
+ * 银行回调日志表Mapper接口
+ *
+ * @author tangys
+ * @since  2026-01-06 10:30:54
+ */
+@Mapper
+public interface WalletBankCallbackMapper {
+    /**
+     * 分页查询银行回调日志表列表
+     *
+     * @param walletBankCallback 银行回调日志表
+     * @return 银行回调日志表列表
+     */
+    List<WalletBankCallback> selectWalletBankCallbackList(WalletBankCallback walletBankCallback);
+
+    /**
+     * 根据主键ID查询银行回调日志表
+     *
+     * @param id 主键ID
+     * @return 银行回调日志表
+     */
+    WalletBankCallback selectWalletBankCallbackById(@Param("id") Long id);
+
+    /**
+     * 根据主键ID列表查询银行回调日志表列表
+     *
+     * @param idList 主键ID列表
+     * @return 列表数据
+     */
+    List<WalletBankCallback> selectWalletBankCallbackByIds(@Param("idList") List<Long> idList);
+
+    /**
+     * 新增银行回调日志表
+     *
+     * @param walletBankCallback 银行回调日志表
+     * @return 结果数据
+     */
+    int insertWalletBankCallback(WalletBankCallback walletBankCallback);
+
+    /**
+     * 修改银行回调日志表
+     *
+     * @param walletBankCallback 银行回调日志表
+     * @return 结果数据
+     */
+    int updateWalletBankCallback(WalletBankCallback walletBankCallback);
+
+    /**
+     * 删除银行回调日志表
+     *
+     * @param id 主键ID
+     * @return 结果数据
+     */
+    int deleteWalletBankCallbackById(@Param("id") Long id);
+
+    /**
+     * 批量删除银行回调日志表
+     *
+     * @param idList 主键ID列表
+     * @return 结果数据
+     */
+    int deleteWalletBankCallbackByIds(@Param("idList") List<Long> idList);
+
+    /**
+     * 批量逻辑删除银行回调日志表
+     *
+     * @param idList 主键ID列表
+     * @param updateBy 登录用户名
+     * @return 结果数据
+     */
+    int deleteWalletBankCallbackLogicByIds(@Param("idList") List<Long> idList, @Param("updateBy") Long updateBy);
+}

+ 72 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/mapper/WalletBankRequestMapper.java

@@ -0,0 +1,72 @@
+package com.sckw.payment.mapper;
+
+import com.sckw.payment.entity.WalletBankRequest;
+import org.apache.ibatis.annotations.Mapper;
+import org.apache.ibatis.annotations.Param;
+
+import java.util.List;
+
+/**
+ * 银行请求响应表Mapper接口
+ *
+ * @author tangys
+ * @since  2026-01-06 10:30:54
+ */
+@Mapper
+public interface WalletBankRequestMapper {
+    /**
+     * 分页查询银行请求响应表列表
+     *
+     * @param walletBankRequest 银行请求响应表
+     * @return 银行请求响应表列表
+     */
+    List<WalletBankRequest> selectWalletBankRequestList(WalletBankRequest walletBankRequest);
+
+    /**
+     * 根据主键ID查询银行请求响应表
+     *
+     * @param id 主键ID
+     * @return 银行请求响应表
+     */
+    WalletBankRequest selectWalletBankRequestById(@Param("id") Long id);
+
+    /**
+     * 根据主键ID列表查询银行请求响应表列表
+     *
+     * @param idList 主键ID列表
+     * @return 列表数据
+     */
+    List<WalletBankRequest> selectWalletBankRequestByIds(@Param("idList") List<Long> idList);
+
+    /**
+     * 新增银行请求响应表
+     *
+     * @param walletBankRequest 银行请求响应表
+     * @return 结果数据
+     */
+    int insertWalletBankRequest(WalletBankRequest walletBankRequest);
+
+    /**
+     * 修改银行请求响应表
+     *
+     * @param walletBankRequest 银行请求响应表
+     * @return 结果数据
+     */
+    int updateWalletBankRequest(WalletBankRequest walletBankRequest);
+
+    /**
+     * 删除银行请求响应表
+     *
+     * @param id 主键ID
+     * @return 结果数据
+     */
+    int deleteWalletBankRequestById(@Param("id") Long id);
+
+    /**
+     * 批量删除银行请求响应表
+     *
+     * @param idList 主键ID列表
+     * @return 结果数据
+     */
+    int deleteWalletBankRequestByIds(@Param("idList") List<Long> idList);
+}

+ 88 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/mapper/WalletBusinessFileMapper.java

@@ -0,0 +1,88 @@
+package com.sckw.payment.mapper;
+
+import com.sckw.payment.entity.WalletBusinessFile;
+import org.apache.ibatis.annotations.Mapper;
+import org.apache.ibatis.annotations.Param;
+
+import java.util.List;
+
+/**
+ * 钱包_业务文件Mapper接口
+ *
+ * @author tangys
+ * @since  2026-01-12 14:11:22
+ */
+@Mapper
+public interface WalletBusinessFileMapper {
+    /**
+     * 分页查询钱包_业务文件列表
+     *
+     * @param walletBusinessFile 钱包_业务文件
+     * @return 钱包_业务文件列表
+     */
+    List<WalletBusinessFile> selectWalletBusinessFileList(WalletBusinessFile walletBusinessFile);
+
+    /**
+     * 根据主键ID查询钱包_业务文件
+     *
+     * @param id 主键
+     * @return 钱包_业务文件
+     */
+    WalletBusinessFile selectWalletBusinessFileById(@Param("id") Long id);
+
+    /**
+     * 根据主键ID列表查询钱包_业务文件列表
+     *
+     * @param idList 主键列表
+     * @return 列表数据
+     */
+    List<WalletBusinessFile> selectWalletBusinessFileByIds(@Param("idList") List<Long> idList);
+
+    /**
+     * 新增钱包_业务文件
+     *
+     * @param walletBusinessFile 钱包_业务文件
+     * @return 结果数据
+     */
+    int insertWalletBusinessFile(WalletBusinessFile walletBusinessFile);
+
+    /**
+     * @desc: 批量插入
+     */
+    void insertBatch(@Param(value = "list") List<WalletBusinessFile> list);
+
+    /**
+     * 修改钱包_业务文件
+     *
+     * @param walletBusinessFile 钱包_业务文件
+     * @return 结果数据
+     */
+    int updateWalletBusinessFile(WalletBusinessFile walletBusinessFile);
+
+    /**
+     * 删除钱包_业务文件
+     *
+     * @param id 主键
+     * @return 结果数据
+     */
+    int deleteWalletBusinessFileById(@Param("id") Long id);
+
+    /**
+     * 批量删除钱包_业务文件
+     *
+     * @param idList 主键列表
+     * @return 结果数据
+     */
+    int deleteWalletBusinessFileByIds(@Param("idList") List<Long> idList);
+
+    /**
+     * 批量逻辑删除钱包_业务文件
+     *
+     * @param idList 主键列表
+     * @param loginName 登录用户名
+     * @return 结果数据
+     */
+    int deleteWalletBusinessFileLogicByIds(@Param("idList") List<Long> idList, @Param("loginName") String loginName);
+
+    List<String> selectFileByBusinessId(@Param("businessId") String businessId);
+}

+ 81 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/mapper/WalletEntInfoMapper.java

@@ -0,0 +1,81 @@
+package com.sckw.payment.mapper;
+
+import com.sckw.payment.entity.WalletEntInfo;
+import org.apache.ibatis.annotations.Mapper;
+import org.apache.ibatis.annotations.Param;
+
+import java.util.List;
+
+/**
+ * 开户企业信息表Mapper接口
+ *
+ * @author tangys
+ * @since  2026-01-07 16:59:01
+ */
+@Mapper
+public interface WalletEntInfoMapper {
+    /**
+     * 分页查询开户企业信息表列表
+     *
+     * @param walletEntInfo 开户企业信息表
+     * @return 开户企业信息表列表
+     */
+    List<WalletEntInfo> selectWalletEntInfoList(WalletEntInfo walletEntInfo);
+
+    /**
+     * 根据主键ID查询开户企业信息表
+     *
+     * @param id id
+     * @return 开户企业信息表
+     */
+    WalletEntInfo selectWalletEntInfoById(@Param("id") Long id);
+
+    /**
+     * 根据主键ID列表查询开户企业信息表列表
+     *
+     * @param idList id列表
+     * @return 列表数据
+     */
+    List<WalletEntInfo> selectWalletEntInfoByIds(@Param("idList") List<Long> idList);
+
+    /**
+     * 新增开户企业信息表
+     *
+     * @param walletEntInfo 开户企业信息表
+     * @return 结果数据
+     */
+    int insertWalletEntInfo(WalletEntInfo walletEntInfo);
+
+    /**
+     * 修改开户企业信息表
+     *
+     * @param walletEntInfo 开户企业信息表
+     * @return 结果数据
+     */
+    int updateWalletEntInfo(WalletEntInfo walletEntInfo);
+
+    /**
+     * 删除开户企业信息表
+     *
+     * @param id id
+     * @return 结果数据
+     */
+    int deleteWalletEntInfoById(@Param("id") Long id);
+
+    /**
+     * 批量删除开户企业信息表
+     *
+     * @param idList id列表
+     * @return 结果数据
+     */
+    int deleteWalletEntInfoByIds(@Param("idList") List<Long> idList);
+
+    /**
+     * 批量逻辑删除开户企业信息表
+     *
+     * @param idList id列表
+     * @param loginName 登录用户名
+     * @return 结果数据
+     */
+    int deleteWalletEntInfoLogicByIds(@Param("idList") List<Long> idList, @Param("loginName") String loginName);
+}

+ 85 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/mapper/WalletEntUserMapper.java

@@ -0,0 +1,85 @@
+package com.sckw.payment.mapper;
+
+import com.sckw.payment.entity.WalletEntUser;
+import org.apache.ibatis.annotations.Mapper;
+import org.apache.ibatis.annotations.Param;
+
+import java.util.List;
+
+/**
+ * 企业股东或最终收益人Mapper接口
+ *
+ * @author tangys
+ * @since  2026-01-07 16:59:01
+ */
+@Mapper
+public interface WalletEntUserMapper {
+    /**
+     * 分页查询企业股东或最终收益人列表
+     *
+     * @param walletEntUser 企业股东或最终收益人
+     * @return 企业股东或最终收益人列表
+     */
+    List<WalletEntUser> selectWalletEntUserList(WalletEntUser walletEntUser);
+
+    /**
+     * 根据主键ID查询企业股东或最终收益人
+     *
+     * @param id id
+     * @return 企业股东或最终收益人
+     */
+    WalletEntUser selectWalletEntUserById(@Param("id") Long id);
+
+    /**
+     * 根据主键ID列表查询企业股东或最终收益人列表
+     *
+     * @param idList id列表
+     * @return 列表数据
+     */
+    List<WalletEntUser> selectWalletEntUserByIds(@Param("idList") List<Long> idList);
+
+    /**
+     * 新增企业股东或最终收益人
+     *
+     * @param walletEntUser 企业股东或最终收益人
+     * @return 结果数据
+     */
+    int insertWalletEntUser(WalletEntUser walletEntUser);
+
+    int insertBatch(@Param("walletEntUsers") List<WalletEntUser> walletEntUsers);
+
+
+
+    /**
+     * 修改企业股东或最终收益人
+     *
+     * @param walletEntUser 企业股东或最终收益人
+     * @return 结果数据
+     */
+    int updateWalletEntUser(WalletEntUser walletEntUser);
+
+    /**
+     * 删除企业股东或最终收益人
+     *
+     * @param id id
+     * @return 结果数据
+     */
+    int deleteWalletEntUserById(@Param("id") Long id);
+
+    /**
+     * 批量删除企业股东或最终收益人
+     *
+     * @param idList id列表
+     * @return 结果数据
+     */
+    int deleteWalletEntUserByIds(@Param("idList") List<Long> idList);
+
+    /**
+     * 批量逻辑删除企业股东或最终收益人
+     *
+     * @param idList id列表
+     * @param loginName 登录用户名
+     * @return 结果数据
+     */
+    int deleteWalletEntUserLogicByIds(@Param("idList") List<Long> idList, @Param("loginName") String loginName);
+}

+ 89 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/mapper/WalletMapper.java

@@ -0,0 +1,89 @@
+package com.sckw.payment.mapper;
+
+import com.sckw.payment.entity.Wallet;
+import org.apache.ibatis.annotations.Mapper;
+import org.apache.ibatis.annotations.Param;
+
+import java.util.List;
+
+/**
+ * 钱包表Mapper接口
+ *
+ * @author tangys
+ * @since  2026-01-06 10:30:54
+ */
+@Mapper
+public interface WalletMapper {
+    /**
+     * 分页查询钱包表列表
+     *
+     * @param wallet 钱包表
+     * @return 钱包表列表
+     */
+    List<Wallet> selectWalletList(Wallet wallet);
+
+    /**
+     * 根据主键ID查询钱包表
+     *
+     * @param id id
+     * @return 钱包表
+     */
+    Wallet selectWalletById(@Param("id") Long id);
+
+    /**
+     * 根据企业ID查询钱包表
+     *
+     * @param entId 企业ID
+     * @return 钱包表
+     */
+    Wallet selectWalletByEntId(@Param("entId") Long entId);
+
+    /**
+     * 根据主键ID列表查询钱包表列表
+     *
+     * @param idList id列表
+     * @return 列表数据
+     */
+    List<Wallet> selectWalletByIds(@Param("idList") List<Long> idList);
+
+    /**
+     * 新增钱包表
+     *
+     * @param wallet 钱包表
+     * @return 结果数据
+     */
+    int insertWallet(Wallet wallet);
+
+    /**
+     * 修改钱包表
+     *
+     * @param wallet 钱包表
+     * @return 结果数据
+     */
+    int updateWallet(Wallet wallet);
+
+    /**
+     * 删除钱包表
+     *
+     * @param id id
+     * @return 结果数据
+     */
+    int deleteWalletById(@Param("id") Long id);
+
+    /**
+     * 批量删除钱包表
+     *
+     * @param idList id列表
+     * @return 结果数据
+     */
+    int deleteWalletByIds(@Param("idList") List<Long> idList);
+
+    /**
+     * 批量逻辑删除钱包表
+     *
+     * @param idList id列表
+     * @param updateBy 登录用户名
+     * @return 结果数据
+     */
+    int deleteWalletLogicByIds(@Param("idList") List<Long> idList, @Param("updateBy") Long updateBy);
+}

+ 91 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/mapper/WalletPayableApplyMapper.java

@@ -0,0 +1,91 @@
+package com.sckw.payment.mapper;
+
+import com.sckw.payment.entity.WalletPayableApply;
+import org.apache.ibatis.annotations.Mapper;
+import org.apache.ibatis.annotations.Param;
+
+import java.util.List;
+
+/**
+ * 运费申请付款记录Mapper接口
+ *
+ * @author tangys
+ * @since  2026-01-19 16:13:22
+ */
+@Mapper
+public interface WalletPayableApplyMapper {
+    /**
+     * 分页查询运费申请付款记录列表
+     *
+     * @param walletPayableApply 运费申请记录
+     * @return 运费申请记录列表
+     */
+    List<WalletPayableApply> selectWalletPayableApplyList(WalletPayableApply walletPayableApply);
+
+    /**
+     * 根据主键ID查询运费申请记录
+     *
+     * @param id 运费申请记录主键id
+     * @return 运费申请记录
+     */
+    WalletPayableApply selectWalletPayableApplyById(@Param("id") Long id);
+
+    WalletPayableApply selectWalletPayableApplyByOrderNo(@Param("orderNo") String orderNo);
+
+    /**
+     * 根据主键ID列表查询运费申请记录列表
+     *
+     * @param idList 运费申请记录主键id列表
+     * @return 列表数据
+     */
+    List<WalletPayableApply> selectWalletPayableApplyByIds(@Param("idList") List<Long> idList);
+
+    /**
+     * 根据运费清单id查询运费申请记录列表
+     *
+     * @param payableId 运费清单id
+     * @return 列表数据
+     */
+    List<WalletPayableApply> selectPayableApplyByPayableId(@Param("payableId") Long payableId);
+
+    /**
+     * 新增运费申请记录
+     *
+     * @param walletPayableApply 运费申请记录
+     * @return 结果数据
+     */
+    int insertWalletPayableApply(WalletPayableApply walletPayableApply);
+
+    /**
+     * 修改运费申请记录
+     *
+     * @param walletPayableApply 运费申请记录
+     * @return 结果数据
+     */
+    int updateWalletPayableApply(WalletPayableApply walletPayableApply);
+
+    /**
+     * 删除运费申请记录
+     *
+     * @param id 运费申请记录主键id
+     * @return 结果数据
+     */
+    int deleteWalletPayableApplyById(@Param("id") Long id);
+
+    /**
+     * 批量删除运费申请记录
+     *
+     * @param idList 运费申请记录主键id列表
+     * @return 结果数据
+     */
+    int deleteWalletPayableApplyByIds(@Param("idList") List<Long> idList);
+
+    /**
+     * 批量逻辑删除运费申请记录
+     *
+     * @param idList 运费申请记录主键id列表
+     * @param loginName 登录用户名
+     * @return 结果数据
+     */
+    int deleteWalletPayableApplyLogicByIds(@Param("idList") List<Long> idList, @Param("loginName") String loginName);
+}

+ 84 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/mapper/WalletPayableBalanceMapper.java

@@ -0,0 +1,84 @@
+package com.sckw.payment.mapper;
+
+import com.sckw.payment.entity.WalletPayableBalance;
+import com.sckw.payment.pojo.vo.req.WalletPayableBalanceQuery;
+import com.sckw.payment.pojo.vo.req.WalletPayableDto;
+import org.apache.ibatis.annotations.Mapper;
+import org.apache.ibatis.annotations.Param;
+
+import java.util.List;
+
+/**
+ * 托运企业待付运费余额明细Mapper接口
+ *
+ * @author tangys
+ * @since  2026-01-12 16:24:22
+ */
+@Mapper
+public interface WalletPayableBalanceMapper {
+    /**
+     * 分页查询托运企业待付运费余额明细列表
+     *
+     * @param query 托运企业待付运费余额明细
+     * @return 托运企业待付运费余额明细列表
+     */
+    List<WalletPayableBalance> selectWalletPayableBalanceList(WalletPayableBalanceQuery query);
+
+    WalletPayableBalance selectFreezePayableBalance(WalletPayableDto walletPayableDto);
+    /**
+     * 根据主键ID查询托运企业待付运费余额明细
+     *
+     * @param id 待付运费余额明细主键id
+     * @return 托运企业待付运费余额明细
+     */
+    WalletPayableBalance selectWalletPayableBalanceById(@Param("id") Long id);
+
+    /**
+     * 根据主键ID列表查询托运企业待付运费余额明细列表
+     *
+     * @param idList 待付运费余额明细主键id列表
+     * @return 列表数据
+     */
+    List<WalletPayableBalance> selectWalletPayableBalanceByIds(@Param("idList") List<Long> idList);
+
+    /**
+     * 新增托运企业待付运费余额明细
+     *
+     * @param walletPayableBalance 托运企业待付运费余额明细
+     * @return 结果数据
+     */
+    int insertWalletPayableBalance(WalletPayableBalance walletPayableBalance);
+
+    /**
+     * 修改托运企业待付运费余额明细
+     *
+     * @param walletPayableBalance 托运企业待付运费余额明细
+     * @return 结果数据
+     */
+    int updateWalletPayableBalance(WalletPayableBalance walletPayableBalance);
+
+    /**
+     * 删除托运企业待付运费余额明细
+     *
+     * @param id 待付运费余额明细主键id
+     * @return 结果数据
+     */
+    int deleteWalletPayableBalanceById(@Param("id") Long id);
+
+    /**
+     * 批量删除托运企业待付运费余额明细
+     *
+     * @param idList 待付运费余额明细主键id列表
+     * @return 结果数据
+     */
+    int deleteWalletPayableBalanceByIds(@Param("idList") List<Long> idList);
+
+    /**
+     * 批量逻辑删除托运企业待付运费余额明细
+     *
+     * @param idList 待付运费余额明细主键id列表
+     * @param loginName 登录用户名
+     * @return 结果数据
+     */
+    int deleteWalletPayableBalanceLogicByIds(@Param("idList") List<Long> idList, @Param("loginName") String loginName);
+}

+ 87 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/mapper/WalletPayableMapper.java

@@ -0,0 +1,87 @@
+package com.sckw.payment.mapper;
+
+import com.sckw.payment.entity.WalletPayable;
+import com.sckw.payment.pojo.vo.req.WalletPayableQuery;
+import com.sckw.payment.pojo.vo.res.WalletPayableSummary;
+import org.apache.ibatis.annotations.Mapper;
+import org.apache.ibatis.annotations.Param;
+
+import java.util.List;
+
+/**
+ * 待付运费清单Mapper接口
+ *
+ * @author tangys
+ * @since  2026-01-06 10:30:54
+ */
+@Mapper
+public interface WalletPayableMapper {
+    /**
+     * 分页查询待付运费清单列表
+     *
+     * @param query 待付运费清单
+     * @return 待付运费清单列表
+     */
+    List<WalletPayable> selectWalletPayableList(WalletPayableQuery query);
+
+    /**
+     * 根据主键ID查询待付运费清单
+     *
+     * @param id 待付运费清单主键id
+     * @return 待付运费清单
+     */
+    WalletPayable selectWalletPayableById(@Param("id") Long id);
+
+    /**
+     * 根据主键ID列表查询待付运费清单列表
+     *
+     * @param idList 待付运费清单主键id列表
+     * @return 列表数据
+     */
+    List<WalletPayable> selectWalletPayableByIds(@Param("idList") List<Long> idList);
+
+    /**
+     * 新增待付运费清单
+     *
+     * @param walletPayable 待付运费清单
+     * @return 结果数据
+     */
+    int insertWalletPayable(WalletPayable walletPayable);
+
+    /**
+     * 修改待付运费清单
+     *
+     * @param walletPayable 待付运费清单
+     * @return 结果数据
+     */
+    int updateWalletPayable(WalletPayable walletPayable);
+
+    /**
+     * 删除待付运费清单
+     *
+     * @param id 待付运费清单主键id
+     * @return 结果数据
+     */
+    int deleteWalletPayableById(@Param("id") Long id);
+
+    /**
+     * 批量删除待付运费清单
+     *
+     * @param idList 待付运费清单主键id列表
+     * @return 结果数据
+     */
+    int deleteWalletPayableByIds(@Param("idList") List<Long> idList);
+
+    /**
+     * 批量逻辑删除待付运费清单
+     *
+     * @param idList 待付运费清单主键id列表
+     * @param updateBy 登录用户名
+     * @return 结果数据
+     */
+    int deleteWalletPayableLogicByIds(@Param("idList") List<Long> idList, @Param("updateBy") Long updateBy);
+
+    WalletPayable selectByConsignAndCarrier(@Param("consignEntId") Long consignEntId,@Param("carrierEntId") Long carrierEntId);
+
+    WalletPayableSummary selectPayableSummary(WalletPayableQuery query);
+}

+ 87 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/mapper/WalletPayablePayMapper.java

@@ -0,0 +1,87 @@
+package com.sckw.payment.mapper;
+
+import com.sckw.payment.entity.WalletPayablePay;
+import com.sckw.payment.pojo.vo.req.WalletPayablePayQuery;
+import org.apache.ibatis.annotations.Mapper;
+import org.apache.ibatis.annotations.Param;
+
+import java.util.List;
+
+/**
+ * 运费支付记录Mapper接口
+ *
+ * @author tangys
+ * @since  2026-01-15 09:32:47
+ */
+@Mapper
+public interface WalletPayablePayMapper {
+    /**
+     * 分页查询运费支付记录列表
+     *
+     * @param query 运费支付记录
+     * @return 运费支付记录列表
+     */
+    List<WalletPayablePay> selectWalletPayablePayList(WalletPayablePayQuery query);
+
+    /**
+     * 根据主键ID查询运费支付记录
+     *
+     * @param id 运费支付记录主键id
+     * @return 运费支付记录
+     */
+    WalletPayablePay selectWalletPayablePayById(@Param("id") Long id);
+
+    WalletPayablePay selectPayableUnPayById(@Param("id") Long id);
+
+
+    WalletPayablePay selectWalletPayablePayByOrderNo(@Param("orderNo") String orderNo);
+
+    /**
+     * 根据主键ID列表查询运费支付记录列表
+     *
+     * @param idList 运费支付记录主键id列表
+     * @return 列表数据
+     */
+    List<WalletPayablePay> selectWalletPayablePayByIds(@Param("idList") List<Long> idList);
+
+    /**
+     * 新增运费支付记录
+     *
+     * @param WalletPayablePay 运费支付记录
+     * @return 结果数据
+     */
+    int insertWalletPayablePay(WalletPayablePay WalletPayablePay);
+
+    /**
+     * 修改运费支付记录
+     *
+     * @param WalletPayablePay 运费支付记录
+     * @return 结果数据
+     */
+    int updateWalletPayablePay(WalletPayablePay WalletPayablePay);
+
+    /**
+     * 删除运费支付记录
+     *
+     * @param id 运费支付记录主键id
+     * @return 结果数据
+     */
+    int deleteWalletPayablePayById(@Param("id") Long id);
+
+    /**
+     * 批量删除运费支付记录
+     *
+     * @param idList 运费支付记录主键id列表
+     * @return 结果数据
+     */
+    int deleteWalletPayablePayByIds(@Param("idList") List<Long> idList);
+
+    /**
+     * 批量逻辑删除运费支付记录
+     *
+     * @param idList 运费支付记录主键id列表
+     * @param loginName 登录用户名
+     * @return 结果数据
+     */
+    int deleteWalletPayablePayLogicByIds(@Param("idList") List<Long> idList, @Param("loginName") String loginName);
+}

+ 86 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/mapper/WalletPrepaidBalanceMapper.java

@@ -0,0 +1,86 @@
+package com.sckw.payment.mapper;
+
+import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+import com.sckw.payment.entity.WalletPrepaidBalance;
+import com.sckw.payment.pojo.vo.req.WalletPrepaidBalanceQuery;
+import com.sckw.payment.pojo.vo.req.WalletPrepaidDto;
+import org.apache.ibatis.annotations.Mapper;
+import org.apache.ibatis.annotations.Param;
+
+import java.util.List;
+
+/**
+ * 采购企业预付余额明细Mapper接口
+ *
+ * @author tangys
+ * @since  2026-01-12 16:24:22
+ */
+@Mapper
+public interface WalletPrepaidBalanceMapper extends BaseMapper<WalletPrepaidBalance> {
+    /**
+     * 分页查询采购企业预付余额明细列表
+     *
+     * @param query 采购企业预付余额明细
+     * @return 采购企业预付余额明细列表
+     */
+    List<WalletPrepaidBalance> selectWalletPrepaidBalanceList(WalletPrepaidBalanceQuery query);
+
+    WalletPrepaidBalance selectFreezePrepaidBalance(WalletPrepaidDto prepaidDto);
+
+    /**
+     * 根据主键ID查询采购企业预付余额明细
+     *
+     * @param id 预付余额明细主键id
+     * @return 采购企业预付余额明细
+     */
+    WalletPrepaidBalance selectWalletPrepaidBalanceById(@Param("id") Long id);
+
+    /**
+     * 根据主键ID列表查询采购企业预付余额明细列表
+     *
+     * @param idList 预付余额明细主键id列表
+     * @return 列表数据
+     */
+    List<WalletPrepaidBalance> selectWalletPrepaidBalanceByIds(@Param("idList") List<Long> idList);
+
+    /**
+     * 新增采购企业预付余额明细
+     *
+     * @param walletPrepaidBalance 采购企业预付余额明细
+     * @return 结果数据
+     */
+    int insertWalletPrepaidBalance(WalletPrepaidBalance walletPrepaidBalance);
+
+    /**
+     * 修改采购企业预付余额明细
+     *
+     * @param walletPrepaidBalance 采购企业预付余额明细
+     * @return 结果数据
+     */
+    int updateWalletPrepaidBalance(WalletPrepaidBalance walletPrepaidBalance);
+
+    /**
+     * 删除采购企业预付余额明细
+     *
+     * @param id 预付余额明细主键id
+     * @return 结果数据
+     */
+    int deleteWalletPrepaidBalanceById(@Param("id") Long id);
+
+    /**
+     * 批量删除采购企业预付余额明细
+     *
+     * @param idList 预付余额明细主键id列表
+     * @return 结果数据
+     */
+    int deleteWalletPrepaidBalanceByIds(@Param("idList") List<Long> idList);
+
+    /**
+     * 批量逻辑删除采购企业预付余额明细
+     *
+     * @param idList 预付余额明细主键id列表
+     * @param updateBy 登录用户名
+     * @return 结果数据
+     */
+    int deleteWalletPrepaidBalanceLogicByIds(@Param("idList") List<Long> idList, @Param("updateBy") Long updateBy);
+}

+ 95 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/mapper/WalletPrepaidMapper.java

@@ -0,0 +1,95 @@
+package com.sckw.payment.mapper;
+
+import com.sckw.payment.entity.WalletPrepaid;
+import com.sckw.payment.pojo.vo.req.WalletPrepaidQuery;
+import com.sckw.payment.pojo.vo.res.WalletPrepaidSummary;
+import org.apache.ibatis.annotations.Mapper;
+import org.apache.ibatis.annotations.Param;
+
+import java.math.BigDecimal;
+import java.util.List;
+
+/**
+ * 预付清单Mapper接口
+ *
+ * @author tangys
+ * @since  2026-01-06 10:30:54
+ */
+@Mapper
+public interface WalletPrepaidMapper {
+    /**
+     * 分页查询预付清单列表
+     *
+     * @param query 预付清单
+     * @return 预付清单列表
+     */
+    List<WalletPrepaid> selectWalletPrepaidList(WalletPrepaidQuery query);
+
+    WalletPrepaidSummary selectWalletPrepaidSummary(WalletPrepaidQuery query);
+
+    /**
+     * BI大屏查询所有供应商待履约金额汇总
+     *
+     * @return 待履约金额汇总
+     */
+    BigDecimal selectAllSupplierPrepaidSummary();
+
+    /**
+     * 根据主键ID查询预付清单
+     *
+     * @param id 预付清单主键id
+     * @return 预付清单
+     */
+    WalletPrepaid selectWalletPrepaidById(@Param("id") Long id);
+
+    WalletPrepaid selectByProEntIdAndSupEntId(@Param("proEntId") Long proEntId, @Param("supEntId") Long supEntId);
+
+    /**
+     * 根据主键ID列表查询预付清单列表
+     *
+     * @param idList 预付清单主键id列表
+     * @return 列表数据
+     */
+    List<WalletPrepaid> selectWalletPrepaidByIds(@Param("idList") List<Long> idList);
+
+    /**
+     * 新增预付清单
+     *
+     * @param walletPrepaid 预付清单
+     * @return 结果数据
+     */
+    int insertWalletPrepaid(WalletPrepaid walletPrepaid);
+
+    /**
+     * 修改预付清单
+     *
+     * @param walletPrepaid 预付清单
+     * @return 结果数据
+     */
+    int updateWalletPrepaid(WalletPrepaid walletPrepaid);
+
+    /**
+     * 删除预付清单
+     *
+     * @param id 预付清单主键id
+     * @return 结果数据
+     */
+    int deleteWalletPrepaidById(@Param("id") Long id);
+
+    /**
+     * 批量删除预付清单
+     *
+     * @param idList 预付清单主键id列表
+     * @return 结果数据
+     */
+    int deleteWalletPrepaidByIds(@Param("idList") List<Long> idList);
+
+    /**
+     * 批量逻辑删除预付清单
+     *
+     * @param idList 预付清单主键id列表
+     * @param updateBy 登录用户名
+     * @return 结果数据
+     */
+    int deleteWalletPrepaidLogicByIds(@Param("idList") List<Long> idList, @Param("updateBy") Long updateBy);
+}

+ 84 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/mapper/WalletPrepaidRecordMapper.java

@@ -0,0 +1,84 @@
+package com.sckw.payment.mapper;
+
+import com.sckw.payment.entity.WalletPrepaidRecord;
+import com.sckw.payment.pojo.vo.req.WalletPrepaidRecordQuery;
+import org.apache.ibatis.annotations.Mapper;
+import org.apache.ibatis.annotations.Param;
+
+import java.util.List;
+
+/**
+ * 预付支付记录Mapper接口
+ *
+ * @author tangys
+ * @since  2026-01-15 09:32:47
+ */
+@Mapper
+public interface WalletPrepaidRecordMapper {
+    /**
+     * 分页查询预付支付记录列表
+     *
+     * @param query 预付支付记录
+     * @return 预付支付记录列表
+     */
+    List<WalletPrepaidRecord> selectWalletPrepaidRecordList(WalletPrepaidRecordQuery query);
+
+    /**
+     * 根据主键ID查询预付支付记录
+     *
+     * @param id 预付支付记录主键id
+     * @return 预付支付记录
+     */
+    WalletPrepaidRecord selectWalletPrepaidRecordById(@Param("id") Long id);
+
+    WalletPrepaidRecord selectWalletPrepaidRecordByOrderNo(@Param("orderNo") String orderNo);
+
+    /**
+     * 根据主键ID列表查询预付支付记录列表
+     *
+     * @param idList 预付支付记录主键id列表
+     * @return 列表数据
+     */
+    List<WalletPrepaidRecord> selectWalletPrepaidRecordByIds(@Param("idList") List<Long> idList);
+
+    /**
+     * 新增预付支付记录
+     *
+     * @param walletPrepaidRecord 预付支付记录
+     * @return 结果数据
+     */
+    int insertWalletPrepaidRecord(WalletPrepaidRecord walletPrepaidRecord);
+
+    /**
+     * 修改预付支付记录
+     *
+     * @param walletPrepaidRecord 预付支付记录
+     * @return 结果数据
+     */
+    int updateWalletPrepaidRecord(WalletPrepaidRecord walletPrepaidRecord);
+
+    /**
+     * 删除预付支付记录
+     *
+     * @param id 预付支付记录主键id
+     * @return 结果数据
+     */
+    int deleteWalletPrepaidRecordById(@Param("id") Long id);
+
+    /**
+     * 批量删除预付支付记录
+     *
+     * @param idList 预付支付记录主键id列表
+     * @return 结果数据
+     */
+    int deleteWalletPrepaidRecordByIds(@Param("idList") List<Long> idList);
+
+    /**
+     * 批量逻辑删除预付支付记录
+     *
+     * @param idList 预付支付记录主键id列表
+     * @param loginName 登录用户名
+     * @return 结果数据
+     */
+    int deleteWalletPrepaidRecordLogicByIds(@Param("idList") List<Long> idList, @Param("loginName") String loginName);
+}

+ 72 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/mapper/WalletRequestLogMapper.java

@@ -0,0 +1,72 @@
+package com.sckw.payment.mapper;
+
+import com.sckw.payment.entity.WalletRequestLog;
+import org.apache.ibatis.annotations.Mapper;
+import org.apache.ibatis.annotations.Param;
+
+import java.util.List;
+
+/**
+ * 钱包接口幂等控制表Mapper接口
+ *
+ * @author tangys
+ * @since  2026-01-06 10:30:54
+ */
+@Mapper
+public interface WalletRequestLogMapper {
+    /**
+     * 分页查询钱包接口幂等控制表列表
+     *
+     * @param walletRequestLog 钱包接口幂等控制表
+     * @return 钱包接口幂等控制表列表
+     */
+    List<WalletRequestLog> selectWalletRequestLogList(WalletRequestLog walletRequestLog);
+
+    /**
+     * 根据主键ID查询钱包接口幂等控制表
+     *
+     * @param id 主键ID
+     * @return 钱包接口幂等控制表
+     */
+    WalletRequestLog selectWalletRequestLogById(@Param("id") Long id);
+
+    /**
+     * 根据主键ID列表查询钱包接口幂等控制表列表
+     *
+     * @param idList 主键ID列表
+     * @return 列表数据
+     */
+    List<WalletRequestLog> selectWalletRequestLogByIds(@Param("idList") List<Long> idList);
+
+    /**
+     * 新增钱包接口幂等控制表
+     *
+     * @param walletRequestLog 钱包接口幂等控制表
+     * @return 结果数据
+     */
+    int insertWalletRequestLog(WalletRequestLog walletRequestLog);
+
+    /**
+     * 修改钱包接口幂等控制表
+     *
+     * @param walletRequestLog 钱包接口幂等控制表
+     * @return 结果数据
+     */
+    int updateWalletRequestLog(WalletRequestLog walletRequestLog);
+
+    /**
+     * 删除钱包接口幂等控制表
+     *
+     * @param id 主键ID
+     * @return 结果数据
+     */
+    int deleteWalletRequestLogById(@Param("id") Long id);
+
+    /**
+     * 批量删除钱包接口幂等控制表
+     *
+     * @param idList 主键ID列表
+     * @return 结果数据
+     */
+    int deleteWalletRequestLogByIds(@Param("idList") List<Long> idList);
+}

+ 86 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/CashVo.java

@@ -0,0 +1,86 @@
+package com.sckw.payment.pojo;
+
+import com.fasterxml.jackson.annotation.JsonFormat;
+import io.swagger.v3.oas.annotations.media.Schema;
+import lombok.Getter;
+import lombok.Setter;
+
+import java.math.BigDecimal;
+import java.time.LocalDateTime;
+
+/**
+ * 提现
+ *
+ * @author xucaiqin
+ * @date 2023-08-29 09:14:04
+ */
+@Getter
+@Setter
+public class CashVo {
+    @JsonFormat(shape = JsonFormat.Shape.STRING)
+    private Long id;
+    /**
+     * 付款方
+     */
+    @Schema(description = "付款方")
+    @JsonFormat(shape = JsonFormat.Shape.STRING)
+    private Long fromEnt;
+    private String fromEntName;
+
+    /**
+     * 收款方
+     */
+    @Schema(description = "收款方")
+    private Long toEnt;
+    private String toEntName;
+
+    /**
+     * 订单号
+     */
+    @Schema(description = "订单号")
+    private String orderNo;
+
+    /**
+     * 操作 1-提现 2-预付 3-支付 4-收益 5-消费
+     */
+    @Schema(description = "操作 1-提现 2-预付 3-支付 4-收益 5-消费")
+    private Integer action;
+    private String actionLabel;
+
+    /**
+     * 交易金额
+     */
+    @Schema(description = "交易金额")
+    private BigDecimal amount;
+
+    /**
+     * 可提现金额
+     */
+    @Schema(description = "可提现金额")
+    private BigDecimal cashAmount;
+
+    /**
+     * 凭证
+     */
+    @Schema(description = "凭证")
+    private String img;
+
+    /**
+     * 备注
+     */
+    @Schema(description = "备注")
+    private String remark;
+
+    /**
+     * 状态 1-成功 2-失败 3-提现中
+     */
+    @Schema(description = "状态 1-成功 2-失败")
+    private Integer status;
+    private String statusLabel;
+    /**
+     * 创建时间
+     */
+    @Schema(description = "创建时间")
+    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8")
+    private LocalDateTime createTime;
+}

+ 24 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/UpdateCash.java

@@ -0,0 +1,24 @@
+package com.sckw.payment.pojo;
+
+import io.swagger.v3.oas.annotations.media.Schema;
+import jakarta.validation.constraints.NotNull;
+import lombok.Getter;
+import lombok.Setter;
+
+/**
+ * 提现
+ *
+ * @author xucaiqin
+ * @date 2023-08-29 09:14:04
+ */
+@Getter
+@Setter
+public class UpdateCash {
+    @NotNull(message = "id不能为空")
+    @Schema(description = "id")
+    private Long id;
+
+    @Schema(description = "预付直提 1-否 2-是")
+    @NotNull(message = "预付直提状态不能为空")
+    private Integer cashFlag;
+}

+ 21 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/dto/CashDto.java

@@ -0,0 +1,21 @@
+package com.sckw.payment.pojo.dto;
+
+import com.alibaba.fastjson2.annotation.JSONField;
+import lombok.Getter;
+import lombok.Setter;
+import org.springframework.web.multipart.MultipartFile;
+
+import java.io.Serializable;
+
+
+@Getter
+@Setter
+public class CashDto implements Serializable {
+
+    private String status;
+    private String remark;
+    private String orderNo;
+    private String amt;
+    @JSONField(serialize = false)
+    private MultipartFile file;
+}

+ 31 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/dto/CashWalletReq.java

@@ -0,0 +1,31 @@
+package com.sckw.payment.pojo.dto;
+
+import com.sckw.common.core.pojo.MoneyChange;
+import jakarta.validation.constraints.Digits;
+import jakarta.validation.constraints.Positive;
+import jakarta.validation.constraints.Size;
+import lombok.Getter;
+import lombok.Setter;
+
+import java.math.BigDecimal;
+
+/**
+ * 提现
+ *
+ * @author xucaiqin
+ * @date 2023-08-29 09:14:04
+ */
+@Getter
+@Setter
+public class CashWalletReq implements MoneyChange {
+
+    @Positive(message = "提现金额必须大于0")
+    @Digits(message = "小数位数过长或金额过大", integer = 10, fraction = 2)
+    private BigDecimal money;
+
+    @Size(message = "备注不能超过200字")
+    private String remark;
+//    @NotBlank(message = "验证码不能为空")
+    private String sms;
+
+}

+ 27 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/dto/CreateUser.java

@@ -0,0 +1,27 @@
+package com.sckw.payment.pojo.dto;
+
+import com.alibaba.fastjson2.annotation.JSONField;
+import lombok.Getter;
+import lombok.Setter;
+
+import java.io.Serial;
+import java.io.Serializable;
+
+/**
+ * @author xucaiqin
+ * @date 2023-07-25 15:30:59
+ */
+@Getter
+@Setter
+public class CreateUser implements Serializable {
+    @Serial
+    private static final long serialVersionUID = -3148504181066374194L;
+    @JSONField(name = "user_id")
+    private String user_id;
+
+    @JSONField(name = "end_time")
+    private String end_time;
+
+    @JSONField(name = "url")
+    private String url;
+}

+ 32 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/dto/CustomSettleDto.java

@@ -0,0 +1,32 @@
+package com.sckw.payment.pojo.dto;
+
+import jakarta.validation.Valid;
+import jakarta.validation.constraints.NotBlank;
+import jakarta.validation.constraints.NotEmpty;
+import lombok.Getter;
+import lombok.Setter;
+
+import java.util.List;
+
+
+/**
+ * @author xucaiqin
+ * @date 2024-01-11 11:35:33
+ */
+@Getter
+@Setter
+public class CustomSettleDto {
+    @NotBlank(message = "uid不能为空")
+    private String uid;
+    //总金额,单位元;包含:商户结算资金和商户手续费DECIMAL{17,2}
+    @NotBlank(message = "总金额不能为空")
+    private String amt;
+    private String mchtFee;
+    @NotBlank(message = "中台回调通知地址不能为空")
+    private String noticeUrl;
+    private String summery;
+    private String remark;
+    @NotEmpty(message = "清分数组不能为空")
+    @Valid
+    private List<DivideDto> divide;
+}

+ 22 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/dto/CustomSettleRes.java

@@ -0,0 +1,22 @@
+package com.sckw.payment.pojo.dto;
+
+import lombok.Getter;
+import lombok.Setter;
+
+import java.io.Serializable;
+import java.util.List;
+
+/**
+ * @author xucaiqin
+ * @date 2024-01-11 10:45:17
+ */
+@Getter
+@Setter
+public class CustomSettleRes implements Serializable {
+    private String returnCode;
+    private String returnMessage;
+    private String dealResult;
+    private String tranNo;
+    private String txnNo;
+    private List<DivideInfoDto> divideInfo;
+}

+ 18 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/dto/DivideDto.java

@@ -0,0 +1,18 @@
+package com.sckw.payment.pojo.dto;
+
+import lombok.Getter;
+import lombok.Setter;
+
+/**
+ * @author xucaiqin
+ * @date 2024-01-15 17:19:12
+ */
+@Getter
+@Setter
+public class DivideDto {
+    //分账金额
+    //交易金额 必须满足:分账金额总和 = 总金额 - 商户结算手续费;币种保持一致
+    private String amt;
+    //收款方
+    private String filter;
+}

+ 14 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/dto/DivideInfoDto.java

@@ -0,0 +1,14 @@
+package com.sckw.payment.pojo.dto;
+
+import lombok.Getter;
+import lombok.Setter;
+
+/**
+ * @author xucaiqin
+ * @date 2024-01-15 17:19:12
+ */
+@Getter
+@Setter
+public class DivideInfoDto extends DivideDto {
+    private String txnNo;
+}

+ 41 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/dto/PayDto.java

@@ -0,0 +1,41 @@
+package com.sckw.payment.pojo.dto;
+
+import jakarta.validation.constraints.NotBlank;
+import lombok.Getter;
+import lombok.Setter;
+
+import java.io.Serializable;
+
+
+@Getter
+@Setter
+public class PayDto implements Serializable {
+    /**
+     * 付款方uid
+     */
+    @NotBlank(message = "付款方uid不能为空")
+    private String uid;
+
+    @NotBlank(message = "收款方filter不能为空")
+    private String filter;
+    /**
+     * 中台订单号
+     */
+    @NotBlank(message = "订单号不能为空")
+    private String orderNo;
+    /**
+     * 订单金额
+     */
+    @NotBlank(message = "订单金额不能为空")
+    private String amt;
+
+    /**
+     * 中台回调通知地址
+     */
+    private String noticeUrl;
+
+    /**
+     * 备注
+     */
+    private String remark;
+}

+ 16 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/dto/Res.java

@@ -0,0 +1,16 @@
+package com.sckw.payment.pojo.dto;
+
+import lombok.Getter;
+import lombok.Setter;
+
+/**
+ * @author xucaiqin
+ * @date 2024-01-11 10:45:17
+ */
+@Getter
+@Setter
+public class Res {
+    private String returnCode;
+    private String returnMessage;
+    private String dealResult;
+}

+ 21 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/dto/SplitDto.java

@@ -0,0 +1,21 @@
+package com.sckw.payment.pojo.dto;
+
+import com.alibaba.fastjson2.annotation.JSONField;
+import lombok.Getter;
+import lombok.Setter;
+import org.springframework.web.multipart.MultipartFile;
+
+import java.io.Serializable;
+
+
+@Getter
+@Setter
+public class SplitDto implements Serializable {
+    private String status;
+    private String msg;
+    private String tranNo;
+    private String txnNo;
+    private String amt;
+    @JSONField(serialize = false)
+    private MultipartFile file;
+}

+ 15 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/dto/UserDataDto.java

@@ -0,0 +1,15 @@
+package com.sckw.payment.pojo.dto;
+
+import lombok.Getter;
+import lombok.Setter;
+
+import java.io.Serializable;
+
+
+@Getter
+@Setter
+public class UserDataDto implements Serializable {
+
+    private String uid;
+    private String xwId;
+}

+ 16 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/dto/UserDto.java

@@ -0,0 +1,16 @@
+package com.sckw.payment.pojo.dto;
+
+import lombok.Getter;
+import lombok.Setter;
+
+import java.io.Serializable;
+
+
+@Getter
+@Setter
+public class UserDto implements Serializable {
+
+    private String status;
+    private String msg;
+    private UserDataDto data;
+}

+ 47 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/dto/UserPara.java

@@ -0,0 +1,47 @@
+package com.sckw.payment.pojo.dto;
+
+
+import jakarta.validation.constraints.NotBlank;
+import lombok.Getter;
+import lombok.Setter;
+
+import java.io.Serial;
+import java.io.Serializable;
+
+/**
+ * @Author xucaiqin
+ * @date 2023-03-30 19:19:43
+ */
+@Getter
+@Setter
+public class UserPara implements Serializable {
+    @Serial
+    private static final long serialVersionUID = 3652670959771172362L;
+    @NotBlank(message = "uid不能为空")
+    private String uid;
+    //公司名称
+    private String companyName;
+    //法人
+    private String legalName;
+    //法人手机号
+    private String legalPhone;
+    //联系人手机号
+    private String contactPhone;
+    //法人身份证
+    private String legalIds;
+    //营业执照
+    private String license;
+
+    private String noticeUrl;
+    //客户号,仅做展示使用,无其它用途
+    private String customerNo;
+
+    /**
+     * 审核状态 0-待提交 1-提交信息 2-小额验证 3-人工审核 4-联系人认证 5-法人认证 6-开户成功 7-开户失败
+     */
+    private Integer auditFlag = 0;
+    /**
+     * 结算授权状态 0-待提交 1-提交申请 2-审核通过 3-审核失败
+     */
+    private Integer settleFlag = 0;
+}

+ 39 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/dto/WithdrawDto.java

@@ -0,0 +1,39 @@
+package com.sckw.payment.pojo.dto;
+
+import jakarta.validation.constraints.NotBlank;
+import lombok.Getter;
+import lombok.Setter;
+
+import java.io.Serializable;
+
+/**
+ * @author lfdc
+ * @description 提现dto
+ * @date 2024-01-22 15:01:03
+ */
+@Getter
+@Setter
+public class WithdrawDto implements Serializable {
+    @NotBlank(message = "uid不能为空")
+    private String uid;
+
+    @NotBlank(message = "订单号不能为空")
+    private String orderNo;
+
+    @NotBlank(message = "提现金额不能为空")
+    private String amt;
+    /**
+     * 异步通知地址
+     */
+    @NotBlank(message = "异步通知地址不能为空")
+    private String noticeUrl;
+    /**
+     * 摘要
+     */
+    private String summary;
+    private String remark;
+    /**
+     * 平台收取佣金费用 非必填
+     */
+    private String commission;
+}

+ 15 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/dto/WithdrawRes.java

@@ -0,0 +1,15 @@
+package com.sckw.payment.pojo.dto;
+
+import lombok.Getter;
+import lombok.Setter;
+
+/**
+ * @author xucaiqin
+ * @date 2024-01-11 10:45:17
+ */
+@Getter
+@Setter
+public class WithdrawRes extends Res {
+    private String tranNo;
+    private String txnNo;
+}

+ 20 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/vo/PayRes.java

@@ -0,0 +1,20 @@
+package com.sckw.payment.pojo.vo;
+
+import lombok.Getter;
+import lombok.Setter;
+
+import java.io.Serializable;
+
+/**
+ * @Author xucaiqin
+ * @date 2023-03-28 10:26:17
+ */
+@Getter
+@Setter
+public class PayRes implements Serializable {
+    private String orderNo;
+    private String amt;
+    private String remark;
+    private String fullName;
+    private String settleAcct;
+}

+ 71 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/vo/WalletCashVo.java

@@ -0,0 +1,71 @@
+package com.sckw.payment.pojo.vo;
+
+import com.baomidou.mybatisplus.annotation.TableField;
+import com.fasterxml.jackson.annotation.JsonFormat;
+import io.swagger.v3.oas.annotations.media.Schema;
+import lombok.Data;
+
+import java.math.BigDecimal;
+
+/**
+ * 钱包信息
+ *
+ * @author xucaiqin
+ * @date 2023-08-28 15:43:49
+ */
+@Data
+@Schema(description = "可提现余额")
+public class WalletCashVo {
+    /**
+     * 主键
+     */
+    @Schema(description = "主键")
+    @JsonFormat(shape = JsonFormat.Shape.STRING)
+    private Long id;
+
+    /**
+     * 企业id
+     */
+    @TableField(value = "ent_id")
+    @Schema(description = "企业id")
+    private Long entId;
+
+    /**
+     * uid
+     */
+    @TableField(value = "`uid`")
+    @Schema(description = "uid")
+    private String uid;
+
+    /**
+     * 企业类型
+     */
+    @TableField(value = "ent_type")
+    @Schema(description = "企业类型")
+    private Integer entType;
+
+    @Schema(description = "预付直提 1-否 2-是")
+    private Integer cashFlag;
+    /**
+     * 提现金额
+     */
+    @TableField(value = "cash_amount")
+    @Schema(description = "提现金额")
+    private BigDecimal cashAmount;
+
+    /**
+     * 预付余额
+     */
+    @TableField(value = "prepay_amount")
+    @Schema(description = "预付余额")
+    private BigDecimal prepayAmount;
+
+    /**
+     * 状态 1-开户中 2-开户成功
+     */
+    @Schema(description = "状态")
+    private Integer status;
+    @Schema(description = "状态 1-开户中 2-开户成功")
+    private String statusLabel;
+
+}

+ 142 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/vo/WalletVo.java

@@ -0,0 +1,142 @@
+package com.sckw.payment.pojo.vo;
+
+import com.baomidou.mybatisplus.annotation.IdType;
+import com.baomidou.mybatisplus.annotation.TableField;
+import com.baomidou.mybatisplus.annotation.TableId;
+import com.fasterxml.jackson.annotation.JsonFormat;
+import io.swagger.v3.oas.annotations.media.Schema;
+import lombok.Data;
+
+import java.math.BigDecimal;
+import java.time.LocalDateTime;
+
+/**
+ * 钱包信息
+ *
+ * @author xucaiqin
+ * @date 2023-08-28 15:43:49
+ */
+@Data
+@Schema(description = "钱包")
+public class WalletVo {
+    /**
+     * 主键
+     */
+    @TableId(value = "id", type = IdType.AUTO)
+    @Schema(description = "主键")
+    @JsonFormat(shape = JsonFormat.Shape.STRING)
+    private Long id;
+
+    /**
+     * 企业id
+     */
+    @TableField(value = "ent_id")
+    @Schema(description = "企业id")
+    @JsonFormat(shape = JsonFormat.Shape.STRING)
+    private Long entId;
+
+    /**
+     * uid
+     */
+    @TableField(value = "`uid`")
+    @Schema(description = "uid")
+    private String uid;
+
+    /**
+     * 企业类型
+     */
+    @TableField(value = "ent_type")
+    @Schema(description = "企业类型")
+    private Integer entType;
+
+    /**
+     * 提现金额
+     */
+    @TableField(value = "cash_amount")
+    @Schema(description = "提现金额")
+    private BigDecimal cashAmount;
+
+    /**
+     * 预付余额
+     */
+    @TableField(value = "prepay_amount")
+    @Schema(description = "预付余额")
+    private BigDecimal prepayAmount;
+
+    /**
+     * 交易中金额
+     */
+    @TableField(value = "dealing_amount")
+    @Schema(description = "交易中金额")
+    private BigDecimal dealingAmount;
+
+    /**
+     * 运费金额
+     */
+    @TableField(value = "freight_amount")
+    @Schema(description = "运费金额")
+    private BigDecimal freightAmount;
+
+    /**
+     * 进行中金额
+     */
+    @Schema(description = "进行中金额")
+    private BigDecimal processingAmount;
+
+    /**
+     * 付款中金额
+     */
+    @Schema(description = "付款中金额")
+    private BigDecimal payingAmount;
+
+    /**
+     * 渠道
+     */
+    @Schema(description = "渠道")
+    private String channel;
+
+    @Schema(description = "预付直提 1-否 2-是")
+    private Integer cashFlag;
+
+    /**
+     * 状态 1-开户中 2-开户成功
+     */
+    @Schema(description = "状态")
+    private Integer status;
+    @Schema(description = "状态 1-开户中 2-开户成功")
+    private String statusLabel;
+
+    /**
+     * 备注
+     */
+    @TableField(value = "remark")
+    @Schema(description = "备注")
+    private String remark;
+
+    /**
+     * 创建人
+     */
+    @TableField(value = "create_by")
+    @Schema(description = "创建人")
+    private Long createBy;
+
+    /**
+     * 创建时间
+     */
+    @TableField(value = "create_time")
+    @Schema(description = "创建时间")
+    private LocalDateTime createTime;
+
+    /**
+     * 更新人
+     */
+    @Schema(description = "更新人")
+    private Long updateBy;
+
+    /**
+     * 更新时间
+     */
+    @Schema(description = "更新时间")
+    private LocalDateTime updateTime;
+
+}

+ 19 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/vo/req/CreateUserReq.java

@@ -0,0 +1,19 @@
+package com.sckw.payment.pojo.vo.req;
+
+import io.swagger.v3.oas.annotations.media.Schema;
+import jakarta.validation.constraints.NotNull;
+import lombok.Getter;
+import lombok.Setter;
+
+/**
+ * @author xucaiqin
+ * @date 2023-09-18 16:19:31
+ */
+@Getter
+@Setter
+@Schema(description = "开户参数")
+public class CreateUserReq {
+    @NotNull(message = "企业id不能为空")
+    @Schema(description = "企业id")
+    private Long entId;
+}

+ 30 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/vo/req/ReceivedCallbackDto.java

@@ -0,0 +1,30 @@
+package com.sckw.payment.pojo.vo.req;
+
+import com.alibaba.fastjson2.annotation.JSONField;
+import lombok.Data;
+import org.springframework.web.multipart.MultipartFile;
+
+import java.math.BigDecimal;
+
+/**
+ * 网银支付回调参数
+ *
+ * @author tangyishan
+ * @since 2026-01-28  15:18
+ */
+@Data
+public class ReceivedCallbackDto {
+    private String status;
+    private String msg;
+    private String customerNo;
+
+
+    private String tranNo;
+    private String uid;
+    private String filter;
+    private String orderNo;
+    private String payOrderNo;
+    private BigDecimal tranAmt;
+    @JSONField(serialize = false)
+    private MultipartFile file;
+}

+ 26 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/vo/req/WalletAccountInfoQuery.java

@@ -0,0 +1,26 @@
+package com.sckw.payment.pojo.vo.req;
+
+import jakarta.validation.constraints.NotBlank;
+import lombok.Data;
+
+/**
+ * @author tangyishan
+ * @since 2026-01-05  16:05
+ *  TODO
+ */
+@Data
+public class WalletAccountInfoQuery {
+    /**
+     * 企业开户接口返回的编号 优先级高于origTranNo
+     */
+    private String openacctNo;
+    /**
+     * 企业开户接口入参中的流水号 tran_no字段,目前对应为企业开户接口入参的orderNo字段
+     */
+    private String origTranNo;
+    /**
+     * 中信企业用户唯一id
+     */
+    @NotBlank(message = "客户编号不能为空")
+    private String customerNo;
+}

+ 26 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/vo/req/WalletPayableApplyPayDto.java

@@ -0,0 +1,26 @@
+package com.sckw.payment.pojo.vo.req;
+
+import io.swagger.v3.oas.annotations.media.Schema;
+import jakarta.validation.constraints.NotNull;
+import lombok.Data;
+
+import java.math.BigDecimal;
+
+/**
+ * 运费申请付款参数
+ *
+ * @author tangyishan
+ * @since 2026-01-20  11:12
+ */
+@Data
+public class WalletPayableApplyPayDto {
+    /** 待付代收运费清单id */
+    @NotNull(message = "待付代收运费清单id不能为空")
+    private Long payableId;
+    /** 申请金额 */
+    @NotNull(message = "申请金额不能为空")
+    private BigDecimal applyAmount;
+    /** 备注 */
+    @Schema(description = "备注")
+    private String remark;
+}

+ 19 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/vo/req/WalletPayableApplyQuery.java

@@ -0,0 +1,19 @@
+package com.sckw.payment.pojo.vo.req;
+
+import io.swagger.v3.oas.annotations.media.Schema;
+import jakarta.validation.constraints.NotNull;
+import lombok.Data;
+
+/**
+ * 运费申请付款记录查询参数
+ *
+ * @author tangyishan
+ * @since 2026-01-22  10:14
+ */
+@Data
+public class WalletPayableApplyQuery {
+    /** 待付/代收清单id */
+    @NotNull(message = "待付/代收清单id不能为空")
+    @Schema(description = "待付/代收清单id")
+    private Long payableId;
+}

+ 53 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/vo/req/WalletPayableBalanceQuery.java

@@ -0,0 +1,53 @@
+package com.sckw.payment.pojo.vo.req;
+
+import com.sckw.common.core.web.page.BaseQuery;
+import io.swagger.v3.oas.annotations.media.Schema;
+import jakarta.validation.constraints.Pattern;
+import lombok.Data;
+
+import java.math.BigDecimal;
+
+import static com.sckw.common.core.utils.DateUtils.dateTimeRegExp;
+
+/**
+ *
+ * 待付/代收运费余额明细查询参数
+ *
+ * @author tangyishan
+ * @since 2026-01-16  14:12
+ */
+@Data
+public class WalletPayableBalanceQuery extends BaseQuery {
+    /** 关联订单编号 */
+    @Schema(description = "关联订单编号")
+    private String orderNo;
+    /** 对方企业id */
+    @Schema(description = "对方企业id")
+    private Long tradeEntId;
+    /** 交易类型 3-收益 4-冻结 5-解冻 6-消费 9-人工录入 10-申请付款 11-付款成功 */
+    @Schema(description = "交易类型 3-收益 4-冻结 5-解冻 6-消费 9-人工录入 10-申请付款 11-付款成功")
+    private Integer tradeType;
+    /** 交易金额最小值 */
+    @Schema(description = "交易金额最小值")
+    private BigDecimal tradeAmountMin;
+    /** 交易金额最大值 */
+    @Schema(description = "交易金额最大值")
+    private BigDecimal tradeAmountMax;
+    /** 执行状态,1-进行中 2-成功 3-失败 */
+    @Schema(description = "执行状态,1-进行中 2-成功 3-失败")
+    private Integer status;
+    /** 开始时间 */
+    @Pattern(regexp = dateTimeRegExp, message = "查询开始时间格式不正确")
+    @Schema(description = "查询开始时间,yyyy-MM-dd HH:mm:ss")
+    private String startTime; // 开始时间
+    /** 结束时间 */
+    @Pattern(regexp = dateTimeRegExp, message = "查询结束时间格式不正确")
+    @Schema(description = "查询结束时间,yyyy-MM-dd HH:mm:ss")
+    private String endTime; // 结束时间
+    /** 当前企业id */
+    @Schema(hidden = true)
+    private Long curEntId;
+    /** 运费类型 1待付运费 2代收运费 */
+    @Schema(hidden = true)
+    private Integer freightType;
+}

+ 24 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/vo/req/WalletPayableConfirmPayDto.java

@@ -0,0 +1,24 @@
+package com.sckw.payment.pojo.vo.req;
+
+import io.swagger.v3.oas.annotations.media.Schema;
+import jakarta.validation.constraints.NotBlank;
+import jakarta.validation.constraints.NotNull;
+import lombok.Data;
+
+/**
+ * 运费付款确认
+ *
+ * @author tangyishan
+ * @since 2026-01-23  11:35
+ */
+@Data
+public class WalletPayableConfirmPayDto {
+    /** 待付/代收运费清单id */
+    @NotNull(message = "待付/代收运费清单id不能为空")
+    @Schema(description = "待付/代收运费清单id")
+    private Long payableId;
+    /** 申请付款记录订单号 */
+    @NotBlank(message = "申请付款记录订单号不能为空")
+    @Schema(description = "申请付款记录订单号")
+    private String orderNo;
+}

+ 45 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/vo/req/WalletPayableDto.java

@@ -0,0 +1,45 @@
+package com.sckw.payment.pojo.vo.req;
+
+import io.swagger.v3.oas.annotations.media.Schema;
+import jakarta.validation.constraints.NotNull;
+import lombok.Data;
+
+import java.math.BigDecimal;
+
+/**
+ * 运费清单初始化、冻结、解冻、消费
+ *
+ * @author tangyishan
+ * @since 2026-03-18  14:43
+ */
+@Data
+public class WalletPayableDto {
+    /** 托运企业id */
+    @NotNull(message = "托运企业id不能为空")
+    @Schema(description = "托运企业id")
+    private Long consignEntId;
+
+    /** 承运企业id */
+    @NotNull(message = "承运企业id不能为空")
+    @Schema(description = "承运企业id")
+    private Long carriageEntId;
+
+    /** 关联订单编号 */
+    @Schema(description = "关联订单编号")
+    private String orderNo;
+    /** 订单类型 5-物流订单号 6-支付订单号 */
+    @Schema(description = "订单类型 5-物流订单号 6-支付订单号")
+    private Integer orderType;
+
+
+    /** 交易类型 3-收益 4-冻结 5-解冻 6-消费 9-人工录入 10-申请付款 11-付款成功 */
+    @Schema(description = "交易类型 3-收益 4-冻结 5-解冻 6-消费 9-人工录入 10-申请付款 11-付款成功")
+    private Integer tradeType;
+
+    /** 交易金额 */
+    @Schema(description = "交易金额")
+    private BigDecimal tradeAmount;
+    /** 备注 */
+    @Schema(description = "备注")
+    private String remark;
+}

+ 37 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/vo/req/WalletPayableManualDto.java

@@ -0,0 +1,37 @@
+package com.sckw.payment.pojo.vo.req;
+
+import io.swagger.v3.oas.annotations.media.Schema;
+import jakarta.validation.constraints.NotNull;
+import lombok.Data;
+
+import java.math.BigDecimal;
+import java.util.List;
+
+/**
+ *
+ * 运费清单人工录入参数
+ *
+ * @author tangyishan
+ * @since 2026-01-16  15:01
+ */
+@Data
+public class WalletPayableManualDto {
+    /** 对方企业id */
+    @Schema(description = "对方企业id")
+    @NotNull(message = "对方企业id不能为空")
+    private Long tradeEntId;
+    /** 运费类型 */
+    @NotNull(message = "运费类型不能为空")
+    @Schema(description = "运费类型,1-待付运费,2付款中运费")
+    private Integer freightType;
+    /** 交易金额 */
+    @Schema(description = "交易金额")
+    @NotNull(message = "交易金额不能为空")
+    private BigDecimal tradeAmount;
+    /** 备注 */
+    @Schema(description = "备注")
+    private String remark;
+    /** 凭证文件地址 */
+    @Schema(description = "凭证文件地址")
+    private List<String> voucherFiles;
+}

+ 34 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/vo/req/WalletPayablePayQuery.java

@@ -0,0 +1,34 @@
+package com.sckw.payment.pojo.vo.req;
+
+import com.sckw.common.core.web.page.BaseQuery;
+import io.swagger.v3.oas.annotations.media.Schema;
+import jakarta.validation.constraints.NotNull;
+import jakarta.validation.constraints.Pattern;
+import lombok.Data;
+
+import static com.sckw.common.core.utils.DateUtils.dateTimeRegExp;
+
+/**
+ * 运费支付记录查询列表参数
+ *
+ * @author tangyishan
+ * @since 2026-01-16  09:13
+ */
+@Data
+public class WalletPayablePayQuery extends BaseQuery {
+    /** 预付清单id */
+    @Schema(description = "运费清单id")
+    @NotNull
+    private Long payableId;
+    /** 支付状态,0-等待支付 2-支付成功*/
+    @Schema(description = "付状态,0-等待支付 2-支付成功")
+    private Integer status;
+    /** 开始时间 */
+    @Pattern(regexp = dateTimeRegExp, message = "查询开始时间格式不正确")
+    @Schema(description = "查询开始时间,yyyy-MM-dd HH:mm:ss")
+    private String startTime; // 开始时间
+    /** 结束时间 */
+    @Pattern(regexp = dateTimeRegExp, message = "查询结束时间格式不正确")
+    @Schema(description = "查询结束时间,yyyy-MM-dd HH:mm:ss")
+    private String endTime; // 结束时间
+}

+ 44 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/vo/req/WalletPayableQuery.java

@@ -0,0 +1,44 @@
+package com.sckw.payment.pojo.vo.req;
+
+import com.sckw.common.core.web.page.BaseQuery;
+import io.swagger.v3.oas.annotations.media.Schema;
+import lombok.Data;
+
+import java.math.BigDecimal;
+
+/**
+ * 待付/代收运费清单查询参数
+ *
+ * @author tangyishan
+ * @since 2026-01-15  15:47
+ */
+@Data
+public class WalletPayableQuery extends BaseQuery {
+    /** 当前企业id */
+    @Schema(hidden = true)
+    private Long curEntId;
+    /** 对方企业id */
+    @Schema(description = "对方企业id")
+    private Long tradeEntId;
+    /** 待付/代收运费最小值 */
+    @Schema(description = "待付/代收运费最小值")
+    private BigDecimal freightMin;
+    /** 待付/代收运费最大值 */
+    @Schema(description = "待付/代收运费最大值")
+    private BigDecimal freightMax;
+    /** 进行中运费最小值 */
+    @Schema(description = "进行中运费最小值")
+    private BigDecimal tradingFreightMin;
+    /** 进行中运费最大值 */
+    @Schema(description = "进行中运费最大值")
+    private BigDecimal tradingFreightMax;
+    /** 付款中运费最小值 */
+    @Schema(description = "付款中运费最小值")
+    private BigDecimal payingFreightMin;
+    /** 付款中运费最大值 */
+    @Schema(description = "付款中运费最大值")
+    private BigDecimal payingFreightMax;
+    /** 运费类型 1待付运费 2代收运费 */
+    @Schema(hidden = true)
+    private Integer freightType;
+}

+ 30 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/vo/req/WalletPrepaidAddDto.java

@@ -0,0 +1,30 @@
+package com.sckw.payment.pojo.vo.req;
+
+import io.swagger.v3.oas.annotations.media.Schema;
+import jakarta.validation.constraints.Min;
+import jakarta.validation.constraints.NotNull;
+import lombok.Data;
+
+import java.math.BigDecimal;
+
+/**
+ * 采购商预付参数
+ *
+ * @author tangyishan
+ * @since 2026-01-15  11:08
+ */
+@Data
+public class WalletPrepaidAddDto {
+    /** 预付清单id */
+    @NotNull(message = "预付清单id不能为空")
+    @Schema(description = "预付清单id")
+    private Long prepaidId;
+    /** 预付金额 */
+    @Min(value = 0, message = "预付金额不能小于0")
+    @NotNull(message = "预付金额不能为空")
+    @Schema(description = "预付金额")
+    private BigDecimal prepaidAmount;
+    /** 备注 */
+    @Schema(description = "备注")
+    private String remark;
+}

+ 52 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/vo/req/WalletPrepaidBalanceQuery.java

@@ -0,0 +1,52 @@
+package com.sckw.payment.pojo.vo.req;
+
+import com.sckw.common.core.web.page.BaseQuery;
+import io.swagger.v3.oas.annotations.media.Schema;
+import jakarta.validation.constraints.Pattern;
+import lombok.Data;
+
+import java.math.BigDecimal;
+
+import static com.sckw.common.core.utils.DateUtils.dateTimeRegExp;
+
+/**
+ * 待履约/预付余额明细查询参数
+ *
+ * @author tangyishan
+ * @since 2026-01-14  10:17
+ */
+@Data
+public class WalletPrepaidBalanceQuery extends BaseQuery {
+    /** 关联订单编号 */
+    @Schema(description = "关联订单编号")
+    private String orderNo;
+    /** 对方企业id */
+    @Schema(description = "对方企业id")
+    private Long tradeEntId;
+    /** 交易类型 2-预付 3-收益 4-冻结 5-解冻 6-消费 9-人工录入 */
+    @Schema(description = "交易类型 2-预付 3-收益 4-冻结 5-解冻 6-消费 9-人工录入")
+    private Integer tradeType;
+    /** 交易金额最小值 */
+    @Schema(description = "交易金额最小值")
+    private BigDecimal tradeAmountMin;
+    /** 交易金额最大值 */
+    @Schema(description = "交易金额最大值")
+    private BigDecimal tradeAmountMax;
+    /** 执行状态,1-进行中 2-成功 3-失败 */
+    @Schema(description = "执行状态,1-进行中 2-成功 3-失败")
+    private Integer status;
+    /** 开始时间 */
+    @Pattern(regexp = dateTimeRegExp, message = "查询开始时间格式不正确")
+    @Schema(description = "查询开始时间,yyyy-MM-dd HH:mm:ss")
+    private String startTime; // 开始时间
+    /** 结束时间 */
+    @Pattern(regexp = dateTimeRegExp, message = "查询结束时间格式不正确")
+    @Schema(description = "查询结束时间,yyyy-MM-dd HH:mm:ss")
+    private String endTime; // 结束时间
+    /** 当前企业id */
+    @Schema(hidden = true)
+    private Long curEntId;
+    /** 企业类型 1供应商 2采购商 */
+    @Schema(hidden = true)
+    private Integer entType;
+}

+ 42 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/vo/req/WalletPrepaidDto.java

@@ -0,0 +1,42 @@
+package com.sckw.payment.pojo.vo.req;
+
+import io.swagger.v3.oas.annotations.media.Schema;
+import lombok.Data;
+
+import java.math.BigDecimal;
+
+/**
+ * 预付清单初始化、冻结、解冻、消费
+ *
+ * @author tangyishan
+ * @since 2026-03-06  08:46
+ */
+@Data
+public class WalletPrepaidDto {
+    //采购商企业id
+    @Schema(description = "采购商企业id")
+    private Long proEntId;
+    //供应商id
+    @Schema(description = "供应商企业id")
+    private Long supEntId;
+    //关联订单编号
+    @Schema(description = "关联订单编号")
+    private String orderNo;
+
+    /** 订单类型 2-预付订单  4-贸易订单 */
+    @Schema(description = "订单类型 2-预付订单  4-贸易订单")
+    private Integer orderType;
+
+
+    /** 交易类型 2-预付 3-收益 4-冻结 5-解冻 6-消费 9-人工录入 */
+    @Schema(description = "交易类型 2-预付 3-收益 4-冻结 5-解冻 6-消费 9-人工录入")
+    private Integer tradeType;
+
+    //交易金额
+    @Schema(description = "交易金额")
+    private BigDecimal tradeAmount;
+
+    //备注
+    @Schema(description = "备注")
+    private String remark;
+}

+ 29 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/vo/req/WalletPrepaidManualDto.java

@@ -0,0 +1,29 @@
+package com.sckw.payment.pojo.vo.req;
+
+import io.swagger.v3.oas.annotations.media.Schema;
+import lombok.Data;
+
+import java.math.BigDecimal;
+import java.util.List;
+
+/**
+ * 待履约/预付人工录入参数
+ *
+ * @author tangyishan
+ * @since 2026-01-12  11:18
+ */
+@Data
+public class WalletPrepaidManualDto {
+    /** 对方企业id */
+    @Schema(description = "对方企业id")
+    private Long tradeEntId;
+    /** 交易金额 */
+    @Schema(description = "交易金额")
+    private BigDecimal tradeAmount;
+    /** 备注 */
+    @Schema(description = "备注")
+    private String remark;
+    /** 凭证文件地址 */
+    @Schema(description = "凭证文件地址")
+    private List<String> voucherFiles;
+}

+ 31 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/vo/req/WalletPrepaidQuery.java

@@ -0,0 +1,31 @@
+package com.sckw.payment.pojo.vo.req;
+
+import com.sckw.common.core.web.page.BaseQuery;
+import io.swagger.v3.oas.annotations.media.Schema;
+import lombok.Data;
+
+import java.math.BigDecimal;
+
+/**
+ * @author tangyishan
+ * @since 2026-01-08  10:18
+ *  待履约/预付列表查询参数
+ */
+@Data
+public class WalletPrepaidQuery extends BaseQuery {
+    /** 当前企业id */
+    @Schema(hidden = true)
+    private Long curEntId;
+    /** 对方企业id */
+    @Schema(description = "对方企业id")
+    private Long tradeEntId;
+    /** 待履约/预付余额最小值 */
+    @Schema(description = "待履约/预付余额最小值 ")
+    private BigDecimal balanceMin;
+    /** 待履约/预付余额最大值 */
+    @Schema(description = "待履约/预付余额最大值 ")
+    private BigDecimal balanceMax;
+    /** 企业类型 1供应商 2采购商 */
+    @Schema(hidden = true)
+    private Integer entType;
+}

+ 36 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/vo/req/WalletPrepaidRecordQuery.java

@@ -0,0 +1,36 @@
+package com.sckw.payment.pojo.vo.req;
+
+import com.sckw.common.core.web.page.BaseQuery;
+import io.swagger.v3.oas.annotations.media.Schema;
+import jakarta.validation.constraints.NotNull;
+import jakarta.validation.constraints.Pattern;
+import lombok.Data;
+import lombok.EqualsAndHashCode;
+
+import static com.sckw.common.core.utils.DateUtils.dateTimeRegExp;
+
+/**
+ * 预付支付记录查询参数
+ *
+ * @author tangyishan
+ * @since 2026-01-15  14:17
+ */
+@EqualsAndHashCode(callSuper = true)
+@Data
+public class WalletPrepaidRecordQuery extends BaseQuery {
+    /** 预付清单id */
+    @Schema(description = "预付清单id")
+    @NotNull(message = "预付清单id不能为空")
+    private Long prepaidId;
+    /** 支付状态,0-等待支付 2-支付成功*/
+    @Schema(description = "付状态,0-等待支付 1-支付成功")
+    private Integer status;
+    /** 开始时间 */
+    @Pattern(regexp = dateTimeRegExp, message = "查询开始时间格式不正确")
+    @Schema(description = "查询开始时间,yyyy-MM-dd HH:mm:ss")
+    private String startTime; // 开始时间
+    /** 结束时间 */
+    @Pattern(regexp = dateTimeRegExp, message = "查询结束时间格式不正确")
+    @Schema(description = "查询结束时间,yyyy-MM-dd HH:mm:ss")
+    private String endTime; // 结束时间
+}

+ 16 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/vo/req/WalletQueryDto.java

@@ -0,0 +1,16 @@
+package com.sckw.payment.pojo.vo.req;
+
+import lombok.Data;
+
+/**
+ * @author tangyishan
+ * @since 2026-01-05  15:01
+ *  钱包查询参数
+ */
+@Data
+public class WalletQueryDto {
+    /**
+     * 企业id
+     */
+    private Long entId;
+}

+ 31 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/vo/res/FinancialReportRes.java

@@ -0,0 +1,31 @@
+package com.sckw.payment.pojo.vo.res;
+
+import io.swagger.v3.oas.annotations.media.Schema;
+import lombok.Data;
+
+import java.math.BigDecimal;
+
+/**
+ * 财务报表响应结果
+ *
+ * @author tangys
+ * @since 2026-04-27
+ */
+@Data
+public class FinancialReportRes {
+
+    @Schema(description = "序号")
+    private Integer serialNumber;
+
+    @Schema(description = "客户名称")
+    private String entName;
+
+    @Schema(description = "预存款(元)")
+    private BigDecimal preDeposit = BigDecimal.ZERO;
+
+    @Schema(description = "累计预存款(元)")
+    private BigDecimal totalPreDeposit = BigDecimal.ZERO;
+
+    @Schema(description = "剩余预存款(元)")
+    private BigDecimal remainingPreDeposit = BigDecimal.ZERO;
+}

+ 89 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/vo/res/HttpResult.java

@@ -0,0 +1,89 @@
+package com.sckw.payment.pojo.vo.res;
+
+import com.sckw.common.core.web.page.HttpStatus;
+import lombok.Data;
+
+import java.io.Serializable;
+
+/**
+ * HTTP结果封装
+ * @author zk
+ * @date Oct 29, 2018
+ */
+@Data
+public class HttpResult implements Serializable {
+
+	private int code = HttpStatus.SUCCESS_CODE;
+	private String msg = HttpStatus.SUCCESS_MESSAGE;
+	private Object data;
+
+	public static HttpResult error() {
+		return error(HttpStatus.GLOBAL_EXCEPTION_CODE, HttpStatus.GLOBAL_EXCEPTION_MESSAGE);
+	}
+
+	public static HttpResult error(String msg) {
+		return error(HttpStatus.GLOBAL_EXCEPTION_CODE, msg);
+	}
+
+	public static HttpResult error(int code, String msg) {
+		HttpResult r = new HttpResult();
+		r.setCode(code);
+		r.setMsg(msg);
+		return r;
+	}
+
+	public static HttpResult error(String msg, Object data) {
+		HttpResult r = new HttpResult();
+		r.setCode(HttpStatus.GLOBAL_EXCEPTION_CODE);
+		r.setMsg(msg);
+		r.setData(data);
+		return r;
+	}
+
+	public static HttpResult error(int code, String msg, Object data) {
+		HttpResult r = new HttpResult();
+		r.setCode(code);
+		r.setMsg(msg);
+		r.setData(data);
+		return r;
+	}
+
+
+	public static HttpResult ok() {
+		return new HttpResult();
+	}
+
+	public static HttpResult ok(String msg) {
+		HttpResult r = new HttpResult();
+		r.setMsg(msg);
+		return r;
+	}
+
+	public static HttpResult ok(Object data) {
+		HttpResult r = new HttpResult();
+		r.setData(data);
+		return r;
+	}
+
+    public static HttpResult ok(int code, String msg) {
+        HttpResult r = new HttpResult();
+        r.setCode(code);
+        r.setMsg(msg);
+        return r;
+    }
+
+	public static HttpResult ok(String msg, Object data) {
+		HttpResult r = new HttpResult();
+		r.setMsg(msg);
+		r.setData(data);
+		return r;
+	}
+
+    public static HttpResult ok(int code,String msg, Object data) {
+        HttpResult r = new HttpResult();
+        r.setCode(code);
+        r.setMsg(msg);
+        r.setData(data);
+        return r;
+    }
+}

+ 38 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/vo/res/WalletPayAddRes.java

@@ -0,0 +1,38 @@
+package com.sckw.payment.pojo.vo.res;
+
+import com.fasterxml.jackson.annotation.JsonFormat;
+import io.swagger.v3.oas.annotations.media.Schema;
+import lombok.Data;
+
+import java.math.BigDecimal;
+
+/**
+ * 添加支付记录响应参数
+ *
+ * @author tangyishan
+ * @since 2026-01-15  13:41
+ */
+@Data
+public class WalletPayAddRes {
+
+    /** 预付支付记录主键id */
+    @JsonFormat(shape = JsonFormat.Shape.STRING)
+    @Schema(description = "预付支付记录主键id")
+    private Long id;
+    /** 支付订单号 */
+    @JsonFormat(shape = JsonFormat.Shape.STRING)
+    @Schema(description = "支付订单号")
+    private String orderNo;
+    /**收款户名 */
+    @Schema(description = "收款户名")
+    private String settleAcctName;
+    /**收款账号 */
+    @Schema(description = "收款账号")
+    private String settleAcctNo;
+    /** 支付金额 */
+    @Schema(description = "支付金额")
+    private BigDecimal amount;
+    /**收款银行 */
+    @Schema(description = "收款银行")
+    private String bankName;
+}

+ 28 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/vo/res/WalletPayableApplyRes.java

@@ -0,0 +1,28 @@
+package com.sckw.payment.pojo.vo.res;
+
+import io.swagger.v3.oas.annotations.media.Schema;
+import lombok.Data;
+
+import java.math.BigDecimal;
+
+/**
+ * 运费申请付款记录
+ *
+ * @author tangyishan
+ * @since 2026-01-22  10:09
+ */
+@Data
+public class WalletPayableApplyRes {
+    /** 申请订单号 */
+    @Schema(description = "申请订单号")
+    private String orderNo;
+    /** 申请金额 */
+    @Schema(description = "申请金额")
+    private BigDecimal applyAmount;
+    /** 未付金额 */
+    @Schema(description = "未付金额")
+    private BigDecimal unpaidAmount;
+    /** 备注 */
+    @Schema(description = "备注")
+    private String remark;
+}

+ 69 - 0
sckw-modules/sckw-payment/src/main/java/com/sckw/payment/pojo/vo/res/WalletPayableBalanceRes.java

@@ -0,0 +1,69 @@
+package com.sckw.payment.pojo.vo.res;
+
+import com.fasterxml.jackson.annotation.JsonFormat;
+import io.swagger.v3.oas.annotations.media.Schema;
+import lombok.Data;
+
+import java.math.BigDecimal;
+import java.util.Date;
+
+/**
+ * 待付/代收运费余额明细响应参数
+ *
+ * @author tangyishan
+ * @since 2026-01-16  13:55
+ */
+@Data
+public class WalletPayableBalanceRes {
+    /** 待付/代收运费余额明细主键id */
+    @Schema(description = "待付/代收运费余额明细主键id")
+    @JsonFormat(shape = JsonFormat.Shape.STRING)
+    private Long id;
+    /** 关联订单编号 */
+    @Schema(description = "关联订单编号")
+    private String orderNo;
+    /** 订单类型 5-物流订单号 6-支付订单号 */
+    @Schema(description = "订单类型 5-物流订单号 6-支付订单号")
+    private Integer orderType;
+    /** 对方企业id */
+    @Schema(description = "对方企业id")
+    @JsonFormat(shape = JsonFormat.Shape.STRING)
+    private Long tradeEntId;
+    /** 对方企业企业名称 */
+    @Schema(description = "对方企业企业名称")
+    private String tradeEntName;
+    /** 交易类型 3-收益 4-冻结 5-解冻 6-消费 9-人工录入 10-申请付款 11-付款成功 */
+    @Schema(description = "交易类型 3-收益 4-冻结 5-解冻 6-消费 9-人工录入 10-申请付款 11-付款成功")
+    private Integer tradeType;
+    /** 交易类型描述 */
+    @Schema(description = "交易类型描述")
+    private String tradeTypeDesc;
+    /** 交易金额 */
+    @Schema(description = "交易金额")
+    private BigDecimal tradeAmount;
+    /** 待付/代收运费 */
+    @Schema(description = "待付/代收运费")
+    private BigDecimal freight;
+    /** 进行中运费 */
+    @Schema(description = "进行中运费")
+    private BigDecimal tradingFreight;
+    /** 付款中运费 */
+    @Schema(description = "付款中运费")
+    private BigDecimal payingFreight;
+    /** 执行状态,1-进行中 2-成功 3-失败 */
+    @Schema(description = "执行状态,1-进行中 2-成功 3-失败")
+    private Integer status;
+    /** 执行状态描述 */
+    @Schema(description = "执行状态描述")
+    private String statusDesc;
+    /** 备注 */
+    @Schema(description = "备注")
+    private String remark;
+    /** 凭证标识 0-无凭证 1-有凭证 */
+    @Schema(description = "凭证标识 0-无凭证 1-有凭证")
+    private Integer voucherFlag;
+    /** 创建时间 */
+    @Schema(description = "创建时间")
+    @JsonFormat(timezone = "GMT+8", pattern = "yyyy-MM-dd HH:mm:ss")
+    private Date createTime;
+}

Некоторые файлы не были показаны из-за большого количества измененных файлов