From 13d2bd6a27f941cfd8f096a7ae2def858a565363 Mon Sep 17 00:00:00 2001
From: zhibing.pu <393733352@qq.com>
Date: 星期三, 04 九月 2024 11:01:34 +0800
Subject: [PATCH] 修改2.0 bug

---
 DriverIGOTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/system/util/quartz/jobs/OrderTimeOutJob.java |  166 ++++++++++++++++++++++++++++++++++++++++++++++++++-----
 1 files changed, 151 insertions(+), 15 deletions(-)

diff --git a/DriverIGOTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/system/util/quartz/jobs/OrderTimeOutJob.java b/DriverIGOTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/system/util/quartz/jobs/OrderTimeOutJob.java
index fa413e4..871e41f 100644
--- a/DriverIGOTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/system/util/quartz/jobs/OrderTimeOutJob.java
+++ b/DriverIGOTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/system/util/quartz/jobs/OrderTimeOutJob.java
@@ -1,20 +1,33 @@
 package com.stylefeng.guns.modular.system.util.quartz.jobs;
 
+import com.alibaba.fastjson.JSON;
+import com.stylefeng.guns.core.util.ToolUtil;
 import com.stylefeng.guns.modular.smallLogistics.model.OrderLogistics;
 import com.stylefeng.guns.modular.smallLogistics.server.IOrderLogisticsService;
 import com.stylefeng.guns.modular.specialTrain.model.OrderPrivateCar;
 import com.stylefeng.guns.modular.specialTrain.server.IOrderPrivateCarService;
+import com.stylefeng.guns.modular.system.dao.UserInfoMapper;
+import com.stylefeng.guns.modular.system.model.Driver;
+import com.stylefeng.guns.modular.system.model.User;
+import com.stylefeng.guns.modular.system.model.UserInfo;
+import com.stylefeng.guns.modular.system.service.IDriverService;
+import com.stylefeng.guns.modular.system.service.IUserService;
 import com.stylefeng.guns.modular.system.util.PushUtil;
+import com.stylefeng.guns.modular.system.util.TextToSpeechUtil;
 import com.stylefeng.guns.modular.system.util.quartz.QuartzUtil;
+import com.stylefeng.guns.modular.system.util.quartz.model.QuartzEnum;
 import com.stylefeng.guns.modular.system.util.quartz.model.QuartzJob;
 import lombok.extern.slf4j.Slf4j;
-import org.quartz.JobDataMap;
-import org.quartz.JobDetail;
-import org.quartz.JobExecutionContext;
-import org.quartz.JobKey;
+import org.quartz.*;
 import org.springframework.stereotype.Component;
 
 import javax.annotation.Resource;
