From db7bf1e9d1da402f22f26164237edcfad5d5c7d2 Mon Sep 17 00:00:00 2001
From: houruijun <411269194@kidgrow.com>
Date: Thu, 13 Aug 2020 21:37:27 +0800
Subject: [PATCH] 修改优化登录后获取用户基本信息接口,解决获取医生信息冗余查询的问题

---
 kidgrow-business/kidgrow-usercenter/kidgrow-usercenter-biz/src/main/java/com/kidgrow/usercenter/service/impl/SysUserServiceImpl.java |  111 +++++++++----------------------------------------------
 1 files changed, 19 insertions(+), 92 deletions(-)

diff --git a/kidgrow-business/kidgrow-usercenter/kidgrow-usercenter-biz/src/main/java/com/kidgrow/usercenter/service/impl/SysUserServiceImpl.java b/kidgrow-business/kidgrow-usercenter/kidgrow-usercenter-biz/src/main/java/com/kidgrow/usercenter/service/impl/SysUserServiceImpl.java
index 356648a..cffd3c6 100644
--- a/kidgrow-business/kidgrow-usercenter/kidgrow-usercenter-biz/src/main/java/com/kidgrow/usercenter/service/impl/SysUserServiceImpl.java
+++ b/kidgrow-business/kidgrow-usercenter/kidgrow-usercenter-biz/src/main/java/com/kidgrow/usercenter/service/impl/SysUserServiceImpl.java
@@ -111,25 +111,22 @@
     /**
      * 获取登录用户的一系列信息 hrj 06-04修改
      *
-     * @param sysUser
+     * @param sysUserNew
      * @return
      */
     @Override
-    public LoginAppUser getLoginAppUser(SysUser sysUser) {
+    public LoginAppUser getLoginAppUser(SysUser sysUserNew) {
         LoginAppUser loginAppUser = new LoginAppUser();
-        SysUser sysUserNew = this.baseMapper.selectById(sysUser);
+        SysUser sysUser = this.baseMapper.selectById(sysUserNew);
         if (sysUser != null) {
-            //返回的数据为什么要把密码也返回?清空!!
-            loginAppUser.setPassword("");
-            loginAppUser.setNewPassword("");
-            loginAppUser.setOldPassword("");
-
             BeanUtils.copyProperties(sysUser, loginAppUser);
             //获取用户所属组织机构列表
-            loginAppUser.setDefaultAuth(sysUserNew.getDefaultAuth());
+            loginAppUser.setDefaultAuth(sysUser.getDefaultAuth());
             List<SysOrganization> sysOrganizations = organizationService.findListByUserId(sysUser.getId());
             //设置组织机构集合
-            loginAppUser.setOrganizations(sysOrganizations);
+            if (sysOrganizations != null) {
+                loginAppUser.setOrganizations(sysOrganizations);
+            }
             List<SysRole> sysRoles = roleUserService.findRolesByUserId(sysUser.getId());
             // 设置角色
             loginAppUser.setRoles(sysRoles);
@@ -144,16 +141,17 @@
                     loginAppUser.setPermissions(permissions);
                 }
             }
-            //是否医院管理员
-            com.kidgrow.usercenter.model.SysDoctor sysDoctor = findDoctorByUserId(sysUser.getId());
-            if (sysDoctor.getIsAdminUser() != null) {
-                loginAppUser.setHAdminUser(sysDoctor.getIsAdminUser());
-            }
             //医院信息 只有H端要返回的信息
             if (sysUser.getTenantId().toLowerCase().equals(CommonConstant.H_TENANT.toLowerCase())) {
                 DoctorUserAll doctorUserAllVo = baseMapper.findDoctorUserAllData(sysUser.getId());
                 loginAppUser.setDoctorUserAllVO(doctorUserAllVo);
+                //是否医院管理员
+                loginAppUser.setHAdminUser(doctorUserAllVo.getIsAdminUser());
             }
+            //返回的数据为什么要把密码也返回?清空!!
+            loginAppUser.setPassword("");
+            loginAppUser.setNewPassword("");
+            loginAppUser.setOldPassword("");
         }
         return loginAppUser;
     }
@@ -724,11 +722,8 @@
             }
         }
 
