From dd899673f3ff75ad59ae43afd124ef8ef0fc0180 Mon Sep 17 00:00:00 2001
From: Administrator <admin>
Date: Wed, 27 Apr 2022 17:24:12 +0800
Subject: [PATCH] ftp 同步修改调整

---
 src/main/java/org/springblade/modules/system/controller/UserController.java |  164 +++++++++++++++++++++++++++++++++++++++++++++++-------
 1 files changed, 142 insertions(+), 22 deletions(-)

diff --git a/src/main/java/org/springblade/modules/system/controller/UserController.java b/src/main/java/org/springblade/modules/system/controller/UserController.java
index 432472f..a3fb872 100644
--- a/src/main/java/org/springblade/modules/system/controller/UserController.java
+++ b/src/main/java/org/springblade/modules/system/controller/UserController.java
@@ -58,6 +58,8 @@
 import org.springblade.core.tool.support.Kv;
 import org.springblade.core.tool.utils.*;
 import org.springblade.modules.FTP.FtpUtil;
+import org.springblade.modules.FTP.Monitor;
+import org.springblade.modules.FTP.Result;
 import org.springblade.modules.accreditation.entity.AccreditationRecords;
 import org.springblade.modules.accreditation.service.AccreditationRecordsService;
 import org.springblade.modules.dispatcher.entity.Dispatcher;
@@ -86,6 +88,7 @@
 import org.springblade.modules.system.wrapper.UserWrapper;
 import org.springblade.modules.training.entity.TrainingRegistration;
 import org.springblade.modules.training.service.TrainingRegistrationService;
+import org.springframework.data.redis.core.RedisTemplate;
 import org.springframework.scheduling.annotation.Async;
 import org.springframework.transaction.annotation.Transactional;
 import org.springframework.web.bind.annotation.*;
@@ -142,6 +145,8 @@
 	private final SecurityPaperService securityPaperService;
 
 	private final MyAsyncService myAsyncService;
