From 8853292babb2ad94de4a3207966f1e83b767cd2d Mon Sep 17 00:00:00 2001
From: zhongrj <646384940@qq.com>
Date: Sun, 17 Sep 2023 16:38:34 +0800
Subject: [PATCH] 新增流程节点进程查询接口

---
 src/main/java/org/springblade/modules/apply/service/impl/ApplyServiceImpl.java |  139 ++++++++++++++++++++++++++++++++++++++++------
 1 files changed, 121 insertions(+), 18 deletions(-)

diff --git a/src/main/java/org/springblade/modules/apply/service/impl/ApplyServiceImpl.java b/src/main/java/org/springblade/modules/apply/service/impl/ApplyServiceImpl.java
index a702dba..3449a4b 100644
--- a/src/main/java/org/springblade/modules/apply/service/impl/ApplyServiceImpl.java
+++ b/src/main/java/org/springblade/modules/apply/service/impl/ApplyServiceImpl.java
@@ -1,6 +1,7 @@
 
 package org.springblade.modules.apply.service.impl;
 
+import com.alibaba.fastjson.JSON;
 import com.baomidou.mybatisplus.core.metadata.IPage;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 import lombok.AllArgsConstructor;
@@ -12,6 +13,8 @@
 import org.springblade.common.utils.arg;
 import org.springblade.core.mp.support.Condition;
 import org.springblade.core.tool.api.R;
+import org.springblade.modules.FTP.FtpUtil;
+import org.springblade.modules.FTP.OutJson;
 import org.springblade.modules.apply.entity.Apply;
 import org.springblade.modules.apply.excel.ApplyExcel;
 import org.springblade.modules.apply.excel.ApplyInfoExcel;
@@ -20,12 +23,21 @@
 import org.springblade.modules.apply.vo.ApplyPaPerVO;
 import org.springblade.modules.apply.vo.ApplyVO;
 import org.springblade.modules.exam.entity.ExamPaper;
+import org.springblade.modules.exam.entity.ExamScore;
 import org.springblade.modules.exam.service.ExamPaperService;
+import org.springblade.modules.exam.service.ExamScoreService;
 import org.springblade.modules.system.entity.User;
 import org.springblade.modules.system.service.IUserService;
+import org.springblade.modules.system.service.MyAsyncService;
+import org.springblade.modules.training.entity.TrainingRegistration;
+import org.springblade.modules.training.service.TrainingRegistrationService;
+import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
 
+import java.io.File;
+import java.io.FileInputStream;
+import java.io.FileNotFoundException;
 import java.text.DecimalFormat;
 import java.text.SimpleDateFormat;
 import java.util.*;
@@ -35,13 +47,18 @@
  * @author zhongrj
  */
 @Service