-        //业务执行中途出错  手动撤回数据
+        //业务执行中途出错
         if (isReg && !isSuccess) {
-            RollBackData(userRegVo.getHospitalId(),
-                    userRegVo.getDepartmentId(), 0L, 0L,
-                    0L, 0L, 0L);
             return ResultBody.failed(expMsg);
         }
         if (!isReg && departmetAccountsCount(userRegVo.getDepartmentId()) < 1) {
@@ -737,7 +732,7 @@
         //添加用户数据  如果没有输入密码,将会创建一个默认密码返回
         String defaultPassWord = "";
         SysUser sysUser = new SysUser();
-        sysUser.setUsername(userRegVo.getUsername());
+        sysUser.setUsername(userRegVo.getMobile());
         sysUser.setMobile(userRegVo.getMobile());
         if (StringUtils.isBlank(userRegVo.getPassword())) {
             defaultPassWord = com.kidgrow.common.utils.RandomValueUtils.getRandom(6);
@@ -758,7 +753,7 @@
         sysUser.setDefaultAuth(false);
         sysUser.setOpenId(userRegVo.getOpenId());
         sysUser.setDel(false);
-        sysUser.setTenantId("hospital");
+        sysUser.setTenantId(CommonConstant.H_TENANT);
         boolean u = this.save(sysUser);
         SysRoleUser sysRoleUser = new SysRoleUser();
         if (u) {
@@ -880,55 +875,11 @@
         }
         /***返回数据***/
         if (!isSuccess) {
-            //撤回数据
-            RollBackData(0L,
-                    0L, sysUser.getId(), sysUserOrgH.getId(),
-                    sysUserOrgH.getId(), sysDictionaries.getId(),
-                    sysDoctor.getId());
             return ResultBody.failed(expMsg);
         } else {
             return ResultBody.ok().data(sysUser);
         }
     }
-
-    /**
-     * 手动撤回数据,需要撤回那个,给那个id传值,不需要的传0
-     *
-     * @param hospitalId
-     * @param departmentId
-     * @param userId
-     * @param userOrgIdH
-     * @param userOrgIdD
-     * @param dicId
-     * @param doctorId
-     */
-    private void RollBackData(Long hospitalId, Long departmentId,
-                              Long userId, Long userOrgIdH, Long userOrgIdD,
-                              Long dicId, Long doctorId) {
-        if (hospitalId > 0) {
-            hospitalService.removeById(hospitalId);
-        }
-        if (departmentId > 0) {
-            departmentService.removeById(departmentId);
-        }
-        if (userId > 0) {
-            baseMapper.deleteById(userId);
-            sysUserRoleMapper.deleteById(userId);
-        }
-        if (userOrgIdH > 0) {
-            sysUserRoleMapper.deleteById(userOrgIdH);
-        }
-        if (userOrgIdD > 0) {
-            sysUserRoleMapper.deleteById(userOrgIdD);
-        }
-        if (dicId > 0) {
-            sysDictionariesService.removeById(dicId);
-        }
-        if (doctorId > 0) {
-            sysDoctorMapper.deleteById(doctorId);
-        }
-    }
-
     /**
      * 获取医院科室下的所有H端有效的医生
      *
@@ -981,8 +932,9 @@
                 List<HospitalDoctorListVo> hospitalDoctorListVos = baseMapper.hospitalDoctorList(sysHospitalId, depatmentId, CommonConstant.HOSPITAL_DOCTOR_ID, CommonConstant.HOSPITAL_ADMIN_ID);
                 if (hospitalDoctorListVos != null) {
                     int doctorCount = hospitalDoctorListVos.size();
-                    int accountCount = sysDepartment.getAccountsCount();
-                    return (accountCount - doctorCount);
+                    int accountCount = sysDepartment.getAccountsCount().intValue();
+                    int liveCount=accountCount - doctorCount;
+                    return liveCount;
                 } else {
                     return 0;
                 }
@@ -1022,31 +974,6 @@
         }
         return hospitalId;
     }
-    /**
-     * 根据部门的id获取所属医院id
-     *
-     * @return
-     */
-//    public List<Long> DepartmentIdListByhospitalId(Long hospitalId) {
-//        List<Long> hospitalIdList =new ArrayList<Long>();
-//        SysHospital sysHospital = hospitalService.getById(hospitalId);
-//        if (sysHospital != null) {
-//            //先获取医院的组织数据
-//            SysOrganization sysOrganization = sysOrganizationMapper.selectById(sysHospital.getOrgId());
-//            if (sysOrganization != null) {
-//                    //根据组织id获取下级科室组织id
-//                    Map<String, Object> selectMap = new HashMap<>();
-//                    selectMap.put("org_parent_id", sysOrganization.getId());
-//                    List<SysOrganization> sysDepartmentList = sysOrganizationMapper.selectByMap(selectMap);
-//                    if (sysDepartmentList != null && sysDepartmentList.size() > 0) {
-//                        //hospitalIdList=sysDepartmentList.stream().sorted(Comparator.comparing(SysOrganization::getCreateTime).reversed()).map(SysOrganization::getId).collect(Collectors.toList());
-//                        sysDepartmentList.stream().sorted(Comparator.comparing(SysOrganization::getCreateTime).reversed()).map(SysOrganization::getId).collect(Collectors.toList()).get(0);
-//                    }
-//            }
-//        }
-//        return hospitalIdList;
-//    }
-
 
     /**
      * 检查用户登录名是否已经注册 true存在  false不存在

--
Gitblit v1.8.0