From 87f979fb201a82ebad5926735ed6dfa75ca004d3 Mon Sep 17 00:00:00 2001 From: liujie <1793218484@qq.com> Date: 星期一, 21 七月 2025 09:21:42 +0800 Subject: [PATCH] 修改bug --- ruoyi-applet/src/main/java/com/ruoyi/web/controller/system/OrderController.java | 202 +++++++++++++++++++++++++++++++++----------------- 1 files changed, 133 insertions(+), 69 deletions(-) diff --git a/ruoyi-applet/src/main/java/com/ruoyi/web/controller/system/OrderController.java b/ruoyi-applet/src/main/java/com/ruoyi/web/controller/system/OrderController.java index f9b70b9..c89460c 100644 --- a/ruoyi-applet/src/main/java/com/ruoyi/web/controller/system/OrderController.java +++ b/ruoyi-applet/src/main/java/com/ruoyi/web/controller/system/OrderController.java @@ -1,14 +1,14 @@ package com.ruoyi.web.controller.system; -import com.alibaba.fastjson.JSONObject; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; -import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.github.binarywang.wxpay.bean.order.WxPayMpOrderResult; import com.github.binarywang.wxpay.exception.WxPayException; +import com.ruoyi.common.constant.HttpStatus; import com.ruoyi.common.core.domain.R; import com.ruoyi.common.core.domain.model.LoginUser; +import com.ruoyi.common.utils.AliSmsUtil; import com.ruoyi.common.utils.StringUtils; import com.ruoyi.framework.web.service.TokenService; import com.ruoyi.system.dto.AddBuyerCompanyInfoDto; @@ -25,9 +25,8 @@ import org.springframework.web.bind.annotation.*; import javax.validation.Valid; -import java.io.UnsupportedEncodingException; -import java.math.BigDecimal; -import java.net.MalformedURLException; +import java.util.Date; +import java.util.HashMap; @Slf4j @RestController @@ -57,16 +56,26 @@ @Autowired private TbAccountDetailService accountDetailService; + @Autowired + private TbUserService userService; + + @Autowired + private TbAgreementService agreementService; - - @ApiOperation(value = "获取我的订单",tags = {"订单模块"}) + @ApiOperation(value = "获取我的订单", tags = {"订单模块"},response =MyPushCompanyListVo.class ) @GetMapping("/getMyOrderList") - public R<Page<MyPushCompanyListVo>> getMyOrderList(MyOrderListQuery query) { + public R<HashMap<String, Object>> getMyOrderList(MyOrderListQuery query) { LoginUser loginUser = tokenService.getLoginUser(); + if(loginUser==null){ + return R.fail(HttpStatus.UNAUTHORIZED,"请重新登录"); + } Long userId = loginUser.getUserId(); - Page<MyPushCompanyListVo> page = orderService.getMyOrderList(query,userId); - return R.ok(page); + Page<MyPushCompanyListVo> page = orderService.getMyOrderList(query, userId); + HashMap<String, Object> map = new HashMap<>(); + map.put("data",page); + map = orderService.getMyOrderListNum(userId,map); + return R.ok(map); } @@ -75,122 +84,169 @@ * @param * @return */ - @ApiOperation(value = "立即支付前填写信息",tags = {"订单模块"}) + @ApiOperation(value = "立即支付前填写信息", tags = {"订单模块"}) @PostMapping("/lastPayOrderData") - public R<?> lastPayOrderData(@RequestBody @Valid AddBuyerCompanyInfoDto dto) { + public synchronized R<WxPayMpOrderResult> lastPayOrderData(@RequestBody @Valid AddBuyerCompanyInfoDto dto) { LoginUser loginUser = tokenService.getLoginUser(); + if(loginUser==null){ + return R.fail(HttpStatus.UNAUTHORIZED,"请重新登录"); + } Long userId = loginUser.getUserId(); TbOrder tbOrder = orderService.getById(dto.getOrderId()); - if(dto.getNeedRename()==1){ - if(StringUtils.isEmpty(dto.getBackupsName())){ + if (dto.getNeedRename() == 1) { + if (StringUtils.isEmpty(dto.getBackupsName())) { return R.fail("请填写备选名称"); } } - if(!tbOrder.getUserId().equals(userId.toString())){ + if (!tbOrder.getUserId().equals(userId.toString())) { return R.fail("非法操作"); } - if(tbOrder.getStatus()!=3){ + if (tbOrder.getStatus() != 3) { return R.fail("订单状态错误"); } TbCompany company = companyService.getById(tbOrder.getCompanyId()); // 判断是否在支付前下架了 或者删除了 - if(company==null || company.getStatus()!=1 || company.getIsDelete()==1){ + if (company == null || company.getStatus() == 2 || company.getIsDelete() == 1) { return R.fail("该公司已下架或者删除"); } - long count = buyerCompanyInfoService.count(new LambdaQueryWrapper<TbBuyerCompanyInfo>().eq(TbBuyerCompanyInfo::getOrderId, dto.getOrderId())); - if(count>0){ - return R.fail("请勿重复填写"); - } - orderService.lastPayOrderData(tbOrder,dto,userId,company); - return R.ok(); + TbBuyerCompanyInfo one = buyerCompanyInfoService.getOne(new LambdaQueryWrapper<TbBuyerCompanyInfo>().eq(TbBuyerCompanyInfo::getOrderId, dto.getOrderId())); + orderService.lastPayOrderData(tbOrder, dto, userId, company,one); + R<WxPayMpOrderResult> wxPayMpOrderResultR = payOrder(dto.getOrderId()); + return wxPayMpOrderResultR; } - - @ApiOperation(value = "立即支付",tags = {"订单模块"}) + @ApiOperation(value = "立即支付", tags = {"订单模块"}) @PostMapping("/payOrder") public R<WxPayMpOrderResult> payOrder(String orderId) { - if(StringUtils.isEmpty(orderId)){ + if (StringUtils.isEmpty(orderId)) { R.fail("订单id不能为空"); } LoginUser loginUser = tokenService.getLoginUser(); + if(loginUser==null){ + return R.fail(HttpStatus.UNAUTHORIZED,"请重新登录"); + } Long userId = loginUser.getUserId(); TbOrder tbOrder = orderService.getById(orderId); - if(!tbOrder.getUserId().equals(userId.toString())){ + if (!tbOrder.getUserId().equals(userId.toString())) { return R.fail("非法操作"); } - if(tbOrder.getStatus()!=3){ + + TbUser user = userService.getById(userId); + if(StringUtils.isEmpty(user.getOpenId())){ + return R.fail(602,"需要授权微信小程序"); + } + + if (tbOrder.getStatus() != 3) { return R.fail("订单状态错误"); } TbCompany company = companyService.getById(tbOrder.getCompanyId()); // 判断是否在支付前下架了 或者删除了 - if(company==null || company.getStatus()!=1 || company.getIsDelete()==1){ + if (company == null || company.getStatus() == 2 || company.getIsDelete() == 1) { return R.fail("该公司已下架或者删除"); } - long count = buyerCompanyInfoService.count(new LambdaQueryWrapper<TbBuyerCompanyInfo>().eq(TbBuyerCompanyInfo::getOrderId,orderId)); - if(count==0){ + long count = buyerCompanyInfoService.count(new LambdaQueryWrapper<TbBuyerCompanyInfo>().eq(TbBuyerCompanyInfo::getOrderId, orderId)); + if (count == 0) { return R.fail("请先填写信息"); } - WxPayMpOrderResult result = orderService.payOrder(tbOrder,userId); + WxPayMpOrderResult result = orderService.payOrder(tbOrder, userId); return R.ok(result); } - - @ApiOperation(value = "下单预定",tags = {"订单模块"}) + @ApiOperation(value = "下单预定", tags = {"订单模块"}) @PostMapping("/placeOrder") public synchronized R<?> placeOrder(String companyId) { - if(StringUtils.isEmpty(companyId)){ - R.fail("id不能为空"); + if (StringUtils.isEmpty(companyId)) { + return R.fail("id不能为空"); } LoginUser loginUser = tokenService.getLoginUser(); + if(loginUser==null){ + return R.fail(HttpStatus.UNAUTHORIZED,"请重新登录"); + } Long userId = loginUser.getUserId(); // 查看现在是否可以单 判断这个公司是否上架 是否已经产生的了订单 TbCompany company = companyService.getById(companyId); - if(company.getStatus()!=1){ + if (company == null) { + return R.fail("公司不存在"); + } + if (company.getUserId().equals(userId.toString())) { + return R.fail("不能预定自己发布的公司"); + } + + if (company.getStatus() == 2) { return R.fail("公司未上架"); } + if (company.getStatus() == 3) { + return R.fail("公司已售卖"); + } + if (company.getStatus() == 4) { + return R.fail("公司已被预定"); + } // long count = orderService.count(new LambdaQueryWrapper<TbOrder>().eq(TbOrder::getCompanyId, companyId).ne(TbOrder::getStatus, -1)); - if (company.getStatus()==4) { + if (company.getStatus() == 4) { return R.fail("改公司已被预定"); } - orderService.placeOrder(companyId,company,userId); - return R.ok(); + String orderId = orderService.placeOrder(companyId, company, userId); + messageService.addMessage("买家申请了交易", company.getUserId(), orderId,1); + + TbUser user = userService.getById(company.getUserId()); + AliSmsUtil.sendSuccessMessageSeller(user.getPhone()); + return R.ok(orderId); + } + + @ApiOperation(value = "下单预定-获取信息", tags = {"订单模块"}) + @GetMapping("/placeOrderInfo") + public R<?> placeOrderInfo(String companyId) { + if (StringUtils.isEmpty(companyId)) { + R.fail("id不能为空"); + } + TbCompany company = companyService.getById(companyId); + String information = company.getInformation(); + HashMap<String, String> map = new HashMap<>(); + map.put("information", information); + TbAgreement one = agreementService.getOne(new LambdaQueryWrapper<TbAgreement>().eq(TbAgreement::getType, 3)); + map.put("agreement", one.getContent()); + return R.ok(map); } - @ApiOperation(value = "买家完成订单",tags = {"订单模块"}) + @ApiOperation(value = "买家完成订单", tags = {"订单模块"}) @PostMapping("/buyerSuccessOrder") public synchronized R<?> buyerSuccessOrder(String orderId) { - if(StringUtils.isEmpty(orderId)){ + if (StringUtils.isEmpty(orderId)) { R.fail("订单id不能为空"); } LoginUser loginUser = tokenService.getLoginUser(); + if(loginUser==null){ + return R.fail(HttpStatus.UNAUTHORIZED,"请重新登录"); + } Long userId = loginUser.getUserId(); TbOrder order = orderService.getById(orderId); - if(order==null){ + if (order == null) { return R.fail("订单不存在"); } TbCompany company = companyService.getById(order.getCompanyId()); if (!order.getUserId().equals(userId.toString())) { return R.fail("非法操作"); } - if(order.getStatus()!=5){ + if (order.getStatus() != 5) { return R.fail("该订单状态不能完成"); } // 订单完成 商品已售卖 order.setStatus(6); + order.setFinishTime( new Date()); + order.updateById(); company.setStatus(3); - // 分佣 - orderService.commission(order,company.getUserId()); - + // 结算 + orderService.commission(order, company.getUserId()); // 卖家账户明细记录更新 - TbAccountDetail one = accountDetailService.getOne(new LambdaQueryWrapper<TbAccountDetail>().eq(TbAccountDetail::getOrderId, orderId).eq(TbAccountDetail::getCategory, 2)); + TbAccountDetail one = accountDetailService.getOne(new LambdaQueryWrapper<TbAccountDetail>().eq(TbAccountDetail::getUserId,company.getUserId()).eq(TbAccountDetail::getOrderId, orderId).eq(TbAccountDetail::getCategory, 2)); if (one != null) { one.setStatus(2); one.updateById(); @@ -202,71 +258,80 @@ } - @ApiOperation(value = "买家回复进度",tags = {"订单模块"}) + @ApiOperation(value = "买家回复进度", tags = {"订单模块"}) @PostMapping("/buyerAddSchedule") public synchronized R<?> buyerAddSchedule(@RequestBody @Valid AddScheduleDto dto) { LoginUser loginUser = tokenService.getLoginUser(); + if(loginUser==null){ + return R.fail(HttpStatus.UNAUTHORIZED,"请重新登录"); + } Long userId = loginUser.getUserId(); TbOrder order = orderService.getById(dto.getOrderId()); - if(order==null){ + if (order == null) { return R.fail("订单不存在"); } if (!order.getUserId().equals(userId.toString())) { return R.fail("非法操作"); } - if(order.getStatus()!=4){ + if (order.getStatus() != 4) { return R.fail("该订单状态不能回复"); } - scheduleService.buyerAddSchedule(dto,userId); + scheduleService.buyerAddSchedule(dto, userId); String userId1 = companyService.getById(order.getCompanyId()).getUserId(); - messageService.addMessage("您的订单有新的回复", userId1,order.getId()); + messageService.addMessage("您的订单有新的回复", userId1, order.getId(),1); return R.ok(); } - @ApiOperation(value = "买家取消订单",tags = {"订单模块"}) + @ApiOperation(value = "买家取消订单", tags = {"订单模块"}) @PostMapping("/buyerCancelOrder") public synchronized R<?> buyerCancelOrder(String orderId) { - if(StringUtils.isEmpty(orderId)){ + if (StringUtils.isEmpty(orderId)) { R.fail("订单id不能为空"); } LoginUser loginUser = tokenService.getLoginUser(); + if(loginUser==null){ + return R.fail(HttpStatus.UNAUTHORIZED,"请重新登录"); + } Long userId = loginUser.getUserId(); TbOrder order = orderService.getById(orderId); - if(order==null){ + if (order == null) { return R.fail("订单不存在"); } if (!order.getUserId().equals(userId.toString())) { return R.fail("非法操作"); } - if(order.getStatus()!=3){ + if (order.getStatus() != 3 && order.getStatus() != 2) { return R.fail("该订单状态不能取消"); } TbCompany company = companyService.getById(order.getCompanyId()); company.setStatus(1); company.updateById(); order.setStatus(-1); + order.setCancelType(2); order.updateById(); - messageService.addMessage("您发布的订单买家已取消", company.getUserId(),order.getId()); + messageService.addMessage("您发布的订单买家已取消", company.getUserId(), order.getId(),1); return R.ok(); } - - @ApiOperation(value = "编辑办理进度",tags = {"发布模块"}) + @ApiOperation(value = "编辑办理进度", tags = {"发布模块"}) @PostMapping("/updateSchedule") public R<?> updateSchedule(@RequestBody @Valid EditScheduleDto dto) { LoginUser loginUser = tokenService.getLoginUser(); + if(loginUser==null){ + return R.fail(HttpStatus.UNAUTHORIZED,"请重新登录"); + } Long userId = loginUser.getUserId(); TbSchedule schedule = scheduleService.getById(dto.getScheduleId()); - if(schedule==null){ + if (schedule == null) { return R.fail("进度不存在"); } - if(!schedule.getUserId().equals(userId.toString())){ + if (!schedule.getUserId().equals(userId.toString())) { return R.fail("非法操作"); } schedule.setText(dto.getText()); @@ -276,24 +341,24 @@ } - @ApiOperation(value = "删除办理进度",tags = {"发布模块"}) + @ApiOperation(value = "删除办理进度", tags = {"发布模块"}) @DeleteMapping("/delSchedule/{scheduleId}") public R<?> delSchedule(@PathVariable("scheduleId") String scheduleId) { LoginUser loginUser = tokenService.getLoginUser(); + if(loginUser==null){ + return R.fail(HttpStatus.UNAUTHORIZED,"请重新登录"); + } Long userId = loginUser.getUserId(); TbSchedule schedule = scheduleService.getById(scheduleId); - if(schedule==null){ + if (schedule == null) { return R.fail("进度不存在"); } - if(!schedule.getUserId().equals(userId.toString())){ + if (!schedule.getUserId().equals(userId.toString())) { return R.fail("非法操作"); } scheduleService.removeById(scheduleId); return R.ok(); } - - - /** @@ -308,7 +373,6 @@ throw new RuntimeException(e); } } - } -- Gitblit v1.7.1