From 67e8a1c12ccb42b82704d989c71607d0cbe33356 Mon Sep 17 00:00:00 2001 From: jiangping <jp@doumee.com> Date: 星期一, 06 一月 2025 11:45:00 +0800 Subject: [PATCH] 最新版本541200007 --- server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/PlatformJobServiceImpl.java | 173 ++++++++++++++++++++++++++++----------------------------- 1 files changed, 84 insertions(+), 89 deletions(-) diff --git a/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/PlatformJobServiceImpl.java b/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/PlatformJobServiceImpl.java index f8d9293..265e4a9 100644 --- a/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/PlatformJobServiceImpl.java +++ b/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/PlatformJobServiceImpl.java @@ -10,16 +10,17 @@ import com.doumee.core.haikang.model.param.request.ParkReservationDelRequest; import com.doumee.core.haikang.model.param.respose.ParkReservationAddResponse; import com.doumee.core.haikang.service.HKService; -import com.doumee.core.model.LoginUserInfo; -import com.doumee.core.model.PageData; -import com.doumee.core.model.PageWrap; -import com.doumee.core.tms.model.request.TmsLockStatusQueryRequest; -import com.doumee.core.tms.model.response.TmsBaseResponse; -import com.doumee.core.tms.model.response.TmsLockStatusQueryResponse; +import com.doumee.service.business.third.model.LoginUserInfo; +import com.doumee.service.business.third.model.PageData; +import com.doumee.service.business.third.model.PageWrap; +import com.doumee.service.business.third.model.request.TmsLockStatusQueryRequest; +import com.doumee.service.business.third.model.response.TmsBaseResponse; +import com.doumee.service.business.third.model.response.TmsLockStatusQueryResponse; import com.doumee.core.utils.*; import com.doumee.core.wx.wxPlat.WxPlatConstants; import com.doumee.core.wx.wxPlat.WxPlatNotice; import com.doumee.dao.business.*; +import com.doumee.dao.business.dao.MemberMapper; import com.doumee.dao.business.dao.SmsConfigMapper; import com.doumee.dao.business.dao.SmsEmailMapper; import com.doumee.dao.business.join.PlatformJobJoinMapper; @@ -29,6 +30,7 @@ import com.doumee.dao.openapi.request.*; import com.doumee.dao.openapi.response.*; +import com.doumee.dao.system.SystemUserMapper; import com.doumee.dao.system.model.SystemUser; import com.doumee.dao.web.reqeust.*; import com.doumee.dao.web.response.DriverHomeVO; @@ -49,6 +51,7 @@ import org.slf4j.LoggerFactory; import org.springframework.beans.BeanUtils; import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.data.redis.core.RedisTemplate; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; import org.springframework.util.CollectionUtils; @@ -57,6 +60,7 @@ import java.math.RoundingMode; import java.util.*; import java.util.Date; +import java.util.concurrent.TimeUnit; import java.util.stream.Collectors; /** @@ -117,6 +121,8 @@ private EmayService emayService; @Autowired + private RedisTemplate<String, Object> redisTemplate; + @Autowired private PlatformBroadcastLogMapper platformBroadcastLogMapper; @Autowired private PlatformWarnEventServiceImpl platformWarnEventService; @@ -124,6 +130,8 @@ private MemberMapper memberMapper; @Autowired private WxNoticeConfigMapper wxNoticeConfigMapper; + @Autowired + private SystemUserMapper systemUserMapper; @Override public Integer create(PlatformJob platformJob) { @@ -508,6 +516,14 @@ .leftJoin(Platform.class,Platform::getId,PlatformJob::getPlatformId) .eq(PlatformJob::getIsdeleted,Constants.ZERO) .eq(PlatformJob::getDrivierPhone,loginUserInfo.getMobile()) + .and(i->i.like(PlatformJob::getDoneDate,DateUtil.getCurrDate()) + .or().in(PlatformJob::getStatus,Constants.PlatformJobStatus.WAIT_CALL.getKey() + ,Constants.PlatformJobStatus.WAIT_CONFIRM.getKey(), + Constants.PlatformJobStatus.WART_SIGN_IN.getKey(), + Constants.PlatformJobStatus.IN_WAIT.getKey(), + Constants.PlatformJobStatus.CALLED.getKey(), + Constants.PlatformJobStatus.WORKING.getKey()) + ) .orderByDesc(PlatformJob::getId) ); for (PlatformJob platformJob:platformJobList) { @@ -518,7 +534,6 @@ } driverHomeVO.setPlatformJobList(platformJobList); - // 鍥尯瀵艰鍥� 鍥剧墖 driverHomeVO.setReservationMap(systemDictDataBiz.queryByCode(Constants.PLATFORM,Constants.PLATFORM_GUIDEMAP).getCode()); // 棰勭害鎸囧崡 鏂囨湰 @@ -651,11 +666,11 @@ } public void sceneSignIn(SignInDTO signInDTO){ - if( StringUtils.isNotBlank(signInDTO.getQrCodeKey())){ throw new BusinessException(ResponseStatus.BAD_REQUEST); } - if(!signInDTO.getQrCodeKey().equals(systemDictDataBiz.queryByCode(Constants.PLATFORM,Constants.SIGN_IN_QRCODE).getCode())){ + if(!signInDTO.getQrCodeKey().equals( + systemDictDataBiz.queryByCode(Constants.PLATFORM,Constants.SIGN_IN_QRCODE_PREFIX).getCode() + systemDictDataBiz.queryByCode(Constants.PLATFORM,Constants.SIGN_IN_QRCODE).getCode())){ throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"浜岀淮鐮佸凡杩囨湡,璇峰埛鏂伴噸璇�"); } } @@ -728,6 +743,7 @@ ,PlatformJob::getId,lineUpDetailDTO.getJobId()) .in(PlatformJob::getStatus,Constants.PlatformJobStatus.WAIT_CALL.getKey(), Constants.PlatformJobStatus.IN_WAIT.getKey(), + Constants.PlatformJobStatus.WORKING.getKey(), Constants.PlatformJobStatus.CALLED.getKey()) .orderByDesc(PlatformJob::getStatus) .orderByAsc(PlatformJob::getSignDate) @@ -869,20 +885,39 @@ //鍏紬鍙锋ā鏉挎秷鎭� if(Objects.nonNull(platformJob.getDriverId())) { - Member member = memberMapper.selectById(platformJob.getDriverId()); - if (Objects.nonNull(member) && StringUtils.isNotBlank(member.getOpenid())) { - WxPlatNotice wxPlatNotice = new WxPlatNotice(); - wxPlatNotice.sendPlatformJobTemplateNotice( - wxNoticeConfigMapper, platformJob, - WxPlatConstants.platformJobContent.platformJobCallIn, - systemDictDataBiz.queryByCode(Constants.WX_PLATFORM, Constants.WX_PLATFORM_ACCESS_TOKEN).getCode(), - Arrays.asList(member.getOpenid().split(",")) - ); - } + this.sendWxNotice(WxPlatConstants.platformJobContent.platformJobCallIn,platformJob); } - return platformJob; } + + public void sendWxNotice(String objCode,PlatformJob platformJob){ + SystemUser driver = systemUserMapper.selectOne(new QueryWrapper<SystemUser>().lambda() + .eq(SystemUser::getDeleted, Constants.ZERO) + .eq(SystemUser::getType, Constants.ZERO) + .eq(SystemUser::getMobile,platformJob.getDrivierPhone()) + .last(" limit 1 ")); + if (Objects.nonNull(driver) && StringUtils.isNotBlank(driver.getOpenid())) { + PlatformJob p = platformJobJoinMapper.selectJoinOne(PlatformJob.class, + new MPJLambdaWrapper<PlatformJob>() + .selectAll(PlatformJob.class) + .selectAs(Platform::getName,PlatformJob::getPlatformName) + .leftJoin(Platform.class,Platform::getId,PlatformJob::getPlatformId) + .eq(PlatformJob::getId,platformJob.getId()) + .last(" limit 1") + ); + + WxPlatNotice wxPlatNotice = new WxPlatNotice(); + wxPlatNotice.sendPlatformJobTemplateNotice(systemDictDataBiz, + wxNoticeConfigMapper, p, + objCode, + systemDictDataBiz.queryByCode(Constants.WX_PLATFORM, Constants.WX_PLATFORM_ACCESS_TOKEN).getCode(), + Arrays.asList(driver.getOpenid().split(",")) + ); + } + } + + + private Logger logger = LoggerFactory.getLogger(PlatformJobServiceImpl.class); @@ -1079,17 +1114,8 @@ ); //鍏紬鍙锋ā鏉挎秷鎭� - if(Objects.nonNull(platformJob.getDriverId())){ - Member member = memberMapper.selectById(platformJob.getDriverId()); - if(Objects.nonNull(member) && StringUtils.isNotBlank(member.getOpenid())){ - WxPlatNotice wxPlatNotice = new WxPlatNotice(); - wxPlatNotice.sendPlatformJobTemplateNotice( - wxNoticeConfigMapper,platformJob, - WxPlatConstants.platformJobContent.platformJobSingIn, - systemDictDataBiz.queryByCode(Constants.WX_PLATFORM,Constants.WX_PLATFORM_ACCESS_TOKEN).getCode(), - Arrays.asList(member.getOpenid().split(",")) - ); - } + if(Objects.nonNull(platformJob.getDriverId())){ + this.sendWxNotice(WxPlatConstants.platformJobContent.platformJobSingIn,platformJob); } @@ -1224,17 +1250,8 @@ ); //鍏紬鍙锋ā鏉挎秷鎭� - if(Objects.nonNull(platformJob.getDriverId())) { - Member member = memberMapper.selectById(platformJob.getDriverId()); - if (Objects.nonNull(member) && StringUtils.isNotBlank(member.getOpenid())) { - WxPlatNotice wxPlatNotice = new WxPlatNotice(); - wxPlatNotice.sendPlatformJobTemplateNotice( - wxNoticeConfigMapper, platformJob, - WxPlatConstants.platformJobContent.platformJobMove, - systemDictDataBiz.queryByCode(Constants.WX_PLATFORM, Constants.WX_PLATFORM_ACCESS_TOKEN).getCode(), - Arrays.asList(member.getOpenid().split(",")) - ); - } + if(Objects.nonNull(platformJob.getDriverId())) { + this.sendWxNotice(WxPlatConstants.platformJobContent.platformJobMove,platformJob); } platformJob.setPlatformName(oldPlatform.getName()); @@ -1287,16 +1304,7 @@ //鍏紬鍙锋ā鏉挎秷鎭� if(Objects.nonNull(platformJob.getDriverId())){ - Member member = memberMapper.selectById(platformJob.getDriverId()); - if(Objects.nonNull(member) && StringUtils.isNotBlank(member.getOpenid())){ - WxPlatNotice wxPlatNotice = new WxPlatNotice(); - wxPlatNotice.sendPlatformJobTemplateNotice( - wxNoticeConfigMapper,platformJob, - WxPlatConstants.platformJobContent.platformJobOverNum, - systemDictDataBiz.queryByCode(Constants.WX_PLATFORM,Constants.WX_PLATFORM_ACCESS_TOKEN).getCode(), - Arrays.asList(member.getOpenid().split(",")) - ); - } + this.sendWxNotice(WxPlatConstants.platformJobContent.platformJobOverNum,platformJob); } platformJob.setPlatformName(platform.getName()); @@ -1348,16 +1356,7 @@ //鍏紬鍙锋ā鏉挎秷鎭� if(Objects.nonNull(platformJob.getDriverId())) { - Member member = memberMapper.selectById(platformJob.getDriverId()); - if (Objects.nonNull(member) && StringUtils.isNotBlank(member.getOpenid())) { - WxPlatNotice wxPlatNotice = new WxPlatNotice(); - wxPlatNotice.sendPlatformJobTemplateNotice( - wxNoticeConfigMapper, platformJob, - WxPlatConstants.platformJobContent.platformJobError, - systemDictDataBiz.queryByCode(Constants.WX_PLATFORM, Constants.WX_PLATFORM_ACCESS_TOKEN).getCode(), - Arrays.asList(member.getOpenid().split(",")) - ); - } + this.sendWxNotice(WxPlatConstants.platformJobContent.platformJobError,platformJob); } platformJob.setPlatformName(platform.getName()); @@ -1411,16 +1410,7 @@ ); //鍏紬鍙锋ā鏉挎秷鎭� if(Objects.nonNull(platformJob.getDriverId())) { - Member member = memberMapper.selectById(platformJob.getDriverId()); - if (Objects.nonNull(member) && StringUtils.isNotBlank(member.getOpenid())) { - WxPlatNotice wxPlatNotice = new WxPlatNotice(); - wxPlatNotice.sendPlatformJobTemplateNotice( - wxNoticeConfigMapper, platformJob, - WxPlatConstants.platformJobContent.platformJobWorking, - systemDictDataBiz.queryByCode(Constants.WX_PLATFORM, Constants.WX_PLATFORM_ACCESS_TOKEN).getCode(), - Arrays.asList(member.getOpenid().split(",")) - ); - } + this.sendWxNotice(WxPlatConstants.platformJobContent.platformJobWorking,platformJob); } //骞挎挱 led閫氱煡 platformJob.setPlatformName(platform.getName()); @@ -1430,11 +1420,22 @@ return platformJob; } - - - /** - * 瀹屾垚浣滀笟 - */ + + @Override + public PlatformJob getLastWaitJob(String uuid, LoginUserInfo loginUser){ + String u = (String) redisTemplate.opsForValue().get(Constants.RedisKeys.BIGSCREEN_UUID); + if(!StringUtils.equals(u,uuid)){ + throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"瀵逛笉璧凤紝浜岀淮鐮佸凡澶辨晥锛�"); + } + PlatformJob platformJob = platformJobMapper.selectOne(new QueryWrapper<PlatformJob>().lambda() + .eq(PlatformJob::getDrivierPhone,loginUser.getMobile()) + .eq(PlatformJob::getIsdeleted,Constants.ZERO) + .eq(PlatformJob::getStatus,Constants.PlatformJobStatus.WART_SIGN_IN.getKey()) + .orderByDesc(PlatformJob::getCreateDate) + .last(" limit 1 ") ); + return platformJob; + } + @Override @Transactional(rollbackFor = {Exception.class,BusinessException.class}) public PlatformJob finishWork(JobOperateDTO jobOperateDTO){ @@ -1509,16 +1510,7 @@ //鍏紬鍙锋ā鏉挎秷鎭� if(Objects.nonNull(platformJob.getDriverId())) { - Member member = memberMapper.selectById(platformJob.getDriverId()); - if (Objects.nonNull(member) && StringUtils.isNotBlank(member.getOpenid())) { - WxPlatNotice wxPlatNotice = new WxPlatNotice(); - wxPlatNotice.sendPlatformJobTemplateNotice( - wxNoticeConfigMapper, platformJob, - WxPlatConstants.platformJobContent.platformJobFinish, - systemDictDataBiz.queryByCode(Constants.WX_PLATFORM, Constants.WX_PLATFORM_ACCESS_TOKEN).getCode(), - Arrays.asList(member.getOpenid().split(",")) - ); - } + this.sendWxNotice(WxPlatConstants.platformJobContent.platformJobFinish,platformJob); } //骞挎挱 led閫氱煡 @@ -2108,7 +2100,11 @@ List<PlatformJob> calledList = platformJobList.stream().filter(i->Constants.equalsInteger(i.getStatus(),Constants.PlatformJobStatus.CALLED.getKey())).collect(Collectors.toList()); largeScreenDataVO.setWaitWorkList(calledList); } - largeScreenDataVO.setQrCode(systemDictDataBiz.queryByCode(Constants.PLATFORM,Constants.SIGN_IN_QRCODE).getCode()); + String u = UUID.randomUUID().toString(); + redisTemplate.opsForValue().set(Constants.RedisKeys.BIGSCREEN_UUID,u,3, TimeUnit.MINUTES); + String url = Constants.getWxUrl(systemDictDataBiz.queryByCode(Constants.PLATFORM,Constants.WX_REDIRECT_URL).getCode(),Constants.WxUrlParams.BISCREEN_CODE,u); + largeScreenDataVO.setQrCode(url); + largeScreenDataVO.setAttention(systemDictDataBiz.queryByCode(Constants.PLATFORM,Constants.SIGN_IN_ATTENTION).getCode()); return largeScreenDataVO; } @@ -2215,7 +2211,6 @@ } } - -- Gitblit v1.9.3