From 7d581f0f8c74beb999b4482bf2bbdc59e4d5846d Mon Sep 17 00:00:00 2001
From: Administrator <admin>
Date: Wed, 11 May 2022 10:36:38 +0800
Subject: [PATCH] 保安员,用户新增,保安员查询姓名修改,账号修改为姓+身份证号码后4位

---
 src/main/java/org/springblade/modules/system/controller/UserController.java |  254 +++++++++++++++++++++++++++++++++++++++++++-------
 1 files changed, 218 insertions(+), 36 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 a3fb872..e62ded0 100644
--- a/src/main/java/org/springblade/modules/system/controller/UserController.java
+++ b/src/main/java/org/springblade/modules/system/controller/UserController.java
@@ -229,20 +229,37 @@
 	//@PreAuth(RoleConstant.HAS_ROLE_ADMIN)
 	public R submit(@Valid @RequestBody User user) {
 		if (null == user.getId()) {
-			//新增
-			//密码加密
-			if (Func.isNotEmpty(user.getPassword())) {
-				user.setPassword(DigestUtil.encrypt(user.getPassword()));
-			}
 			Integer userCount = userService.selectCountAccount(user.getAccount());
 			if (userCount > 0) {
 				throw new org.springblade.core.log.exception.ServiceException(StringUtil.format("当前用户 [{}] 已存在!", user.getAccount()));
 			}
+			//判断角色
+			if(user.getRoleId().equals("1412226235153731586")){
+				//如果是保安员,默认为无证
+				user.setHold("2");
+			}
 			user.setTenantId("000000");
+			user.setDispatch("1");
+			//待审查
+			user.setExaminationType("2");
+//			String realName = user.getRealName();
+//			String cardid = user.getCardid();
+////			user.setAccount(user.getRealName());
+//			user.setAccount(realName.substring(0,1)+cardid.substring(cardid.length()-4));
+			//默认在职
 			user.setStatus(1);
 			user.setIsDeleted(0);
 			user.setCreateTime(new Date());
 			user.setUpdateTime(new Date());
+
+			//密码加密
+			if (Func.isNotEmpty(user.getCardid())) {
+				//取身份证号码后6位作为密码
+				user.setPassword(DigestUtil.encrypt(user.getCardid().substring(user.getCardid().length() - 6)));
+			}
+			user.setCreateTime(new Date());
+			user.setTenantId("000000");
+
 			//判断是否为民警 code
 			if (null != user.getCode() && !user.getCode().equals("")) {
 				//民警
@@ -254,32 +271,72 @@
 				Jurisdiction one = jurisdictionService.getOne(Condition.getQueryWrapper(jurisdiction));
 				user.setJurisdiction(one.getId().toString());
 			}
-			//新增
-			boolean stats = userService.save(user);
-			if (stats) {
-				//内网同步
-				String s = "insert into blade_user(" +
-					"id,tenant_id,code,account,password,real_name,phone,sex,role_id,dept_id," +
-					"create_time,update_time,cardid,status,is_deleted,jurisdiction) " +
-					"values(" + "'" + user.getId() + "'" + "," +
-					"'" + user.getTenantId() + "'" + "," +
-					"'" + user.getCode() + "'" + "," +
-					"'" + user.getAccount() + "'" + "," +
-					"'" + user.getPassword() + "'" + "," +
-					"'" + user.getRealName() + "'" + "," +
-					"'" + user.getPhone() + "'" + "," +
-					"'" + user.getSex() + "'" + "," +
-					"'" + user.getRoleId() + "'" +
-					"," + "'" + user.getDeptId() + "'" +
-					"," + "'" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(user.getCreateTime()) + "'" +
-					"," + "'" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(user.getUpdateTime()) + "'" +
-					"," + "'" + user.getCardid() + "'" +
-					"," + "'" + user.getStatus() + "'" +
-					"," + "'" + user.getIsDeleted() + "'" +
-					"," + "'" + user.getJurisdiction() + "'"
-					+ ")";
-				myAsyncService.FTP(s);
+			//用户新增
+//		boolean status = userService.save(user);
+
+
+			User user1 = Objects.requireNonNull(BeanUtil.copy(user,User.class));
+
+			//生成随机数
+			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){
+				try {
+					Thread.sleep(1000);
+				} catch (InterruptedException e) {
+					e.printStackTrace();
+				}
+				//调用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 == 30) {
+						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, "新增失败!");
+			}
+
+
 		} else {
 			//修改
 			User user1 = userService.getById(user.getId());
@@ -306,6 +363,93 @@
 		//返回
 		return R.success("成功");
 	}