+import java.io.IOException;
+import java.text.SimpleDateFormat;
+import java.util.Arrays;
+import java.util.List;
+import java.util.Timer;
+import java.util.TimerTask;
 
 /**
  * 订单司机超时提醒任务
@@ -31,27 +44,45 @@
 	private IOrderPrivateCarService orderPrivateCarService;
 	@Resource
 	private IOrderLogisticsService orderLogisticsService;
+	@Resource
+	private IDriverService driverService;
+	@Resource
+	private UserInfoMapper userInfoMapper;
 	
 	
 	
 	@Override
 	public QuartzJob buildQuartzJob() {
-		return super.buildQuartzJob();
+		return buildQuartzJob(QuartzEnum.JOB_NAME.getValue());
 	}
 	
 	@Override
 	public QuartzJob buildQuartzJob(String name) {
-		return super.buildQuartzJob(name);
+		return buildQuartzJob(name, QuartzEnum.DEFAULT_GROUP.getValue());
 	}
 	
 	@Override
 	public QuartzJob buildQuartzJob(String name, String group) {
-		return super.buildQuartzJob(name, group);
+		return buildQuartzJob(name, QuartzEnum.DEFAULT_GROUP.getValue(), null);
 	}
 	
 	@Override
 	public QuartzJob buildQuartzJob(String name, String group, JobDataMap jobDataMap) {
-		return super.buildQuartzJob(name, group, jobDataMap);
+		QuartzJob job = new OrderTimeOutJob();
+		if(ToolUtil.isNotEmpty(name)){
+			job.setName(name);
+		}else{
+			job.setName(QuartzEnum.JOB_NAME.getValue());
+		}
+		if(ToolUtil.isNotEmpty(group)){
+			job.setGroup(group);
+		}else{
+			job.setGroup(QuartzEnum.DEFAULT_GROUP.getValue());
+		}
+		if(null != jobDataMap){
+			job.setJobDataMap(jobDataMap);
+		}
+		return job;
 	}
 	
 	/**
@@ -60,14 +91,63 @@
 	 */
 	@Override
 	public void run(JobExecutionContext jobExecutionContext) {
-		JobDataMap jobDataMap = jobExecutionContext.getJobDetail().getJobDataMap();
-		Integer driverId = jobDataMap.getIntegerFromString("driverId");
-		Integer orderId = jobDataMap.getIntegerFromString("orderId");
-		Integer orderType = jobDataMap.getIntegerFromString("orderType");
+		JobDetail jobDetail = jobExecutionContext.getJobDetail();
+		JobDataMap jobDataMap = jobDetail.getJobDataMap();
+		String name = jobDetail.getKey().getName();
+		log.info("执行{}定时任务逻辑 JobDataMap:{}", name, JSON.toJSONString(jobDataMap));
+		Integer timeOutType = jobDataMap.getIntValue("timeOutType");
+		Integer driverId = jobDataMap.getIntValue("driverId");
+		Integer orderId = jobDataMap.getIntValue("orderId");
+		Integer orderType = jobDataMap.getIntValue("orderType");
+		Integer driverTimeout = jobDataMap.getIntValue("driverTimeout");
+		long timeOut = jobDataMap.getLongValue("timeOut");
 		String describe = jobDataMap.getString("describe");
+		Driver driver = driverService.selectById(driverId);
+		Integer language = driver.getLanguage();
+		if(1 == timeOutType){
+			if(orderType == 1){
+				describe = language == 1 ? "您已超时" + driverTimeout + "分钟,\n用户可免费取消订单" : language == 2 ? "You are overdue for " + driverTimeout + " minutes,\nThe subscriber could cancel the order for free" : "Vous êtes en retard de " + driverTimeout + " minutes,\nL'abonné peut annuler la commande gratuitement";
+			}
+			if(orderType == 4){
+				describe = language == 1 ? "您已超时" + driverTimeout + "分钟,\n用户可免费取消订单" : language == 2 ? "You are overdue for " + driverTimeout + " minutes,\nThe subscriber could cancel the order for free" : "Vous êtes en retard de " + driverTimeout + " minutes,\nL'abonné peut annuler la commande gratuitement";
+			}
+		}
+		if(2 == timeOutType){
+			if(orderType == 1){
+				OrderPrivateCar orderPrivateCar = orderPrivateCarService.selectById(orderId);
+				UserInfo userInfo = userInfoMapper.selectById(orderPrivateCar.getUserId());
+				SimpleDateFormat sdf = new SimpleDateFormat("HH:mm");
+				describe = language == 1 ? "您将于" + sdf.format(orderPrivateCar.getTravelTime()) + "去接" + (ToolUtil.isEmpty(userInfo.getFirstName()) ? userInfo.getNickName() : userInfo.getFirstName() + " " + userInfo.getLastName())  + ",请准时!" :
+						language == 2 ? "You are going to pick up " + (ToolUtil.isEmpty(userInfo.getFirstName()) ? userInfo.getNickName() : userInfo.getFirstName() + " " + userInfo.getLastName()) + " at " + sdf.format(orderPrivateCar.getTravelTime()) + ", please be on time. " :
+								"Vous allez chercher " + (ToolUtil.isEmpty(userInfo.getFirstName()) ? userInfo.getNickName() : userInfo.getFirstName() + " " + userInfo.getLastName()) + " à " + sdf.format(orderPrivateCar.getTravelTime()) + ", s’il vous plaît soyez à l’heure.";
+			}
+			if(orderType == 4){
+			}
+		}
+		if(3 == timeOutType){
+			Integer m = Double.valueOf((System.currentTimeMillis() - timeOut) / 60000).intValue();
+			if(orderType == 1){
+				if(0 == m){
+					describe = language == 1 ? "您的打车订单已超时,请抓紧!" : language == 2 ? "Your ride order is overdue, please go faster." : "Votre commande de course est en retard, veuillez aller plus vite.";
+				}else{
+					describe = language == 1 ? "您的打车订单已超时" + m + "分钟,请抓紧!" : language == 2 ? "Your ride order is overdue for " + m + " minute(s), please go faster." : "Votre commande de course est en retard depuis " + m + " minute(s), veuillez aller plus vite.";
+				}
+			}
+			if(orderType == 4){
+				if(0 == m){
+					describe = language == 1 ? "您的包裹订单已超时,请抓紧!" : language == 2 ? "Your delivery order is overdue, please go faster." : "Votre commande de Delivery est en retard, veuillez aller plus vite.";
+				}else{
+					describe = language == 1 ? "您的包裹订单已超时" + m + "分钟,请抓紧!" : language == 2 ? "Your delivery order is overdue for " + m + " minute(s), please go faster." : "Votre commande de livraison est en retard depuis " + m + " minute(s), veuillez aller plus vite.";
+				}
+			}
+		}
+		
+		
 		if(1 == orderType){
+			//结束预约单出发循环提醒定时
 			OrderPrivateCar orderPrivateCar = orderPrivateCarService.selectById(orderId);
-			if(2 != orderPrivateCar.getState()){
+			List<Integer> list = Arrays.asList(4, 5, 6, 7, 8, 9, 10, 11, 12);
+			if(1 == timeOutType && list.contains(orderPrivateCar.getState())){
 				JobKey key = jobExecutionContext.getJobDetail().getKey();
 				boolean b = QuartzUtil.deleteQuartzTask(key);
 				if(!b){
@@ -75,10 +155,40 @@
 				}
 				return;
 			}
+			if(2 == timeOutType && (System.currentTimeMillis() >= timeOut || list.contains(orderPrivateCar.getState()))){
+				JobKey key = jobExecutionContext.getJobDetail().getKey();
+				boolean b = QuartzUtil.deleteQuartzTask(key);
+				if(!b){
+					log.error("定时任务关闭失败:" + key.toString());
+				}
+				return;
+			}
+			
+			//结束超时循环提醒定时
+			if(3 == timeOutType && list.contains(orderPrivateCar.getState())){
+				JobKey key = jobExecutionContext.getJobDetail().getKey();
+				boolean b = QuartzUtil.deleteQuartzTask(key);
+				if(!b){
+					log.error("定时任务关闭失败:" + key.toString());
+				}
+				return;
+			}
+			
+			
 		}
 		if(4 == orderType){
 			OrderLogistics orderLogistics = orderLogisticsService.selectById(orderId);
-			if(2 != orderLogistics.getState()){
+			List<Integer> list = Arrays.asList(4, 5, 6, 7, 8, 9, 10, 11, 12, 13);
+			if(1 == timeOutType && list.contains(orderLogistics.getState())){
+				JobKey key = jobExecutionContext.getJobDetail().getKey();
+				boolean b = QuartzUtil.deleteQuartzTask(key);
+				if(!b){
+					log.error("定时任务关闭失败:" + key.toString());
+				}
+				return;
+			}
+			//结束超时循环提醒定时
+			if(3 == timeOutType && list.contains(orderLogistics.getState())){
 				JobKey key = jobExecutionContext.getJobDetail().getKey();
 				boolean b = QuartzUtil.deleteQuartzTask(key);
 				if(!b){
@@ -87,7 +197,33 @@
 				return;
 			}
 		}
-		pushUtil.pushOrderTimeOut(2, driverId, orderId, orderType, describe);
+		
+		String fileName = "orderTimeOut" + driverId + "_" + timeOutType + ".mp3";
+		String audioUrl = null;
+		try {
+			audioUrl = TextToSpeechUtil.create(language == 1 ? "cmn-CN" : language == 2 ? "en-US" : "fr-FR", describe, fileName);
+		} catch (Exception e) {
+			e.printStackTrace();
+		}
+		
+		//定时任务删除语音文件
+		new Timer().schedule(new TimerTask() {
+			@Override
+			public void run() {
+				Process process = null;
+				try {
+					process = Runtime.getRuntime().exec("sudo rm -rf /home/igotechgh/nginx/html/files/audio/" + fileName);
+				} catch (IOException e) {
+					throw new RuntimeException(e);
+				}
+				if (process != null) {
+					process.destroy();
+				}
+			}
+		}, 30000);
+		
+		log.info("开始推送提醒-{}:orderId={};orderType={};timeOutType={};describe={};audioUrl={}", System.currentTimeMillis(), orderId, orderType, timeOutType, describe, audioUrl);
+		pushUtil.pushOrderTimeOut(2, driverId, timeOutType, orderId, orderType, describe, audioUrl);
 	}
 	
 	

--
Gitblit v1.7.1