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 |  209 ++++++++++++++++++++++++++++++++++++++++++++--------
 1 files changed, 177 insertions(+), 32 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 33d734b..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,15 +11,14 @@
 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.EventGridMemberAddDTO;
-import com.panzhihua.common.model.dtos.grid.EventGridMemberEditStatusDTO;
-import com.panzhihua.common.model.dtos.grid.EventGridMemberPassResetDTO;
-import com.panzhihua.common.model.dtos.grid.PageEventGridMemberRelationDTO;
+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.*;
@@ -31,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;
@@ -84,6 +84,10 @@
     private SysMenuDAO sysMenuDAO;
     @Resource
     private SysUserInputDAO sysUserInputDAO;
+    @Resource
+    private EventGridMemberBuildingRelationService buildingRelationService;
+    @Resource
+    private EventGridMemberBuildingRelationMapper eventGridMemberBuildingRelationMapper;
 //    @Resource
 //    private GridService gridService;
 
@@ -240,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)) {
@@ -616,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);
@@ -951,14 +961,17 @@
 
 //        获取所有权限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 = sysRoleMenuDAO.selectOne(new QueryWrapper<SysRoleMenuDO>().lambda().eq(SysRoleMenuDO::getMenuId,menuIds.get(i))
-                    .eq(SysRoleMenuDO::getRoleId,roleId));
-            if(sysRoleMenuDO == null){
-                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();
@@ -1111,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();
         }
@@ -1150,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();
         }
@@ -1657,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("用户不存在");
         }
@@ -1907,7 +1921,13 @@
         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);
@@ -1915,13 +1935,38 @@
             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")) {
-                throw new ServiceException("手机号已经存在");
+                return R.fail("手机号已经存在");
             } else if (e.getMessage().contains("union_account_type")) {
-                throw new ServiceException("账户已经存在");
+                return R.fail("账户已经存在");
             }
         }
         if(insert > 0){
@@ -1938,7 +1983,26 @@
      */
     @Override
     public R getGridMemberList(PageEventGridMemberRelationDTO memberRelationDTO){
-        return R.ok(userDao.getGridMemberList(new Page(memberRelationDTO.getPageNum(),memberRelationDTO.getPageSize()),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);
     }
 
     /**
@@ -1947,7 +2011,8 @@
      * @return  修改结果
      */
     @Override
-    public R editGridUser(EventGridMemberAddDTO gridMemberDTO){
+    @Transactional(rollbackFor = Exception.class)
+    public R editGridUser(EventGridMemberEditAdminDTO gridMemberDTO){
 
         if(gridMemberDTO.getGridMemberId() == null){
             return R.fail("参数错误");
@@ -1965,20 +2030,49 @@
             return R.fail("昵称已使用");
         }
 
-        String encode = new BCryptPasswordEncoder().encode(gridMemberDTO.getPassword());
-        gridMemberDTO.setPassword(encode);
         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")) {
-                throw new ServiceException("手机号已经存在");
+                return R.fail("手机号已经存在");
             } else if (e.getMessage().contains("union_account_type")) {
-                throw new ServiceException("账户已经存在");
+                return R.fail("账户已经存在");
             }
         }
         if(insert > 0){
@@ -2027,4 +2121,55 @@
         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