+
+	/**
+//	 * 新增或修改
+//	 */
+//	@PostMapping("/submit")
+//	@ApiOperationSupport(order = 4)
+//	@ApiOperation(value = "新增或修改", notes = "传入User")
+//	//@PreAuth(RoleConstant.HAS_ROLE_ADMIN)
+//	public R submit(@Valid @RequestBody User user) {
+//		if (null == user.getId()) {
+//			//新增
+//			//密码加密
+//			if (Func.isNotEmpty(user.getPassword())) {
+//				user.setPassword(DigestUtil.encrypt(user.getPassword()));
+//			}
+//			Integer userCount = userService.selectCountAccount(user.getAccount());
+//			if (userCount > 0) {
+//				throw new org.springblade.core.log.exception.ServiceException(StringUtil.format("当前用户 [{}] 已存在!", user.getAccount()));
+//			}
+//			user.setTenantId("000000");
+//			user.setStatus(1);
+//			user.setIsDeleted(0);
+//			user.setCreateTime(new Date());
+//			user.setUpdateTime(new Date());
+//			//判断是否为民警 code
+//			if (null != user.getCode() && !user.getCode().equals("")) {
+//				//民警
+//				//根据 deptId 查询dept信息,公安管理员
+//				Dept dept = iDeptService.getById(user.getDeptId());
+//				//获取辖区的数据
+//				Jurisdiction jurisdiction = new Jurisdiction();
+//				jurisdiction.setDeptName(dept.getDeptName());
+//				Jurisdiction one = jurisdictionService.getOne(Condition.getQueryWrapper(jurisdiction));
+//				user.setJurisdiction(one.getId().toString());
+//			}
+//			//新增
+//			boolean stats = userService.save(user);
+//			if (stats) {
+//				//内网同步
+//				String s = "insert into blade_user(" +
+//					"id,tenant_id,code,account,password,real_name,phone,sex,role_id,dept_id," +
+//					"create_time,update_time,cardid,status,is_deleted,jurisdiction) " +
+//					"values(" + "'" + user.getId() + "'" + "," +
+//					"'" + user.getTenantId() + "'" + "," +
+//					"'" + user.getCode() + "'" + "," +
+//					"'" + user.getAccount() + "'" + "," +
+//					"'" + user.getPassword() + "'" + "," +
+//					"'" + user.getRealName() + "'" + "," +
+//					"'" + user.getPhone() + "'" + "," +
+//					"'" + user.getSex() + "'" + "," +
+//					"'" + user.getRoleId() + "'" +
+//					"," + "'" + user.getDeptId() + "'" +
+//					"," + "'" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(user.getCreateTime()) + "'" +
+//					"," + "'" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(user.getUpdateTime()) + "'" +
+//					"," + "'" + user.getCardid() + "'" +
+//					"," + "'" + user.getStatus() + "'" +
+//					"," + "'" + user.getIsDeleted() + "'" +
+//					"," + "'" + user.getJurisdiction() + "'"
+//					+ ")";
+//				myAsyncService.FTP(s);
+//			}
+//		} else {
+//			//修改
+//			User user1 = userService.getById(user.getId());
+//			user.setPassword(user1.getPassword());
+//			user.setUpdateTime(new Date());
+//			boolean b = userService.updateById(user);
+//			if (b) {
+//				String s1 =
+//					"update blade_user set account = " + "'" + user.getAccount() + "'"
+//						+ ",code = " + "'" + user.getCode() + "'"
+//						+ ",real_name = " + "'" + user.getRealName() + "'"
+//						+ ",phone = " + "'" + user.getPhone() + "'"
+//						+ ",sex = " + "'" + user.getSex() + "'"
+//						+ ",update_time = " + "'" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(user.getUpdateTime()) + "'"
+//						+ ",role_id = " + "'" + user.getRoleId() + "'"
+//						+ ",dept_id = " + "'" + user.getDeptId() + "'"
+//						+ ",cardid = " + "'" + user.getCardid() + "'"
+//						+ ",guncode = " + "'" + user.getGuncode() + "'"
+//						+ " " + "where id = " + "'" + user.getId() + "'";
+//				myAsyncService.FTP(s1);
+//			}
+//		}
+//
+//		//返回
+//		return R.success("成功");
+//	}
 
 	/**
 	 * 修改
@@ -570,6 +714,41 @@
 			return R.data(201,null,"保安证编号不匹配,请核实!也可通过提供保安证件信息提交核实申请!");
 		}
 		return R.data(200,null,"修改成功!");
+	}
+
+	/**
+	 * 账号修改
+	 * @param user
+	 * @return
+	 */
+	@PostMapping("/update_account")
+	public R updataAccount(@RequestBody User user){
+		boolean status = false;
+		//校验账户是否重复
+		User user1 = new User();
+		user1.setIsDeleted(0);
+		user1.setStatus(1);
+		user1.setAccount(user.getAccount());
+		List<User> list = userService.list(new QueryWrapper<>(user1));
+		if (list.size()>0){
+			throw new ServiceException("账号:["+user.getAccount()+"]已存在!");
+		}
+		//如果不重复,则进行修改操作
+		//更新用户账户信息
+		status = userService.updateById(user);
+		if (status){
+			System.out.println("user = " + user);
+			UserDTO userDTO = new UserDTO();
+			userDTO.setAccount(user.getAccount());
+			userDTO.setPassword(user.getPassword());
+			userDTO.setSecurityId(user.getId().toString());
+			userDTO.setPhone(user.getPhone());
+			userDTO.setAvatar(user.getAvatar());
+			//异步修改群防群控
+			myAsyncService.updateUserByAccount(userDTO);
+		}
+		//返回
+		return R.status(status);
 	}
 
 