+
+	private final RedisTemplate redisTemplate;
 
 	/**
 	 * 查询单条
@@ -324,25 +329,31 @@
 		}
 
 		//判断是否持证
+		boolean states = false;
 		if (user.getHold().equals("1") && null!=user.getSecuritynumber() && !user.getSecuritynumber().equals("")){
 			//持证,校验保安证编号是否合法
 			SecurityPaper securityPaper = new SecurityPaper();
 			securityPaper.setIdCardNo(user.getCardid());
 			List<SecurityPaper> securityPaperList = securityPaperService.list(Condition.getQueryWrapper(securityPaper));
 			if (securityPaperList.size()>0){
-				boolean status = false;
 				//遍历
 				for (SecurityPaper paper : securityPaperList) {
 					if (paper.getNumber().equals(user.getSecuritynumber())){
-						status = true;
+						states = true;
 					}
 				}
-				if (!status){
-					throw new ServiceException("保安证编号不匹配,请核实!也可通过提供保安证件信息提交核实申请!");
+				if (!states){
+					user.setHold("2");
+//					throw new ServiceException("保安证编号不匹配,请核实!也可通过提供保安证件信息提交核实申请!");
 				}
 			}else {
-				throw new ServiceException("保安证编号不匹配,请核实!也可通过提供保安证件信息提交核实申请!");
+//				throw new ServiceException("保安证编号不匹配,请核实!也可通过提供保安证件信息提交核实申请!");
+				states = false;
+				user.setHold("2");
 			}
+		}
+		if (user.getHold().equals("2")){
+			states = true;
 		}
 
 		//如果是离职
@@ -555,7 +566,10 @@
 			//FtpUtil.sqlFileUpload(s1);
 			myAsyncService.FTP(s1);
 		}
-		return R.success("修改成功");
+		if (!states) {
+			return R.data(201,null,"保安证编号不匹配,请核实!也可通过提供保安证件信息提交核实申请!");
+		}
+		return R.data(200,null,"修改成功!");
 	}
 
 
@@ -649,7 +663,7 @@
 			}
 		}
 		//填写你文件上传的地址以及相应信息
-		String url = "http://223.82.109.183:2081";
+		String url = "http://61.131.136.25:2081";
 		String access = "zhbaadmin";
 		String secret = "zhbapassword";
 		String bucket = "zhba";
@@ -682,7 +696,7 @@
 		FtpUtil.uploadFile(FtpConfig.ftpHost, ftpPort, FtpConfig.ftpUserName, ftpPassword, ftpPath, "/", split[2], inputStream);
 		in.close();
 		//外围url
-		String urls = "http://223.82.109.183:2081/zhba/" + newName;
+		String urls = "http://61.131.136.25:2081/zhba/" + newName;
 		//内网
 		String inUrl = FtpConfig.ip + "/zhba/" + newName;
 		//返回
@@ -881,7 +895,7 @@
 	@ApiOperationSupport(order = 12)
 	@ApiOperation(value = "导入用户", notes = "传入excel")
 	public R importSecurityTest(MultipartFile file, Integer isCovered, String deptId) {
-		SecurityImporterTest securityImporter = new SecurityImporterTest(userService, false, deptId);
+		SecurityImporterTest securityImporter = new SecurityImporterTest(userService);
 		ExcelUtil.save(file, securityImporter, SecurityExcel.class);
 		return R.success("操作成功");
 	}
@@ -1169,6 +1183,7 @@
 		user.setDispatch("1");
 		user.setExaminationType("0");
 		user.setAccount(user.getCardid());
+		user.setStatus(1);
 
 		User user1 = new User();
 		user1.setIsDeleted(0);
@@ -1208,25 +1223,29 @@
 		}
 
 		//判断是否持证
+		boolean state = false;
 		if (user.getHold().equals("1")){
 			//持证,校验保安证编号是否合法
 			SecurityPaper securityPaper = new SecurityPaper();
 			securityPaper.setIdCardNo(user.getCardid());
 			List<SecurityPaper> securityPaperList = securityPaperService.list(Condition.getQueryWrapper(securityPaper));
 			if (securityPaperList.size()>0){
-				boolean status = false;
 				//遍历
 				for (SecurityPaper paper : securityPaperList) {
 					if (paper.getNumber().equals(user.getSecuritynumber())){
-						status = true;
+						state = true;
 					}
 				}
-				if (!status){
-					throw new ServiceException("保安证编号不匹配,请核实!也可通过提供保安证件信息提交核实申请!");
+				if (!state){
+					user.setHold("2");
+					user.setSecuritynumber(null);
 				}
 			}else {
-				throw new ServiceException("保安证编号不匹配,请核实!也可通过提供保安证件信息提交核实申请!");
+				user.setHold("2");
+				user.setSecuritynumber(null);
 			}
+		}else {
+			state = true;
 		}
 
 		String url = "";
@@ -1270,13 +1289,6 @@
 		experience.setPost("保安员");
 		experienceService.save(experience);
 
-
-		//发证日期处理
-//		if (user.getPaperTime() == null) {
-//			paperTime = "";
-//		} else {
-//			paperTime = new SimpleDateFormat("yyyy-MM-dd").format(user.getPaperTime());
-//		}
 		//头像
 		if (null != user.getAvatar() && !user.getAvatar().equals("")) {
 			user.setAvatar(FtpConfig.ip + user.getAvatar().substring(26));
@@ -1354,7 +1366,115 @@
 //			}
 //		}
 		//判断是否持证是否为空
-		return R.status(status);
+		if (!state) {
+			return R.data(201, null, "保安证编号不匹配,请核实!也可通过提供保安证件信息提交核实申请!");
+		}
+		return R.data(200,null,"新增成功!");
+	}
+
+	/**
+	 * 保安员新增(外网不能存敏感数据)
+	 * @since 2022-04-26
+	 * @param userMap
+	 */
+	@PostMapping("/securitySaves")
+	@Transactional(rollbackFor = Exception.class)
+	public R securitySaves(@Valid @RequestBody Map<String, Object> userMap) throws Exception {
+		//获取user
+		User user = JSON.parseObject(JSON.toJSONString(userMap.get("user")), User.class);
+
+		//分配保安角色
+		Role role = new Role();
+		role.setRoleAlias("保安");
+		Role oneRole = roleService.getOne(Condition.getQueryWrapper(role));
+		user.setRoleId(oneRole.getId().toString());
+		user.setDispatch("1");
+		user.setExaminationType("0");
+		user.setAccount(user.getRealName());
+		user.setStatus(1);
+
+		//密码加密
+		if (Func.isNotEmpty(user.getCardid())) {
+			//取身份证号码后6位作为密码
+			user.setPassword(DigestUtil.encrypt(user.getCardid().substring(user.getCardid().length() - 6)));
+		}
+		user.setCreateTime(new Date());
+		user.setTenantId("000000");
+		//用户新增
+//		boolean status = userService.save(user);
+
+
+		User user1 = user;
+		//头像
+		if (null != user.getAvatar() && !user.getAvatar().equals("")) {
+			user1.setAvatar(FtpConfig.ip + user.getAvatar().substring(26));
+		}
+		//指纹
+		String url = "";
+		if (null != user.getFingerprint() && !user.getFingerprint().equals("")) {
+			if (user.getFingerprint().length() > 100) {
+				String s = uploadBase64String(user);
+				String[] split = s.split(",");
+				user.setFingerprint(split[0]);
+				url = split[1];
+				user1.setFingerprint(url);
+			}
+		}
+
+		//生成随机数
+		String uuid = UUID.randomUUID().toString();
+		//将 user 存入 redis
+		redisTemplate.opsForValue().set(uuid,JSON.toJSONString(user));
+		//user1 临时设置uuid 到 reason_for_leav 离职原因字段
+		user1.setReasonForLeav(uuid);
+
+		//数据推送
+		Map<String, Object> map = new HashMap<>(1);
+		map.put("user",user1);
+		myAsyncService.FTPObject(map);
+
+		int count = 0;
+		int flag = 1;
+		Result result = new Result();
+		//调用ftp获取返回数据
+		while (true){
+			Thread.sleep(1000);
+			//调用ftp获取返回数据
+			result = Monitor.isFTPFileExist(uuid);
+			//如果返回true,就退处
+			if (result.getCode()==200){
+				flag = 1;
+				break;
+			}else if (result.getCode()==201){
+				flag = 2;
+				break;
+			}else if (result.getCode()==202){
+				flag = 3;
+				break;
+			}else if (result.getCode()==203){
+				flag = 4;
+				break;
+			}else{
+				//计数
+				count++;
+				//如果超过10s 没有读取到,则退出
+				if (count == 10) {
+					break;
+				}
+			}
+		}
+		if (flag==1 || flag==2) {
+			//返回
+			return R.data(200, null, "新增成功!");
+		}else if (flag==3){
+			throw new ServiceException(result.getMsg());
+		}else if (flag==4){
+//			return R.data(201, null, "保安证编号不匹配,请核实!也可通过提供保安证件信息提交核实申请!");
+			return R.data(201, null, "保安证编号不匹配,请核实!");
+		}else{
+			//返回
+			return R.data(400, null, "新增失败!");
+		}
 	}
 
 	/**

--
Gitblit v1.9.3