From 68a19b71ddb5775670e4cb125c29b4ee70d62da9 Mon Sep 17 00:00:00 2001 From: k94314517 <8417338+k94314517@user.noreply.gitee.com> Date: 星期四, 19 十二月 2024 17:26:29 +0800 Subject: [PATCH] 代码初始化 --- server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/PlatformJobServiceImpl.java | 141 ++++++++++++++++++++-------------------------- 1 files changed, 62 insertions(+), 79 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 d1811f2..476825c 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 @@ -29,6 +29,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; @@ -56,6 +57,7 @@ import java.math.BigDecimal; import java.math.RoundingMode; +import java.net.URLEncoder; import java.util.*; import java.util.Date; import java.util.concurrent.TimeUnit; @@ -119,6 +121,8 @@ private EmayService emayService; @Autowired + private RedisTemplate<String, Object> redisTemplate; + @Autowired private PlatformBroadcastLogMapper platformBroadcastLogMapper; @Autowired private PlatformWarnEventServiceImpl platformWarnEventService; @@ -126,6 +130,8 @@ private MemberMapper memberMapper; @Autowired private WxNoticeConfigMapper wxNoticeConfigMapper; + @Autowired + private SystemUserMapper systemUserMapper; @Override public Integer create(PlatformJob platformJob) { @@ -871,19 +877,35 @@ //鍏紬鍙锋ā鏉挎秷鎭� 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); @@ -1081,17 +1103,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); } @@ -1226,17 +1239,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()); @@ -1289,16 +1293,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()); @@ -1350,16 +1345,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()); @@ -1413,16 +1399,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()); @@ -1432,11 +1409,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){ @@ -1511,16 +1499,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閫氱煡 @@ -2110,7 +2089,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; } -- Gitblit v1.9.3