@@ -1133,6 +1312,7 @@
 	@GetMapping("/security-apply-tree")
 	public R<List<TreeNode>> securityApplyTree(UserVO user) {
 		List<TreeNode> tree = userService.getSecurityApplyTree(user);
+		System.out.println("tree = " + tree);
 		return R.data(tree);
 	}
 
@@ -1389,8 +1569,12 @@
 		Role oneRole = roleService.getOne(Condition.getQueryWrapper(role));
 		user.setRoleId(oneRole.getId().toString());
 		user.setDispatch("1");
-		user.setExaminationType("0");
-		user.setAccount(user.getRealName());
+		//待审查
+		user.setExaminationType("2");
+		String realName = user.getRealName();
+		String cardid = user.getCardid();
+//			user.setAccount(user.getRealName());
+		user.setAccount(realName.substring(0,1)+cardid.substring(cardid.length()-4));
 		user.setStatus(1);
 
 		//密码加密
@@ -1404,7 +1588,7 @@
 //		boolean status = userService.save(user);
 
 
-		User user1 = user;
+		User user1 = Objects.requireNonNull(BeanUtil.copy(user,User.class));
 		//头像
 		if (null != user.getAvatar() && !user.getAvatar().equals("")) {
 			user1.setAvatar(FtpConfig.ip + user.getAvatar().substring(26));
@@ -1458,7 +1642,7 @@
 				//计数
 				count++;
 				//如果超过10s 没有读取到,则退出
-				if (count == 10) {
+				if (count == 30) {
 					break;
 				}
 			}
@@ -1552,7 +1736,6 @@
 				"," + "'" + experience.getCompanyname() + "'" +
 				"," + "'" + experience.getSecurityid() + "'"
 				+ ")";
-			//FtpUtil.sqlFileUpload(s);
 			myAsyncService.FTP(s);
 		}
 	}
@@ -1595,7 +1778,6 @@
 		if (null != user1.getFingerprint() && !user1.getFingerprint().equals("")) {
 			//url 转base64
 			String base64Url = ImageUtils.imageUrlToBase64(user1.getFingerprint());
-			System.out.println("base64Url = " + base64Url);
 			user1.setFingerprint(base64Url);
 		}
 		return R.data(user1);

--
Gitblit v1.9.3