| package com.panzhihua.service_community.service.impl; | 
|   | 
| import com.alibaba.fastjson.JSON; | 
| import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; | 
| import com.baomidou.mybatisplus.core.metadata.IPage; | 
| import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | 
| import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; | 
| import com.google.common.base.Joiner; | 
| import com.google.common.collect.Lists; | 
| import com.panzhihua.common.exceptions.ServiceException; | 
| import com.panzhihua.common.model.dtos.community.ComMngPopulationDTO; | 
| import com.panzhihua.common.model.dtos.community.ComMngPopulationTagDTO; | 
| import com.panzhihua.common.model.helper.AESUtil; | 
| import com.panzhihua.common.model.dtos.community.PageComActDTO; | 
| import com.panzhihua.common.model.helper.AESUtil; | 
| import com.panzhihua.common.model.vos.R; | 
| import com.panzhihua.common.model.vos.community.*; | 
| import com.panzhihua.common.model.vos.user.ComHouseMemberVo; | 
| import com.panzhihua.service_community.dao.ComActDAO; | 
| import com.panzhihua.service_community.dao.ComActVillageDAO; | 
| import com.panzhihua.service_community.dao.ComMngPopulationDAO; | 
| import com.panzhihua.service_community.model.dos.ComActDO; | 
| import com.panzhihua.service_community.model.dos.ComMngPopulationDO; | 
| import com.panzhihua.service_community.model.dos.ComMngVillageDO; | 
| import com.panzhihua.service_community.service.ComMngPopulationService; | 
| import org.springframework.beans.BeanUtils; | 
| import org.springframework.beans.factory.annotation.Value; | 
| import org.springframework.beans.factory.annotation.Value; | 
| import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder; | 
| import org.springframework.stereotype.Service; | 
| import org.springframework.util.ObjectUtils; | 
|   | 
| import javax.annotation.Resource; | 
| import javax.crypto.BadPaddingException; | 
| import javax.crypto.IllegalBlockSizeException; | 
| import javax.crypto.NoSuchPaddingException; | 
| import java.io.UnsupportedEncodingException; | 
| import java.security.InvalidKeyException; | 
| import java.security.NoSuchAlgorithmException; | 
| import java.util.ArrayList; | 
| import java.util.List; | 
| import java.util.stream.Collectors; | 
|   | 
| /** | 
|  * 实有人口Service实现类 | 
|  */ | 
| @Service | 
| public class ComMngPopulationServiceImpl extends ServiceImpl<ComMngPopulationDAO, ComMngPopulationDO> implements ComMngPopulationService { | 
|     @Resource | 
|     private ComMngPopulationDAO populationDAO; | 
|     @Resource | 
|     private ComActDAO comActDAO; | 
|     @Resource | 
|     private ComActVillageDAO comActVillageDAO; | 
|     @Value("${domain.aesKey:}") | 
|     private String aesKey; | 
|   | 
|   | 
|     /** | 
|      * 新增实有人口 | 
|      * | 
|      * @param comMngPopulationVO 新增信息 | 
|      * @return 新增结果 | 
|      */ | 
|     @Override | 
|     public R addPopulation(ComMngPopulationVO comMngPopulationVO) { | 
|         ComMngPopulationDO comMngPopulationDO = new ComMngPopulationDO(); | 
|         Integer integer = populationDAO.selectCount(new QueryWrapper<ComMngPopulationDO>().lambda().eq(ComMngPopulationDO::getCardNo, comMngPopulationVO.getCardNo())); | 
|         if (integer > 0) { | 
|             return R.fail("实有人口已经存在"); | 
|         } | 
|         BeanUtils.copyProperties(comMngPopulationVO, comMngPopulationDO); | 
|   | 
|         int nub = populationDAO.insert(comMngPopulationDO); | 
|         if (nub < 1) { | 
|             return R.fail(); | 
|         } | 
|         return R.ok(nub); | 
|     } | 
|   | 
|   | 
|     /** | 
|      * 编辑实有人口 | 
|      * | 
|      * @param comMngPopulationVO 编辑内容 | 
|      * @return 编辑结果 | 
|      */ | 
|     @Override | 
|     public R putPopulation(ComMngPopulationVO comMngPopulationVO) { | 
|         ComMngPopulationDO comMngPopulationDO = populationDAO.selectById(comMngPopulationVO.getId()); | 
|         if (comMngPopulationDO == null) { | 
|             return R.fail("未查询到人口记录"); | 
|         } | 
|         BeanUtils.copyProperties(comMngPopulationVO, comMngPopulationDO); | 
|   | 
|         int nub = populationDAO.updateById(comMngPopulationDO); | 
|         if (nub < 1) { | 
|             return R.fail(); | 
|         } | 
|         return R.ok(); | 
|     } | 
|   | 
|     /** | 
|      * 查询实有人口 | 
|      * | 
|      * @param comMngPopulationVO 查询条件 | 
|      * @return 实有人口集合 | 
|      */ | 
|     @Override | 
|     public R listPopulation(ComMngPopulationDTO comMngPopulationVO) { | 
|         List<ComMngPopulationVO> populationVOS = populationDAO.listPopulation(comMngPopulationVO); | 
|         return R.ok(populationVOS); | 
|     } | 
|   | 
|     /** | 
|      * 实有人口详情 | 
|      * | 
|      * @param populationId 实有人口id | 
|      * @return 实有人口详情 | 
|      */ | 
|     @Override | 
|     public R detailPopulation(Long populationId) { | 
|         ComMngPopulationDO comMngPopulationDO = populationDAO.selectById(populationId); | 
|         if (ObjectUtils.isEmpty(comMngPopulationDO)) { | 
|             return R.fail(); | 
|         } | 
|         ComMngPopulationVO comMngPopulationVO = new ComMngPopulationVO(); | 
|         BeanUtils.copyProperties(comMngPopulationDO, comMngPopulationVO); | 
|   | 
|         //查询房屋成员信息 | 
|         List<ComHouseMemberVo> comMngFamilyInfoVOS = populationDAO.listHouseMermberByUserId(comMngPopulationDO); | 
|         if (!comMngFamilyInfoVOS.isEmpty()) { | 
|             comMngPopulationVO.setComMngFamilyInfoVOS(comMngFamilyInfoVOS); | 
|         } | 
|         return R.ok(comMngPopulationVO); | 
|     } | 
|   | 
|     /** | 
|      * 分页查询社区 | 
|      * | 
|      * @param comMngPopulationVO 查询参数 | 
|      * @return 分页集合 | 
|      */ | 
|     @Override | 
|     public R pagePopulation(ComMngPopulationDTO comMngPopulationVO) { | 
|         Page page = new Page<>(); | 
|         Long pageNum = comMngPopulationVO.getPageNum(); | 
|         Long pageSize = comMngPopulationVO.getPageSize(); | 
|         if (null == pageNum || 0 == pageNum) { | 
|             pageNum = 1l; | 
|         } | 
|         if (null == pageSize || 0 == pageSize) { | 
|             pageSize = 10l; | 
|         } | 
|         page.setSize(pageSize); | 
|         page.setCurrent(pageNum); | 
|         IPage<ComMngPopulationVO> iPage = populationDAO.pagePopulation(page, comMngPopulationVO); | 
|         return R.ok(iPage); | 
|     } | 
|   | 
|     /** | 
|      * 删除实有人口 | 
|      * | 
|      * @param populationId 实有人口id | 
|      * @return 删除结果 | 
|      */ | 
|     @Override | 
|     public R deletePopulation(Long populationId) { | 
|         int delete = populationDAO.deleteById(populationId); | 
|         if (delete > 0) { | 
|             return R.ok(); | 
|         } | 
|         return R.fail(); | 
|     } | 
|   | 
|     /** | 
|      * 查询所有实有人口 | 
|      * | 
|      * @return 实有人口集合 按照创建顺序倒序排列 | 
|      */ | 
|     @Override | 
|     public R listPopulationAll() { | 
|         List<ComMngPopulationDO> populationDOS = populationDAO.selectList(new QueryWrapper<ComMngPopulationDO>().lambda().orderByDesc(ComMngPopulationDO::getCreateAt)); | 
|         List<ComMngPopulationVO> populationVOS = new ArrayList<>(); | 
|         if (!ObjectUtils.isEmpty(populationDOS)) { | 
|             populationDOS.forEach(comActDO -> { | 
|                 ComMngPopulationVO populationVO = new ComMngPopulationVO(); | 
|                 BeanUtils.copyProperties(comActDO, populationVO); | 
|                 populationVOS.add(populationVO); | 
|             }); | 
|         } | 
|         return R.ok(populationVOS); | 
|     } | 
|   | 
|     @Override | 
|     public R listSavePopulation(List<ComMngPopulationServeExcelVO> list, Long communityId) { | 
|         List<ComMngPopulationImportErrorVO> populationImportErrorVOList = new ArrayList<>(); | 
|         List<ComMngPopulationDO> comMngPopulationDOS = populationDAO.selectList(new QueryWrapper<ComMngPopulationDO>().lambda().eq(ComMngPopulationDO::getActId, communityId)); | 
|         //查询该社区所有(实有房屋)小区 | 
| //        List<ComMngVillageDO> villageDOList = comActVillageDAO.selectList(new QueryWrapper<ComMngVillageDO>().lambda().eq(ComMngVillageDO::getCommunityId, communityId)); | 
|         ComActDO comActDO = comActDAO.selectById(communityId); | 
|         ArrayList<ComMngPopulationDO> populationDOList = Lists.newArrayList(); | 
|         int index = 2; | 
|         for (ComMngPopulationServeExcelVO vo : list) { | 
|             //判断DB和exel数据重复判断 | 
|             boolean result = comMngPopulationDOS.stream().anyMatch(population -> population.getCardNo().equals(vo.getCardNo())); | 
|             if (result) { | 
|                 ComMngPopulationImportErrorVO importErrorVO = new ComMngPopulationImportErrorVO(); | 
|                 importErrorVO.setErrorMsg("导入实有人口已存在(" + vo.getCardNo() + ")"); | 
|                 importErrorVO.setErrorPosition("第" + index + "行,第2列"); | 
|                 populationImportErrorVOList.add(importErrorVO); | 
|                 index++; | 
|                 continue; | 
| //                return R.fail(501,"导入实有人口已存在(" + vo.getCardNo() + ")"); | 
|             } | 
|   | 
|             ComMngPopulationDO comMngPopulationDO = new ComMngPopulationDO(); | 
|             //查询街路巷是否存在 | 
|             ComMngVillageDO comMngVillageDO = comActVillageDAO.selectOne(new QueryWrapper<ComMngVillageDO>().eq("alley",vo.getRoad()).eq("house_num",vo.getDoorNo()).eq("community_id",communityId)); | 
| //            ComMngVillageDO comMngVillageDO = villageDOList.stream().filter(village -> village.getAlley().equals(vo.getRoad()) && village.getHouseNum().equals(Integer.valueOf(vo.getDoorNo()))).findFirst().orElse(null); | 
|             BeanUtils.copyProperties(vo, comMngPopulationDO); | 
|             if (comMngVillageDO == null) { | 
|                 ComMngPopulationImportErrorVO importErrorVO = new ComMngPopulationImportErrorVO(); | 
|                 importErrorVO.setErrorMsg("查无:" + vo.getRoad() + "小区/房租地址,请先新建地址"); | 
|                 importErrorVO.setErrorPosition("第" + index + "行,第7,8列"); | 
|                 populationImportErrorVOList.add(importErrorVO); | 
|                 index++; | 
|                 continue; | 
|             } | 
|             List<String> userTag = vo.getUserTagStr().stream().map(userTagStr -> userTagStr.split("\\(")[0]).collect(Collectors.toList()); | 
|             comMngPopulationDO.setVillageId(comMngVillageDO.getVillageId()); | 
|             comMngPopulationDO.setActId(comActDO.getCommunityId()); | 
|             comMngPopulationDO.setStreetId(comActDO.getStreetId()); | 
|             comMngPopulationDO.setLabel(Joiner.on(",").join(userTag)); | 
|             comMngPopulationDO.setVillageName(comMngVillageDO.getGroupAt()); | 
|             populationDOList.add(comMngPopulationDO); | 
|             index++; | 
|         } | 
|         //如果有错误,返回错误 | 
|         if(!populationImportErrorVOList.isEmpty()){ | 
|             return R.fail(JSON.toJSONString(populationImportErrorVOList)); | 
|         } | 
|   | 
|         this.saveBatch(populationDOList); | 
|         return R.ok("共计导入实有人口数量:" + populationDOList.size()); | 
|     } | 
|   | 
|     /** | 
|      * 确认导入实有人口(有则更新,无则新建) | 
|      * @param list  用户信息 | 
|      * @param communityId   社区id | 
|      * @return  导入结果 | 
|      */ | 
|     @Override | 
|     public R listSavePopulationConfirm(List<ComMngPopulationServeExcelVO> list, Long communityId) { | 
|         if (list.size() == 0) { | 
|             return R.fail("数据为空!"); | 
|         } | 
|         List<ComMngPopulationDO> comMngPopulationDOS = populationDAO.selectList(new QueryWrapper<ComMngPopulationDO>().lambda().eq(ComMngPopulationDO::getActId, communityId)); | 
|         //查询该社区所有(实有房屋)小区 | 
| //        List<ComMngVillageDO> villageDOList = comActVillageDAO.selectList(new QueryWrapper<ComMngVillageDO>().lambda().eq(ComMngVillageDO::getCommunityId, communityId)); | 
|         ComActDO comActDO = comActDAO.selectById(communityId); | 
|         ArrayList<ComMngPopulationDO> populationDOList = Lists.newArrayList(); | 
|         list.forEach(vo -> { | 
|             ComMngPopulationDO comMngPopulationDO = new ComMngPopulationDO(); | 
|             //查询街路巷是否存在 | 
|             ComMngVillageDO comMngVillageDO = comActVillageDAO.selectOne(new QueryWrapper<ComMngVillageDO>().eq("alley",vo.getRoad()).eq("house_num",vo.getDoorNo()).eq("community_id",communityId)); | 
| //            ComMngVillageDO comMngVillageDO = villageDOList.stream().filter(village -> village.getAlley().equals(vo.getRoad()) && village.getHouseNum().equals(Integer.valueOf(vo.getDoorNo()))).findFirst().orElse(null); | 
|             BeanUtils.copyProperties(vo, comMngPopulationDO); | 
|             if (comMngVillageDO == null) { | 
|                 throw new ServiceException("街道巷:" + vo.getRoad() + "不存在!"); | 
|             } | 
|             comMngPopulationDO.setVillageId(comMngVillageDO.getVillageId()); | 
|             comMngPopulationDO.setActId(comActDO.getCommunityId()); | 
|             comMngPopulationDO.setStreetId(comActDO.getStreetId()); | 
|             List<String> userTag = vo.getUserTagStr().stream().map(userTagStr -> userTagStr.split("\\(")[0]).collect(Collectors.toList()); | 
|             comMngPopulationDO.setLabel(Joiner.on(",").join(userTag)); | 
|             comMngPopulationDO.setVillageName(comMngVillageDO.getGroupAt()); | 
|             populationDOList.add(comMngPopulationDO); | 
|         }); | 
|   | 
|         if(!populationDOList.isEmpty()){ | 
|             //循环遍历待导入人员信息,如果数据库存在则更新,如果不存在则新建 | 
|             populationDOList.forEach(population -> { | 
|                 try { | 
|                     //加密身份证号码 | 
|                     String cardNo = AESUtil.encrypt128(population.getCardNo(), aesKey); | 
|                     population.setCardNo(cardNo); | 
|                     //查询这个用户是否存在 | 
|                     ComMngPopulationDO comMngPopulationDO = this.populationDAO.selectOne(new QueryWrapper<ComMngPopulationDO>().lambda() | 
|                             .eq(ComMngPopulationDO::getCardNo, population.getCardNo())); | 
|                     if(comMngPopulationDO != null){ | 
|                         population.setId(comMngPopulationDO.getId()); | 
|                         BeanUtils.copyProperties(population,comMngPopulationDO); | 
|                         this.populationDAO.updateById(population); | 
|                     }else{ | 
|                         this.populationDAO.insert(population); | 
|                     } | 
|                 }catch (Exception e){ | 
|                     log.error("导入实有人口失败"); | 
|                 } | 
|             }); | 
|         } | 
|         return R.ok("共计导入实有人口数量:" + populationDOList.size()); | 
|     } | 
|   | 
|     public boolean isNumeric(String str) { | 
|         for (int i = 0; i < str.length(); i++) { | 
|             System.out.println(str.charAt(i)); | 
|             if (!Character.isDigit(str.charAt(i))) { | 
|                 return false; | 
|             } | 
|         } | 
|         return true; | 
|     } | 
|   | 
|     /** | 
|      * 根据id修改实有人口标签 | 
|      * @param populationTagDTO 请求参数 | 
|      * @return 修改结果 | 
|      */ | 
|     @Override | 
|     public R editTagPopulation(ComMngPopulationTagDTO populationTagDTO) { | 
|         ComMngPopulationDO comMngPopulationDO = populationDAO.selectById(populationTagDTO.getId()); | 
|         if (comMngPopulationDO == null) { | 
|             return R.fail("未查询到人口记录"); | 
|         } | 
|         BeanUtils.copyProperties(populationTagDTO,comMngPopulationDO); | 
|   | 
|         int nub = populationDAO.updateById(comMngPopulationDO); | 
|         if(nub < 1){ | 
|             return R.fail(); | 
|         } | 
|         return R.ok(); | 
|     } | 
|   | 
|     /** | 
|      * 批量删除实有人口 | 
|      * @param Ids | 
|      * @return | 
|      */ | 
|     @Override | 
|     public R deletePopulations(List<Long> Ids) { | 
|         int delete = populationDAO.deleteBatchIds(Ids); | 
|         if (delete > 0) { | 
|             return R.ok(); | 
|         } | 
|         return R.fail(); | 
|     } | 
|   | 
|     /** | 
|      * 根据社区id查询所有实有人口 | 
|      * @param communityId   社区id | 
|      * @return  查询结果 | 
|      */ | 
|     @Override | 
|     public R getPopulationListByCommunityId(Long communityId) { | 
|         List<ComMngPopulationDO> list = populationDAO.selectList(new QueryWrapper<ComMngPopulationDO>().eq("act_id",communityId)); | 
|         List<ComMngPopulationVO> resultList = new ArrayList<>(); | 
|         if(list.size() > 0){ | 
|             list.forEach(populationDO -> { | 
|                 ComMngPopulationVO populationVO=new ComMngPopulationVO(); | 
|                 BeanUtils.copyProperties(populationDO,populationVO); | 
|                 resultList.add(populationVO); | 
|             }); | 
|         } | 
|         return R.ok(resultList); | 
|     } | 
|   | 
|     /** | 
|      * 根据id集合查询实有人口 | 
|      * @param Ids   实有人口id集合 | 
|      * @return  查询结果 | 
|      */ | 
|     @Override | 
|     public R getPopulationLists(List<Long> Ids) { | 
|         List<ComMngPopulationDO> list = populationDAO.selectBatchIds(Ids); | 
|         List<ComMngPopulationVO> resultList = new ArrayList<>(); | 
|         if(list.size() > 0){ | 
|             list.forEach(populationDO -> { | 
|                 ComMngPopulationVO populationVO = new ComMngPopulationVO(); | 
|                 BeanUtils.copyProperties(populationDO,populationVO); | 
|                 resultList.add(populationVO); | 
|             }); | 
|         } | 
|         return R.ok(resultList); | 
|     } | 
|   | 
|     @Override | 
|     public R editPopulation(EditComMngPopulationVO vo, Long communityId) { | 
|         ComActDO comActDO = comActDAO.selectById(communityId); | 
|         ComMngPopulationDO populationDO = populationDAO.selectById(vo.getId()); | 
|         if(populationDO==null){ | 
|             return R.fail(); | 
|         } | 
|         BeanUtils.copyProperties(vo,populationDO); | 
|         try { | 
|             //TODO 修改拦截器时候需要维护加密操作 | 
|              populationDO.setCardNo(AESUtil.encrypt128(populationDO.getCardNo(), aesKey)); | 
|              populationDO.setPhone(AESUtil.encrypt128(populationDO.getPhone(), aesKey)); | 
|   | 
|         } catch (NoSuchPaddingException e) { | 
|             e.printStackTrace(); | 
|         } catch (NoSuchAlgorithmException e) { | 
|             e.printStackTrace(); | 
|         } catch (InvalidKeyException e) { | 
|             e.printStackTrace(); | 
|         } catch (UnsupportedEncodingException e) { | 
|             e.printStackTrace(); | 
|         } catch (BadPaddingException e) { | 
|             e.printStackTrace(); | 
|         } catch (IllegalBlockSizeException e) { | 
|             e.printStackTrace(); | 
|         } | 
|   | 
|         ComMngVillageDO comMngVillageDO = comActVillageDAO.selectOne(new QueryWrapper<ComMngVillageDO>().eq("alley",vo.getRoad()).eq("house_num",vo.getDoorNo()).eq("community_id",communityId)); | 
|         if (comMngVillageDO == null) { | 
|             throw new ServiceException("街道巷:" + vo.getRoad() + "不存在!"); | 
|         } | 
|         populationDO.setVillageId(comMngVillageDO.getVillageId()); | 
|         populationDO.setActId(comActDO.getCommunityId()); | 
|         populationDO.setStreetId(comActDO.getStreetId()); | 
|         populationDO.setVillageName(comMngVillageDO.getGroupAt()); | 
|         this.updateById(populationDO); | 
|         return R.ok(); | 
|     } | 
| } |