From 425daed225844521327f0913f7e28304db492c82 Mon Sep 17 00:00:00 2001 From: huanghongfa <18228131219@163.com> Date: 星期五, 18 十二月 2020 16:44:43 +0800 Subject: [PATCH] 社区管理房屋管理志愿者接口完成 --- springcloud_k8s_panzhihuazhihuishequ/service_user/src/main/java/com/panzhihua/service_user/service/impl/UserServiceImpl.java | 333 +++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 332 insertions(+), 1 deletions(-) diff --git a/springcloud_k8s_panzhihuazhihuishequ/service_user/src/main/java/com/panzhihua/service_user/service/impl/UserServiceImpl.java b/springcloud_k8s_panzhihuazhihuishequ/service_user/src/main/java/com/panzhihua/service_user/service/impl/UserServiceImpl.java index 199ceb2..5349eef 100644 --- a/springcloud_k8s_panzhihuazhihuishequ/service_user/src/main/java/com/panzhihua/service_user/service/impl/UserServiceImpl.java +++ b/springcloud_k8s_panzhihuazhihuishequ/service_user/src/main/java/com/panzhihua/service_user/service/impl/UserServiceImpl.java @@ -2,23 +2,35 @@ import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; +import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper; +import com.baomidou.mybatisplus.core.metadata.IPage; +import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.panzhihua.common.constants.UserConstants; import com.panzhihua.common.model.vos.LoginUserInfoVO; import com.panzhihua.common.model.vos.R; import com.panzhihua.common.model.vos.partybuilding.ActivityManagerVO; import com.panzhihua.common.model.vos.user.ChangePasswordVO; +import com.panzhihua.common.model.vos.user.ComMngFamilyInfoVO; +import com.panzhihua.common.model.vos.user.UserPhoneVO; +import com.panzhihua.service_user.dao.ComMngFamilyInfoDAO; +import com.panzhihua.service_user.dao.ComMngUserTagDAO; import com.panzhihua.service_user.dao.RoleDAO; import com.panzhihua.service_user.dao.UserDao; +import com.panzhihua.service_user.model.dos.ComMngFamilyInfoDO; +import com.panzhihua.service_user.model.dos.ComMngUserTagDO; import com.panzhihua.service_user.model.dos.SysRoleDO; import com.panzhihua.service_user.model.dos.SysUserDO; import com.panzhihua.service_user.service.UserService; import org.springframework.beans.BeanUtils; +import org.springframework.data.redis.core.StringRedisTemplate; +import org.springframework.data.redis.core.ValueOperations; import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder; import org.springframework.stereotype.Service; import org.springframework.util.ObjectUtils; import javax.annotation.Resource; import java.util.*; +import java.util.stream.Collectors; /** * @program: springcloud_k8s_panzhihuazhihuishequ @@ -32,6 +44,13 @@ private UserDao userDao; @Resource private RoleDAO roleDAO; + @Resource + private ComMngUserTagDAO comMngUserTagDAO; + @Resource + private ComMngFamilyInfoDAO comMngFamilyInfoDAO; + @Resource + private StringRedisTemplate stringRedisTemplate; + /** * 小程序微信用户信息更新 @@ -53,7 +72,7 @@ sysUserDO1.setOpenid(openid); sysUserDO1.setUnionid(unionid); sysUserDO1.setSessionKey(sessionKey); - sysUserDO1.setCreateTime(date); + sysUserDO1.setCreateAt(date); sysUserDO1.setLastLoginTime(date); sysUserDO1.setPassword(encode); sysUserDO1.setType(1); @@ -229,6 +248,318 @@ return R.ok(activityManagerVOS); } + /** + * 分页查询人脸识别 + * + * @param loginUserInfoVO 查询参数 + * @return 分页集合 + */ + @Override + public R pageUserFace(LoginUserInfoVO loginUserInfoVO) { + Page page = new Page<>(); + Long pageNum = loginUserInfoVO.getPageNum(); + Long pageSize = loginUserInfoVO.getPageSize(); + if (ObjectUtils.isEmpty(pageNum)||0==pageNum) { + pageNum = 1l; + } + if (ObjectUtils.isEmpty(pageSize)||0==pageSize) { + pageSize = 10l; + } + page.setSize(pageSize); + page.setCurrent(pageNum); + IPage<LoginUserInfoVO> iPage = userDao.pageUserFace(page, loginUserInfoVO); + return R.ok(iPage); + } + + /** + * 编辑人脸采集数据通过、驳回、删除 + * + * @param loginUserInfoVO 操作信息 + * @return 操作结果 + */ + @Override + public R putUserFace(LoginUserInfoVO loginUserInfoVO) { + int operationType = loginUserInfoVO.getOperationType().intValue(); + Long userId = loginUserInfoVO.getUserId(); + SysUserDO sysUserDO=new SysUserDO(); + sysUserDO.setUserId(userId); + switch (operationType){ + case 1: + sysUserDO.setFaceState(1); + break; + case 2: + sysUserDO.setFaceState(3); + break; + case 3: + break; + default: + break; + } + int num=0; + if (operationType==3) { + num=userDao.deleteById(userId); + } else { + num=userDao.updateById(sysUserDO); + } + if (num>0) { + return R.ok(); + } + return R.fail(); + } + + /** + * 分页查询人口管理 + * + * @param loginUserInfoVO 查询参数 + * @return 分页数据 + */ + @Override + public R pageUser(LoginUserInfoVO loginUserInfoVO) { + Page page = new Page<>(); + Long pageNum = loginUserInfoVO.getPageNum(); + Long pageSize = loginUserInfoVO.getPageSize(); + if (ObjectUtils.isEmpty(pageNum)||0==pageNum) { + pageNum = 1l; + } + if (ObjectUtils.isEmpty(pageSize)||0==pageSize) { + pageSize = 10l; + } + page.setSize(pageSize); + page.setCurrent(pageNum); + IPage<LoginUserInfoVO> iPage = userDao.pageUser(page, loginUserInfoVO); + return R.ok(iPage); + } + + /** + * 查询所有人员标签 + * + * @return 标签集合 + */ + @Override + public R listTag() { + List<String> list=new ArrayList<>(); + List<ComMngUserTagDO> comMngUserTagDOS = comMngUserTagDAO.selectList(null); + if (!ObjectUtils.isEmpty(comMngUserTagDOS)) { + list=comMngUserTagDOS.stream().map(comMngUserTagDO -> comMngUserTagDO.getTagName()).collect(Collectors.toList()); + } + return R.ok(list); + } + + /** + * 人员详情 + * + * @param userId 用户id + * @return 人员详情 + */ + @Override + public R detailUser(Long userId) { + SysUserDO sysUserDO = userDao.selectById(userId); + if (ObjectUtils.isEmpty(sysUserDO)) { + return R.fail("人员不存在"); + } + LoginUserInfoVO loginUserInfoVO=new LoginUserInfoVO(); + BeanUtils.copyProperties(sysUserDO,loginUserInfoVO); + List<ComMngFamilyInfoDO> comMngFamilyInfoDOS = comMngFamilyInfoDAO.selectList(new QueryWrapper<ComMngFamilyInfoDO>().lambda().eq(ComMngFamilyInfoDO::getUserId, userId)); + if (!ObjectUtils.isEmpty(comMngFamilyInfoDOS)) { + List<ComMngFamilyInfoVO>comMngFamilyInfoVOS=new ArrayList<>(); + comMngFamilyInfoDOS.forEach(comMngFamilyInfoDO -> { + ComMngFamilyInfoVO comMngFamilyInfoVO=new ComMngFamilyInfoVO(); + BeanUtils.copyProperties(comMngFamilyInfoDO,comMngFamilyInfoVO); + comMngFamilyInfoVOS.add(comMngFamilyInfoVO); + }); + loginUserInfoVO.setComMngFamilyInfoVOS(comMngFamilyInfoVOS); + } + return R.ok(loginUserInfoVO); + } + + /** + * 设置用户标签 + * + * @param loginUserInfoVO 标签信息 + * @return 设置结果 + */ + @Override + public R putUserTag(LoginUserInfoVO loginUserInfoVO) { + SysUserDO sysUserDO=new SysUserDO(); + sysUserDO.setUserId(loginUserInfoVO.getUserId()); + sysUserDO.setTags(loginUserInfoVO.getTags()); + int update = userDao.updateById(sysUserDO); + if (update>0) { + return R.ok(); + } + return R.fail(); + } + + /** + * 修改用户志愿者状态 + * + * @param phone 志愿者手机号 + * @param type + */ + @Override + public R putUserIsVolunteer(String phone, int type) { + SysUserDO sysUserDO=new SysUserDO(); + sysUserDO.setIsVolunteer(type); + int update = userDao.update(sysUserDO, new UpdateWrapper<SysUserDO>().lambda().eq(SysUserDO::getPhone, phone)); + if (update>0) { + return R.ok(); + } + return R.fail(); + } + + /** + * 用户绑定社区、小区 + * + * @param loginUserInfoVO 社区小区数据 + * @return 绑定结果 + */ + @Override + public R putUserCommunityArea(LoginUserInfoVO loginUserInfoVO) { + SysUserDO sysUserDO=new SysUserDO(); + sysUserDO.setCommunityId(loginUserInfoVO.getCommunityId()); + sysUserDO.setAreaId(loginUserInfoVO.getAreaId()); + sysUserDO.setUserId(loginUserInfoVO.getUserId()); + int update = userDao.updateById(sysUserDO); + if (update>0) { + return R.ok(); + } + return R.fail(); + } + + /** + * 用户实名认证 + * + * @param loginUserInfoVO 认证数据 + * @return 认证结果 + */ + @Override + public R putUserAuthentication(LoginUserInfoVO loginUserInfoVO) { + SysUserDO sysUserDO=new SysUserDO(); + sysUserDO.setName(loginUserInfoVO.getName()); + sysUserDO.setIdCard(loginUserInfoVO.getIdCard()); + sysUserDO.setSex(loginUserInfoVO.getSex()); + sysUserDO.setBirthday(loginUserInfoVO.getBirthday()); + sysUserDO.setJob(loginUserInfoVO.getJob()); + sysUserDO.setUserId(loginUserInfoVO.getUserId()); + sysUserDO.setFaceUrl(loginUserInfoVO.getFaceUrl()); + sysUserDO.setFaceState(0); + int update = userDao.updateById(sysUserDO); + if (update>0) { + return R.ok(); + } + return R.fail(); + } + + /** + * 修改用户手机号 + * + * @param userPhoneVO 手机号信息 + * @return 修改结果 + */ + @Override + public R putUserphone(UserPhoneVO userPhoneVO) { + String oldPhone = userPhoneVO.getOldPhone(); + String newPhone = userPhoneVO.getNewPhone(); + String smsCode = userPhoneVO.getSmsCode(); + if (oldPhone.equals(newPhone)) { + return R.fail("新旧手机号不能重复"); + } + String key = UserConstants.PHONE_PUT + newPhone; + Boolean hasKey = stringRedisTemplate.hasKey(key); + if (!hasKey) { + return R.fail("重新发送验证码"); + } + SysUserDO sysUserDO1 = userDao.selectById(userPhoneVO.getUserId()); + String phone = sysUserDO1.getPhone(); + if (!phone.equals(oldPhone)) { + return R.fail("旧手机号错误"); + } + ValueOperations<String, String> valueOperations = stringRedisTemplate.opsForValue(); + String code = valueOperations.get(key); + if (!code.equals(smsCode)) { + return R.fail("验证码错误"); + } + SysUserDO sysUserDO=new SysUserDO(); + sysUserDO.setUserId(userPhoneVO.getUserId()); + sysUserDO.setPhone(newPhone); + int update = userDao.updateById(sysUserDO); + if (update>0) { + return R.ok(); + } + return R.fail(); + } + + /** + * 修改用户信息 + * + * @param loginUserInfoVO 修改内容 + * @return 修改结果 + */ + @Override + public R putUser(LoginUserInfoVO loginUserInfoVO) { + SysUserDO sysUserDO=new SysUserDO(); + BeanUtils.copyProperties(loginUserInfoVO,sysUserDO); + int update = userDao.updateById(sysUserDO); + if (update>0) { + return R.ok(); + } + return R.fail(); + } + + /** + * 家庭成员列表 + * + * @param userId 登录用户 + * @return 成员集合 + */ + @Override + public R listFamily(Long userId) { + List<ComMngFamilyInfoVO>comMngFamilyInfoVOS=new ArrayList<>(); + List<ComMngFamilyInfoDO> comMngFamilyInfoDOS = comMngFamilyInfoDAO.selectList(new QueryWrapper<ComMngFamilyInfoDO>().lambda().eq(ComMngFamilyInfoDO::getUserId, userId)); + if (!ObjectUtils.isEmpty(comMngFamilyInfoDOS)) { + comMngFamilyInfoDOS.forEach(comMngFamilyInfoDO -> { + ComMngFamilyInfoVO comMngFamilyInfoVO=new ComMngFamilyInfoVO(); + BeanUtils.copyProperties(comMngFamilyInfoDO,comMngFamilyInfoVO); + comMngFamilyInfoVOS.add(comMngFamilyInfoVO); + }); + } + return R.ok(comMngFamilyInfoVOS); + } + + /** + * 新增家庭成员 + * + * @param comMngFamilyInfoVO 家庭成员基本信息 + * @return 增加结果 + */ + @Override + public R addFamily(ComMngFamilyInfoVO comMngFamilyInfoVO) { + ComMngFamilyInfoDO comMngFamilyInfoDO=new ComMngFamilyInfoDO(); + BeanUtils.copyProperties(comMngFamilyInfoVO,comMngFamilyInfoDO); + int insert = comMngFamilyInfoDAO.insert(comMngFamilyInfoDO); + if (insert>0) { + return R.ok(); + } + return R.fail(); + } + + /** + * 编辑家庭成员 + * + * @param comMngFamilyInfoVO 家庭成员信息 + * @return 编辑结果 + */ + @Override + public R putFamily(ComMngFamilyInfoVO comMngFamilyInfoVO) { + ComMngFamilyInfoDO comMngFamilyInfoDO=new ComMngFamilyInfoDO(); + BeanUtils.copyProperties(comMngFamilyInfoDO,comMngFamilyInfoVO); + int update = comMngFamilyInfoDAO.updateById(comMngFamilyInfoDO); + if (update>0) { + return R.ok(); + } + return R.fail(); + } + public static void main(String[] args) { String encode = new BCryptPasswordEncoder().encode("123456"); System.out.println(encode); -- Gitblit v1.7.1