From 2c8b9868fe8c45320eb18fd5d6b51ec770c30610 Mon Sep 17 00:00:00 2001 From: huanghongfa <huanghongfa123456> Date: 星期六, 24 七月 2021 11:43:57 +0800 Subject: [PATCH] 注释用户实名认证请求公安接口 --- springcloud_k8s_panzhihuazhihuishequ/service_user/src/main/java/com/panzhihua/service_user/service/impl/UserServiceImpl.java | 410 +++++++++++++++++++++++++++++++++++++++++++++++++++++++-- 1 files changed, 390 insertions(+), 20 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 197facb..4de00fd 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 @@ -11,13 +11,18 @@ import com.panzhihua.common.model.dtos.PageDTO; import com.panzhihua.common.model.dtos.community.ExportUserDTO; import com.panzhihua.common.model.dtos.community.NoticeReadDTO; +import com.panzhihua.common.model.dtos.grid.*; import com.panzhihua.common.model.dtos.user.*; import com.panzhihua.common.model.vos.*; import com.panzhihua.common.model.vos.community.ComActVO; import com.panzhihua.common.model.vos.community.ComMngVolunteerMngVO; +import com.panzhihua.common.model.vos.grid.EventGridMemberRelationVO; +import com.panzhihua.common.model.vos.grid.GridMemberVO; +import com.panzhihua.common.model.vos.grid.admin.GridMemberBuildingVO; import com.panzhihua.common.model.vos.partybuilding.ActivityManagerVO; import com.panzhihua.common.model.vos.shop.ShopStoreVO; import com.panzhihua.common.model.vos.user.*; +//import com.panzhihua.common.service.grid.GridService; import com.panzhihua.common.service.partybuilding.PartyBuildingService; import com.panzhihua.common.utlis.IdCard; import com.panzhihua.common.utlis.RealNameUtil; @@ -25,6 +30,7 @@ import com.panzhihua.service_user.dao.*; import com.panzhihua.service_user.model.dos.*; import com.panzhihua.service_user.model.dtos.DataKanbanDTO; +import com.panzhihua.service_user.service.EventGridMemberBuildingRelationService; import com.panzhihua.service_user.service.UserService; import lombok.extern.slf4j.Slf4j; import org.apache.commons.lang.time.DateFormatUtils; @@ -78,7 +84,12 @@ private SysMenuDAO sysMenuDAO; @Resource private SysUserInputDAO sysUserInputDAO; - + @Resource + private EventGridMemberBuildingRelationService buildingRelationService; + @Resource + private EventGridMemberBuildingRelationMapper eventGridMemberBuildingRelationMapper; +// @Resource +// private GridService gridService; /** * 小程序微信用户信息更新 @@ -233,6 +244,12 @@ // 志愿者状态 String phone = sysUserDO.getPhone(); Long userCommunityId = sysUserDO.getCommunityId(); + if(userCommunityId!=null){ + ComActVO comActVO = userDao.selectCommunity(userCommunityId); + if(comActVO!=null) { + loginUserInfoVO.setCommunityName(comActVO.getName()); + } + } if (!ObjectUtils.isEmpty(phone)) { ComMngVolunteerMngVO comMngVolunteerMngVO = userDao.selectVolunteerMngByPhone(phone); if (ObjectUtils.isEmpty(comMngVolunteerMngVO)) { @@ -609,14 +626,14 @@ String idCard = loginUserInfoVO.getIdCard(); String name = loginUserInfoVO.getName(); log.info("用户实名认证发送请求,姓名:" + name + "身份证号码:" + idCard); - try { - boolean b = RealNameUtil.authentication(idCard, name); - if (!b) { - return R.fail("身份认证失败:请填写真实信息"); - } - }catch (ServiceException serviceException){ - return R.fail(serviceException.getMessage()); - } +// try { +// boolean b = RealNameUtil.authentication(idCard, name); +// if (!b) { +// return R.fail("身份认证失败:请填写真实信息"); +// } +// }catch (ServiceException serviceException){ +// return R.fail(serviceException.getMessage()); +// } SysUserDO sysUserDO = new SysUserDO(); sysUserDO.setName(name); sysUserDO.setIdCard(idCard); @@ -865,6 +882,29 @@ } } + + if(insert>0 && sysUserDO.getType()==3){//添加的用户是社区账号时 + //添加网格综合治理管理后台用户 + SysUserDO sysUserDOWangGe = new SysUserDO(); + BeanUtils.copyProperties(sysUserDO, sysUserDOWangGe); + sysUserDOWangGe.setUserId(null); + sysUserDOWangGe.setType(7);//网格综治后台 + try { + int addWange = userDao.insert(sysUserDOWangGe); + if(addWange!=1){ + throw new ServiceException("新增网格综合治理管理后台用户失败"); + } + } catch (Exception e) { + e.printStackTrace(); + log.error("网格综合治理管理后台用户报错【{}】", e.getMessage()); + if (e.getMessage().contains("union_phone_type")) { + throw new ServiceException("手机号已经存在"); + } else if (e.getMessage().contains("union_account_type")) { + throw new ServiceException("账户已经存在"); + } + + } + } if (insert > 0) { SysUserDO sysUserDO1 = userDao.selectOne(new QueryWrapper<SysUserDO>().lambda().eq(SysUserDO::getType, administratorsUserVO.getType()).eq(SysUserDO::getAccount, administratorsUserVO.getAccount())); Long userId = sysUserDO1.getUserId(); @@ -921,14 +961,19 @@ // 获取所有权限id List<SysMenuDO> menuDOList = sysMenuDAO.selectList(new QueryWrapper<SysMenuDO>().lambda().eq(SysMenuDO::getCommunityId, 2l).orderByAsc(SysMenuDO::getOrderNum)); - menuIds = menuDOList.stream().map(sysMenuDO -> sysMenuDO.getMenuId()).collect(Collectors.toList()); - for (int i = 0; i < menuIds.size(); i++) { - SysRoleMenuDO sysRoleMenuDO = new SysRoleMenuDO(); - sysRoleMenuDO.setMenuId(menuIds.get(i)); - sysRoleMenuDO.setRoleId(roleId); - sysRoleMenuDAO.insert(sysRoleMenuDO); + if(!menuDOList.isEmpty()){ + menuIds = menuDOList.stream().map(sysMenuDO -> sysMenuDO.getMenuId()).collect(Collectors.toList()); + for (int i = 0; i < menuIds.size(); i++) { + SysRoleMenuDO sysRoleMenuDO = sysRoleMenuDAO.selectOne(new QueryWrapper<SysRoleMenuDO>().lambda().eq(SysRoleMenuDO::getMenuId,menuIds.get(i)) + .eq(SysRoleMenuDO::getRoleId,roleId)); + if(sysRoleMenuDO == null){ + sysRoleMenuDO = new SysRoleMenuDO(); + sysRoleMenuDO.setMenuId(menuIds.get(i)); + sysRoleMenuDO.setRoleId(roleId); + sysRoleMenuDAO.insert(sysRoleMenuDO); + } + } } - return R.ok(); } @@ -1079,8 +1124,9 @@ * @return 协议集合 */ @Override - public R listAgreement() { - List<SysUserAgreementDO> sysUserAgreementDOS = sysUserAgreementDAO.selectList(new LambdaQueryWrapper<>()); + public R listAgreement(Long communityId) { + List<SysUserAgreementDO> sysUserAgreementDOS = sysUserAgreementDAO.selectList(new LambdaQueryWrapper<SysUserAgreementDO>() + .eq(SysUserAgreementDO::getCommunityId,communityId)); if (ObjectUtils.isEmpty(sysUserAgreementDOS)) { return R.fail(); } @@ -1118,7 +1164,7 @@ */ @Override public R listComMngUserTag(Long communityId) { - List<ComMngUserTagDO> comMngUserTagDOS = comMngUserTagDAO.selectList(new QueryWrapper<ComMngUserTagDO>().lambda().eq(ComMngUserTagDO::getCommunityId, communityId)); + List<ComMngUserTagDO> comMngUserTagDOS = comMngUserTagDAO.selectList(new QueryWrapper<ComMngUserTagDO>().or().lambda().eq(ComMngUserTagDO::getSysFlag,1).or().eq(ComMngUserTagDO::getCommunityId, communityId)); if (ObjectUtils.isEmpty(comMngUserTagDOS)) { return R.fail(); } @@ -1625,7 +1671,7 @@ @Override public R getSysUserVOByPhone(String phone) { - SysUserDO sysUserDO = userDao.selectOne(new QueryWrapper<SysUserDO>().lambda().eq(SysUserDO::getPhone, phone)); + SysUserDO sysUserDO = userDao.selectOne(new QueryWrapper<SysUserDO>().lambda().eq(SysUserDO::getPhone, phone).eq(SysUserDO::getType,1)); if (ObjectUtils.isEmpty(sysUserDO)) { return R.fail("用户不存在"); } @@ -1802,4 +1848,328 @@ userDao.updateUserArchives(userArchivesVO); return R.ok(); } + + /** + * 修改app用户密码 + * @param userInfoAppDTO 请求参数 + * @return 修改结果 + */ + @Override + public R updateUserPassByApp(EditUserInfoPassAppDTO userInfoAppDTO){ + if(userInfoAppDTO.getOldPassword().equals(userInfoAppDTO.getNewPassword())){ + return R.fail("新密码不可与原密码相同"); + } + //查询用户信息 + SysUserDO userDO = userDao.selectById(userInfoAppDTO.getUserId()); + if (userDO == null) { + return R.fail("未查询到用户信息"); + } + BCryptPasswordEncoder passwordEncoder = new BCryptPasswordEncoder(); + if (!passwordEncoder.matches(userInfoAppDTO.getOldPassword(),userDO.getPassword())) { + return R.fail("原密码错误"); + } + if(!userInfoAppDTO.getNewPassword().equals(userInfoAppDTO.getConfirmPassword())){ + return R.fail("两次输入的新密码不一致"); + } + userDO.setPassword(passwordEncoder.encode(userInfoAppDTO.getNewPassword())); + if (userDao.updateById(userDO) > 0) { + return R.ok(); + } else { + return R.fail(); + } + } + + /** + * 添加网格员 + * @param eventGridMemberAddDTO 请求参数 + * @return 结果 + */ + @Override + @Transactional(rollbackFor = Exception.class) + public R addGridUser(EventGridMemberAddDTO eventGridMemberAddDTO) { + + SysRoleDO gridMemberDefaultRole = roleDAO.selectOne(new QueryWrapper<SysRoleDO>().lambda().eq(SysRoleDO::getRoleKey, Constants.GRID_DEFAULT_ROLE_KEY)); + if(gridMemberDefaultRole==null) { + //添加默认网格员角色 + gridMemberDefaultRole = new SysRoleDO(); + gridMemberDefaultRole.setCommunityId(0L); + gridMemberDefaultRole.setRoleName("网格员默认角色"); + gridMemberDefaultRole.setRoleKey(Constants.GRID_DEFAULT_ROLE_KEY); + gridMemberDefaultRole.setRoleSort(0); + gridMemberDefaultRole.setCreateBy(eventGridMemberAddDTO.getUserId()); + int insert = roleDAO.insert(gridMemberDefaultRole); + if (insert!=1) { + throw new ServiceException("网格员默认角色添加失败"); + } + } + Long roleId = gridMemberDefaultRole.getRoleId(); + //新角色设置所有权限 + MenuRoleVO menuRoleVO = new MenuRoleVO(); + menuRoleVO.setIsAll(1); + menuRoleVO.setCommunityId(eventGridMemberAddDTO.getCommunityId()); + menuRoleVO.setRoleId(roleId); + this.putMenuRole(menuRoleVO); + + //参数校验 + SysUserDO oldUserDO = userDao.selectOne(new QueryWrapper<SysUserDO>().lambda().eq(SysUserDO::getType,6) + .eq(SysUserDO::getNickName,eventGridMemberAddDTO.getNickName())); + if(oldUserDO != null){ + return R.fail("昵称已使用"); + } + + SysUserDO sysUserDO = new SysUserDO(); + String encode = new BCryptPasswordEncoder().encode(eventGridMemberAddDTO.getPassword()); + eventGridMemberAddDTO.setPassword(encode); + BeanUtils.copyProperties(eventGridMemberAddDTO, sysUserDO); + if(!StringUtils.isEmpty(sysUserDO.getNickName())){ + sysUserDO.setName(sysUserDO.getNickName()); + } + sysUserDO.setType(6); + if(StringUtils.isEmpty(eventGridMemberAddDTO.getImageUrl())){ + sysUserDO.setImageUrl(Constants.ZONG_ZHI_GRID_MEMBER_IMAGE_URL); + } + int insert = 0; + try { + insert = userDao.insert(sysUserDO); + SysUserRoleDO sysUserRoleDO = new SysUserRoleDO(); + sysUserRoleDO.setUserId(sysUserDO.getUserId()); + sysUserRoleDO.setRoleId(roleId); + sysUserRoleDAO.insert(sysUserRoleDO); + + //关联市平台网格员 + if(eventGridMemberAddDTO.getLcMemberId() != null){ + this.userDao.addLcMember(eventGridMemberAddDTO.getLcMemberId(),sysUserDO.getUserId(),sysUserDO.getNickName()); + } + + //网格员关联楼栋 + if(eventGridMemberAddDTO.getBuildingIds() != null && !eventGridMemberAddDTO.getBuildingIds().isEmpty()){ + List<EventGridMemberBuildingRelationDO> buildingRelationList = new ArrayList<>(); + eventGridMemberAddDTO.getBuildingIds().forEach(buildingId -> { + Map<String,Long> resultMap = this.userDao.getBuilding(buildingId); + if(resultMap != null){ + EventGridMemberBuildingRelationDO buildingRelationDO = new EventGridMemberBuildingRelationDO(); + buildingRelationDO.setBuildingId(buildingId); + buildingRelationDO.setGridMemberId(sysUserDO.getUserId()); + buildingRelationDO.setVillageId(Long.parseLong(resultMap.get("village_id").toString())); + buildingRelationDO.setCommunityId(Long.parseLong(resultMap.get("act_id").toString())); + buildingRelationDO.setCreateAt(new Date()); + buildingRelationList.add(buildingRelationDO); + } + }); + if(!buildingRelationList.isEmpty()){ + buildingRelationService.saveBatch(buildingRelationList); + } + } + } catch (Exception e) { + e.printStackTrace(); + log.error("新增后台用户报错【{}】", e.getMessage()); + if (e.getMessage().contains("union_phone_type")) { + return R.fail("手机号已经存在"); + } else if (e.getMessage().contains("union_account_type")) { + return R.fail("账户已经存在"); + } + } + if(insert > 0){ + return R.ok(); + }else{ + return R.fail("添加失败"); + } + } + + /** + * 网格员管理 + * @param memberRelationDTO 请求参数 + * @return 网格员列表 + */ + @Override + public R getGridMemberList(PageEventGridMemberRelationDTO memberRelationDTO){ + IPage<GridMemberVO> gridMemberPage = userDao.getGridMemberList(new Page(memberRelationDTO.getPageNum() + ,memberRelationDTO.getPageSize()),memberRelationDTO); + if(!gridMemberPage.getRecords().isEmpty()){ + gridMemberPage.getRecords().forEach(gridMember -> { + //查询网格员关联市平台网格员id + gridMember.setLcMemberId(this.userDao.getLcMemberId(gridMember.getUserId())); + + //查询网格员关联楼栋信息 + List<GridMemberBuildingVO> memberBuildingList = eventGridMemberBuildingRelationMapper.getGridMemberBuildingRelation(gridMember.getUserId()); + if(!memberBuildingList.isEmpty()){ + memberBuildingList.forEach(memberBuilding -> { + if(!memberBuilding.getBuildingName().contains("栋")){ + memberBuilding.setBuildingName(memberBuilding.getBuildingName() + "栋"); + } + }); + gridMember.setMemberBuildingList(memberBuildingList); + } + }); + } + return R.ok(gridMemberPage); + } + + /** + * 修改网格员信息 + * @param gridMemberDTO 请求参数 + * @return 修改结果 + */ + @Override + @Transactional(rollbackFor = Exception.class) + public R editGridUser(EventGridMemberEditAdminDTO gridMemberDTO){ + + if(gridMemberDTO.getGridMemberId() == null){ + return R.fail("参数错误"); + } + SysUserDO sysUserDO = userDao.selectById(gridMemberDTO.getGridMemberId()); + if(sysUserDO == null){ + return R.fail("参数错误"); + } + gridMemberDTO.setUserId(gridMemberDTO.getGridMemberId()); + + //参数校验 + SysUserDO oldUserDO = userDao.selectOne(new QueryWrapper<SysUserDO>().lambda().eq(SysUserDO::getType,6) + .eq(SysUserDO::getNickName,gridMemberDTO.getNickName())); + if(oldUserDO != null && !oldUserDO.getUserId().equals(gridMemberDTO.getGridMemberId())){ + return R.fail("昵称已使用"); + } + + BeanUtils.copyProperties(gridMemberDTO,sysUserDO); + + int insert = 0; + try { + insert = userDao.updateById(sysUserDO); + + //清除原本关联网格员信息 + this.userDao.delLcMember(sysUserDO.getUserId()); + //关联市平台网格员 + if(gridMemberDTO.getLcMemberId() != null){ + //关联现有的网格员信息 + this.userDao.addLcMember(gridMemberDTO.getLcMemberId(),sysUserDO.getUserId(),sysUserDO.getNickName()); + } + //清除原网格员与楼栋关联关系 + this.userDao.delGridMemberRelation(sysUserDO.getUserId()); + + //新增网格员关联楼栋 + if(gridMemberDTO.getBuildingIds() != null && !gridMemberDTO.getBuildingIds().isEmpty()){ + List<EventGridMemberBuildingRelationDO> buildingRelationList = new ArrayList<>(); + gridMemberDTO.getBuildingIds().forEach(buildingId -> { + Map<String,Long> resultMap = this.userDao.getBuilding(buildingId); + if(resultMap != null){ + EventGridMemberBuildingRelationDO buildingRelationDO = new EventGridMemberBuildingRelationDO(); + buildingRelationDO.setBuildingId(buildingId); + buildingRelationDO.setGridMemberId(sysUserDO.getUserId()); + buildingRelationDO.setVillageId(Long.parseLong(resultMap.get("village_id").toString())); + buildingRelationDO.setCommunityId(Long.parseLong(resultMap.get("act_id").toString())); + buildingRelationDO.setCreateAt(new Date()); + buildingRelationList.add(buildingRelationDO); + } + }); + if(!buildingRelationList.isEmpty()){ + buildingRelationService.saveBatch(buildingRelationList); + } + } + + } catch (Exception e) { + e.printStackTrace(); + log.error("修改网格员用户报错【{}】", e.getMessage()); + if (e.getMessage().contains("union_phone_type")) { + return R.fail("手机号已经存在"); + } else if (e.getMessage().contains("union_account_type")) { + return R.fail("账户已经存在"); + } + } + if(insert > 0){ + return R.ok(); + } + return R.fail("修改失败"); + } + + /** + * 重置网格员密码 + * @param gridMemberDTO 请求参数 + * @return 重置结果 + */ + @Override + public R passResetUser(EventGridMemberPassResetDTO gridMemberDTO){ + if(gridMemberDTO.getIds().isEmpty() || StringUtils.isEmpty(gridMemberDTO.getPassword())){ + return R.fail("参数错误"); + } + String encode = new BCryptPasswordEncoder().encode(gridMemberDTO.getPassword()); + gridMemberDTO.setPassword(encode); + userDao.passResetUser(gridMemberDTO); + return R.ok(); + } + + /** + * 批量删除网格员 + * @param Ids 网格员id集合 + * @return 删除结果 + */ + @Override + public R deleteMembers(List<Long> Ids){ + if(Ids.isEmpty()){ + return R.fail("参数有误"); + } + if(userDao.deleteBatchIds(Ids) > 0){ + return R.ok(); + } + return R.fail("删除失败"); + } + + @Override + public R gridMemberEditStatus(EventGridMemberEditStatusDTO gridMemberEditDTO){ + if(gridMemberEditDTO.getIds().isEmpty()){ + return R.fail("参数有误"); + } + userDao.gridMemberEditStatus(gridMemberEditDTO); + return R.ok(); + } + + @Override + public R noTips(Long userId){ + SysUserDO userDO = this.userDao.selectById(userId); + if(userDO != null){ + userDO.setBigAgeTips(2); + if(this.userDao.updateById(userDO) > 0){ + return R.ok(); + } + } + return R.fail(); + } + + /** + * 查询社区的收益说明 + * @param communityId 社区id + * @return 收益说明 + */ + @Override + public R listAgreements(Long communityId){ + + List<SysUserAgreementDO> sysUserAgreementDOS = sysUserAgreementDAO.selectList(new LambdaQueryWrapper<SysUserAgreementDO>() + .eq(SysUserAgreementDO::getCommunityId,communityId).eq(SysUserAgreementDO::getType,5)); + if (sysUserAgreementDOS.isEmpty()) { + SysUserAgreementDO agreementDO = new SysUserAgreementDO(); + agreementDO.setCommunityId(communityId); + agreementDO.setName("收益说明"); + agreementDO.setType(5); + agreementDO.setCreateAt(new Date()); + agreementDO.setContent(Constants.PROFIT_EXPLAIN); + sysUserAgreementDAO.insert(agreementDO); + sysUserAgreementDOS.add(agreementDO); + } + List<SysUserAgreementVO> sysUserAgreementVOS = new ArrayList<>(); + sysUserAgreementDOS.forEach(sysUserAgreementDO -> { + SysUserAgreementVO sysUserAgreementVO = new SysUserAgreementVO(); + BeanUtils.copyProperties(sysUserAgreementDO, sysUserAgreementVO); + sysUserAgreementVOS.add(sysUserAgreementVO); + }); + return R.ok(sysUserAgreementVOS); + } + + @Override + public R getGridIsOk(Long userId){ + Integer count = this.userDao.getGridIsOk(userId); + if(count > 0){ + return R.ok(count); + }else{ + return R.fail(); + } + } } -- Gitblit v1.7.1