-@AllArgsConstructor
 public class ApplyServiceImpl extends ServiceImpl<ApplyMapper, Apply> implements ApplyService {
 
+	@Autowired
+	private ExamPaperService examPaperService;
 
-	private final ExamPaperService examPaperService;
+	@Autowired
+	private IUserService userService;
 
-	private final IUserService userService;
+	@Autowired
+	private TrainingRegistrationService trainingRegistrationService;
+	@Autowired
+	private  MyAsyncService myAsyncService;
 
 	/**
 	 * 自定义分页数据
@@ -91,7 +108,7 @@
 	 */
 	@Override
 	@Transactional(rollbackFor = Exception.class)
-	public void importApply(List<ApplyExcel> data, Boolean isCovered) {
+	public void importApply(List<ApplyExcel> data, Boolean isCovered,Long examId) {
 		data.forEach(applyExcel -> {
 			//查询用户信息
 			User user = new User();
@@ -106,22 +123,62 @@
 					apply1.setIsExam(1);
 					apply1.setApplyTime(new Date());
 					apply1.setUserId(user1.getId());
+					if (null!=examId){
+						apply1.setExamId(examId);
+						//生成准考证号
+						apply1.setCandidateNo(getCandidateNo(apply1));
+					}
+
 					this.save(apply1);
 					//修改保安报名状态
 					user1.setIsApply(1);
 					userService.updateById(user1);
+
+					String formatStr = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date());
+					Long id = apply1.getId();
+					String s = "insert into sys_apply(id,user_id,candidate_no,apply_time,apply_status,exam_id,is_exam) " +
+						"values(" + "'" + id + "'" + ","
+						+ "'" + apply1.getUserId() + "'" + ","
+						+ "'" + apply1.getCandidateNo() + "'" + ","
+						+ "'" + formatStr +"'" + ","
+						+ "'" + apply1.getApplyStatus() + "'" + ","
+						+ "'" + examId + "'" + ","
+						+"'" + apply1.getIsExam() + "'" + ");" +
+						"update blade_user set is_apply = " + "'" + user1.getIsApply() + "'" +"where id = " + "'" + user1.getId() + "'";
+					//FtpUtil.sqlFileUpload(s);
+					myAsyncService.dataSync(s);
 				}else {
-					if (user1.getIsApply()==2) {
+					if (user1.getIsApply()!=1) {
 						Apply apply1 = new Apply();
 						apply1.setApplyStatus(2);
 						//默认为未考试状态
 						apply1.setIsExam(1);
 						apply1.setApplyTime(new Date());
 						apply1.setUserId(user1.getId());
+						if (null!=examId){
+							apply1.setExamId(examId);
+							//生成准考证号
+							apply1.setCandidateNo(getCandidateNo(apply1));
+						}
 						this.save(apply1);
 						//修改保安报名状态
 						user1.setIsApply(1);
 						userService.updateById(user1);
+
+						//内网数据同步
+						String formatStr = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date());
+						Long id = apply1.getId();
+						String s = "insert into sys_apply(id,user_id,candidate_no,apply_time,apply_status,exam_id,is_exam) " +
+							"values(" + "'" + id + "'" + ","
+							+ "'" + apply1.getUserId() + "'" + ","
+							+ "'" + apply1.getCandidateNo() + "'" + ","
+							+ "'" + formatStr +"'" + ","
+							+ "'" + apply1.getApplyStatus() + "'" + ","
+							+ "'" + examId + "'" + ","
+							+"'" + apply1.getIsExam() + "'" + ");" +
+							"update blade_user set is_apply = " + "'" + user1.getIsApply() + "'" +"where id = " + "'" + user1.getId() + "'";
+						//FtpUtil.sqlFileUpload(s);
+						myAsyncService.dataSync(s);
 					}
 				}
 			}
@@ -288,25 +345,22 @@
 		//正式考试
 		if (apply.getApplyExamType()==1){
 			ApplyPaPerVO applyPaPerVO = baseMapper.getApplyInfo(apply);
-			String time = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(applyPaPerVO.getStartTime()).split(" ")[0];
-			String startTime = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(applyPaPerVO.getStartTime()).split(" ")[1];
-			String endTime = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(applyPaPerVO.getEndTime()).split(" ")[1];
-			applyPaPerVO.setStringTime(time+" "+startTime.substring(0,startTime.length()-3) +"-"+ endTime.substring(0,endTime.length()-3));
+//			String time = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(applyPaPerVO.getStartTime()).split(" ")[0];
+//			String startTime = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(applyPaPerVO.getStartTime()).split(" ")[1];
+//			String endTime = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(applyPaPerVO.getEndTime()).split(" ")[1];
+			applyPaPerVO.setStringTime(new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(applyPaPerVO.getStartTime()));
 			return applyPaPerVO;
 		}
 
 		//模拟考试
 		if (apply.getApplyExamType()==2){
 			ApplyPaPerVO applyPaPerVO = baseMapper.getTrainApplyInfo(apply);
-			String time = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(applyPaPerVO.getStartTime()).split(" ")[0];
-			String startTime = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(applyPaPerVO.getStartTime()).split(" ")[1];
-			String endTime = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(applyPaPerVO.getEndTime()).split(" ")[1];
-			applyPaPerVO.setStringTime(time+" "+startTime.substring(0,startTime.length()-3) +"-"+ endTime.substring(0,endTime.length()-3));
+//			String time = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(applyPaPerVO.getStartTime()).split(" ")[0];
+//			String startTime = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(applyPaPerVO.getStartTime()).split(" ")[1];
+//			String endTime = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(applyPaPerVO.getEndTime()).split(" ")[1];
+			applyPaPerVO.setStringTime(new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(applyPaPerVO.getStartTime()));
 			return applyPaPerVO;
 		}
-
-
-
 		return null;
 	}
 
@@ -345,8 +399,10 @@
 	 * @return
 	 */
 	@Override
-	public List<Long> getApplyIds() {
-		return baseMapper.getApplyIds();
+	public List<Apply> getApplyIds(ApplyVO applyVO) {
+		applyVO.setSerialStart(applyVO.getSerialStart() -1);
+		applyVO.setSerialEnd(applyVO.getSerialEnd() -applyVO.getSerialStart());
+		return baseMapper.getApplyIds(applyVO);
 	}
 
 	/**
@@ -395,4 +451,51 @@
 	public ApplyVO getSecurityApplyDetail(ApplyVO apply) {
 		return baseMapper.getSecurityApplyDetail(apply);
 	}
+
+
+	/**
+	 * 修改考试状态
+	 * @param apply 报名信息,包含userId,applyid
+	 * @return
+	 */
+	@Override
+	public void updateApplyStatus(ApplyVO apply) {
+		//正式考
+		if (apply.getExamType()==1){
+			Apply apply1 = new Apply();
+			apply1.setId(apply.getId());
+			//考试中
+			apply1.setIsExam(3);
+			baseMapper.updateById(apply1);
+
+			String s1 =
+				"update sys_apply set is_exam = " + apply1.getIsExam() + " " +"where id = " + "'" + apply1.getId() + "'";
+			//FtpUtil.sqlFileUpload(s1);
+			myAsyncService.dataSync(s1);
+		}
+		//模拟考
+		if (apply.getExamType()==2){
+			TrainingRegistration trainingRegistration = new TrainingRegistration();
+			trainingRegistration.setId(apply.getId());
+			//考试中
+			trainingRegistration.setIsExam(3);
+//			trainingRegistration.setIsExam(1);
+			trainingRegistrationService.updateById(trainingRegistration);
+
+			String s1 =
+				"update sys_training_registration set is_exam = " + trainingRegistration.getIsExam() + " " +"where id = " + "'" + trainingRegistration.getId() + "'";
+			//FtpUtil.sqlFileUpload(s1);
+			myAsyncService.dataSync(s1);
+		}
+	}
+
+	/**
+	 * 查询报名信息,取最新的一条(即当前userId,)applyId最大的一条记录
+	 * @param userId
+	 * @return
+	 */
+	@Override
+	public Apply getMaxApplyIdByUserIdInfo(Long userId) {
+		return baseMapper.getMaxApplyIdByUserIdInfo(userId);
+	}
 }

--
Gitblit v1.9.3