From 67717487eefdc9575635ee611e03233530508332 Mon Sep 17 00:00:00 2001
From: Administrator <admin>
Date: Mon, 07 Mar 2022 11:43:30 +0800
Subject: [PATCH] 押运人员导入修改,新增qfqk推送和保安证编号校验

---
 src/main/java/org/springblade/modules/system/service/impl/UserServiceImpl.java |  153 ++++++++++++++++++++++++++++++++++++++------------
 1 files changed, 115 insertions(+), 38 deletions(-)

diff --git a/src/main/java/org/springblade/modules/system/service/impl/UserServiceImpl.java b/src/main/java/org/springblade/modules/system/service/impl/UserServiceImpl.java
index 54cde20..b69ef8a 100644
--- a/src/main/java/org/springblade/modules/system/service/impl/UserServiceImpl.java
+++ b/src/main/java/org/springblade/modules/system/service/impl/UserServiceImpl.java
@@ -915,31 +915,28 @@
 				if (null != userExcel.getSecuritynumber() && userExcel.getSecuritynumber() != "") {
 					user.setHold("1");
 					//校验保安员证编号是否合规
-					if (null!=userExcel.getSecuritynumber() && !userExcel.getSecuritynumber().equals("")){
-						//持证,校验保安证编号是否合法
-						SecurityPaper securityPaper = new SecurityPaper();
-						securityPaper.setIdCardNo(userExcel.getCardid());
-						List<SecurityPaper> securityPaperList = securityPaperService.list(Condition.getQueryWrapper(securityPaper));
-						if (securityPaperList.size()>0){
-							boolean state = false;
-							//遍历
-							for (SecurityPaper paper : securityPaperList) {
-								if (paper.getNumber().equals(user.getSecuritynumber())){
-									state = true;
-								}
+					SecurityPaper securityPaper = new SecurityPaper();
+					securityPaper.setIdCardNo(userExcel.getCardid());
+					List<SecurityPaper> securityPaperList = securityPaperService.list(Condition.getQueryWrapper(securityPaper));
+					if (securityPaperList.size()>0){
+						boolean state = false;
+						//遍历
+						for (SecurityPaper paper : securityPaperList) {
+							if (paper.getNumber().equals(user.getSecuritynumber())){
+								state = true;
 							}
-							if (!state){
-								user.setHold("2");
-								user.setSecuritynumber(null);
-								securityInvalidList.add(userExcel.getCardid());
-								securityInvalidStatus.set(false);
-							}
-						}else {
+						}
+						if (!state){
 							user.setHold("2");
 							user.setSecuritynumber(null);
 							securityInvalidList.add(userExcel.getCardid());
 							securityInvalidStatus.set(false);
 						}
+					}else {
+						user.setHold("2");
+						user.setSecuritynumber(null);
+						securityInvalidList.add(userExcel.getCardid());
+						securityInvalidStatus.set(false);
 					}
 				}else {
 					user.setHold("2");
@@ -1236,11 +1233,14 @@
 		List<String> errorList = new ArrayList<>();
 		//将需要新增的保安员信息存入集合
 		List<String> ageErrorList = new ArrayList<>();
+		//保安员证编号不符的保安员信息存入集合
+		List<String> securityInvalidList = new ArrayList<>();
 		//将需要更新的保安员信息存入集合
 		List<User> updateList = new ArrayList<>();
 		//导入状态,默认为true ,如果有一个出现问题则为 false
 		AtomicBoolean status = new AtomicBoolean(true);
 		AtomicBoolean agetStatus = new AtomicBoolean(true);
+		AtomicBoolean securityInvalidStatus = new AtomicBoolean(true);
 		data.forEach(userExcel -> {
 			User user = Objects.requireNonNull(BeanUtil.copy(userExcel, User.class));
 			//设置部门id
@@ -1297,6 +1297,30 @@
 				//判断是否持证
 				if (null != userExcel.getSecuritynumber() && userExcel.getSecuritynumber() != "") {
 					user.setHold("1");
+					//校验保安员证编号是否合规
+					SecurityPaper securityPaper = new SecurityPaper();
+					securityPaper.setIdCardNo(userExcel.getCardid());
+					List<SecurityPaper> securityPaperList = securityPaperService.list(Condition.getQueryWrapper(securityPaper));
+					if (securityPaperList.size()>0){
+						boolean state = false;
+						//遍历
+						for (SecurityPaper paper : securityPaperList) {
+							if (paper.getNumber().equals(user.getSecuritynumber())){
+								state = true;
+							}
+						}
+						if (!state){
+							user.setHold("2");
+							user.setSecuritynumber(null);
+							securityInvalidList.add(userExcel.getCardid());
+							securityInvalidStatus.set(false);
+						}
+					}else {
+						user.setHold("2");
+						user.setSecuritynumber(null);
+						securityInvalidList.add(userExcel.getCardid());
+						securityInvalidStatus.set(false);
+					}
 				}else {
 					user.setHold("2");
 				}
@@ -1331,6 +1355,8 @@
 				user.setCreateTime(new Date());
 				//新增
 				this.save(user);
+				//qfqk 推送
+				myAsyncService.qfqkUserSave(user);
 
 				//从业记录新增
 				Experience experience = new Experience();
@@ -1421,6 +1447,30 @@
 						if (null != userExcel.getSecuritynumber() && userExcel.getSecuritynumber() != "") {
 							user2.setHold("1");
 							user2.setSecuritynumber(user.getSecuritynumber());
+							//校验保安员证编号是否合规
+							SecurityPaper securityPaper = new SecurityPaper();
+							securityPaper.setIdCardNo(userExcel.getCardid());
+							List<SecurityPaper> securityPaperList = securityPaperService.list(Condition.getQueryWrapper(securityPaper));
+							if (securityPaperList.size()>0){
+								boolean state = false;
+								//遍历
+								for (SecurityPaper paper : securityPaperList) {
+									if (paper.getNumber().equals(user.getSecuritynumber())){
+										state = true;
+									}
+								}
+								if (!state){
+									user2.setHold("2");
+									user2.setSecuritynumber(null);
+									securityInvalidList.add(userExcel.getCardid());
+									securityInvalidStatus.set(false);
+								}
+							}else {
+								user2.setHold("2");
+								user2.setSecuritynumber(null);
+								securityInvalidList.add(userExcel.getCardid());
+								securityInvalidStatus.set(false);
+							}
 						}else {
 							user2.setHold("2");
 						}
@@ -1432,6 +1482,9 @@
 						user2.setUpdateTime(new Date());
 						//更新用户数据
 						this.updateById(user2);
+						//qfqk 推送
+						myAsyncService.updateUserByQfqk(user);
+
 						String s1 =
 							"update blade_user set hold = " + "'" + user2.getHold() + "'"
 								+ ",securitynumber = " + "'" + user2.getSecuritynumber() + "'"
@@ -1464,6 +1517,30 @@
 					if (null != userExcel.getSecuritynumber() && userExcel.getSecuritynumber() != "") {
 						user2.setHold("1");
 						user2.setSecuritynumber(user.getSecuritynumber());
+						//校验保安员证编号是否合规
+						SecurityPaper securityPaper = new SecurityPaper();
+						securityPaper.setIdCardNo(userExcel.getCardid());
+						List<SecurityPaper> securityPaperList = securityPaperService.list(Condition.getQueryWrapper(securityPaper));
+						if (securityPaperList.size()>0){
+							boolean state = false;
+							//遍历
+							for (SecurityPaper paper : securityPaperList) {
+								if (paper.getNumber().equals(user.getSecuritynumber())){
+									state = true;
+								}
+							}
+							if (!state){
+								user2.setHold("2");
+								user2.setSecuritynumber(null);
+								securityInvalidList.add(userExcel.getCardid());
+								securityInvalidStatus.set(false);
+							}
+						}else {
+							user2.setHold("2");
+							user2.setSecuritynumber(null);
+							securityInvalidList.add(userExcel.getCardid());
+							securityInvalidStatus.set(false);
+						}
 					}else {
 						user2.setHold("2");
 					}
@@ -1475,6 +1552,9 @@
 					user2.setUpdateTime(new Date());
 					//更新用户数据
 					this.updateById(user2);
+					//qfqk 推送
+					myAsyncService.updateUserByQfqk(user);
+
 					String s1 =
 						"update blade_user set hold = " + "'" + user2.getHold() + "'"
 							+ ",securitynumber = " + "'" + user2.getSecuritynumber() + "'"
@@ -1487,25 +1567,22 @@
 			}
 		});
 		//如果所有数据导入有一个异常
-//		if (!status.get()){
-//			String errorAccount = StringUtils.join(errorList, "\\\n");
-//			throw new ServiceException("用户:["+errorAccount+"]导入失败!已在其他单位存在!");
-//		}
-		if (!status.get() || !agetStatus.get()){
-			if (!status.get() && agetStatus.get()) {
-				String errorAccount = StringUtils.join(errorList, "\\\n");
-				throw new ServiceException("用户:[" + errorAccount + "]导入失败!已在其他单位存在!");
-			}
-			if (!agetStatus.get() && status.get()) {
-				String errorAccount = StringUtils.join(ageErrorList, "\\\n");
-				throw new ServiceException("用户:[" + errorAccount + "]导入失败!身份证号码不正确,请核对!");
-			}
-			if (!status.get() && !agetStatus.get()) {
-				String errorAccount = StringUtils.join(errorList, "\\\n");
-				String errorAgeAccount = StringUtils.join(ageErrorList, "\\\n");
-				throw new ServiceException("用户:[" + errorAccount + "]导入失败!已在其他单位存在!"+
-					"用户:[" + errorAgeAccount + "]导入失败!身份证号码不正确,请核对!");
-			}
+		StringBuilder errorBuilder = new StringBuilder();
+		if (!status.get()){
+			String errorAccount = StringUtils.join(errorList, "\\\n");
+			errorBuilder.append("用户:[" + errorAccount + "]导入失败!已在其他单位存在!");
+		}
+		if (!agetStatus.get()){
+			String errorAccount = StringUtils.join(ageErrorList, "\\\n");
+			errorBuilder.append("用户:[" + errorAccount + "]导入失败!已在其他单位存在!");
+		}
+		if (!securityInvalidStatus.get()){
+			String errorAccount = StringUtils.join(securityInvalidList, "\\\n");
+			errorBuilder.append("用户:[" + errorAccount + "]保安证编号不匹配,请核实!也可通过提供保安证件信息提交核实申请!!");
+		}
+		//抛出异常
+		if (errorBuilder.length()>0){
+			throw new ServiceException(errorBuilder.toString());
 		}
 	}
 

--
Gitblit v1.9.3