|
@@ -2,10 +2,16 @@ package com.diagbot.facade;
|
|
|
|
|
|
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
|
|
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
|
|
import com.diagbot.client.AuthServiceClient;
|
|
import com.diagbot.client.AuthServiceClient;
|
|
|
|
+import com.diagbot.dto.HospitalInfoDTO;
|
|
|
|
+import com.diagbot.dto.HospitalLoginDTO;
|
|
import com.diagbot.dto.JwtDTO;
|
|
import com.diagbot.dto.JwtDTO;
|
|
|
|
+import com.diagbot.dto.LoginDTO;
|
|
|
|
+import com.diagbot.dto.UserLoginDTO;
|
|
|
|
+import com.diagbot.entity.HospitalInfo;
|
|
import com.diagbot.entity.JWT;
|
|
import com.diagbot.entity.JWT;
|
|
import com.diagbot.entity.JwtStore;
|
|
import com.diagbot.entity.JwtStore;
|
|
import com.diagbot.entity.SysUser;
|
|
import com.diagbot.entity.SysUser;
|
|
|
|
+import com.diagbot.entity.wrapper.SysMenuWrapper;
|
|
import com.diagbot.enums.ConstantEnum;
|
|
import com.diagbot.enums.ConstantEnum;
|
|
import com.diagbot.enums.IsDeleteEnum;
|
|
import com.diagbot.enums.IsDeleteEnum;
|
|
import com.diagbot.enums.StatusEnum;
|
|
import com.diagbot.enums.StatusEnum;
|
|
@@ -13,7 +19,10 @@ import com.diagbot.exception.CommonErrorCode;
|
|
import com.diagbot.exception.CommonException;
|
|
import com.diagbot.exception.CommonException;
|
|
import com.diagbot.exception.ServiceErrorCode;
|
|
import com.diagbot.exception.ServiceErrorCode;
|
|
import com.diagbot.service.impl.SysUserServiceImpl;
|
|
import com.diagbot.service.impl.SysUserServiceImpl;
|
|
|
|
+import com.diagbot.util.BeanUtil;
|
|
import com.diagbot.util.DateUtil;
|
|
import com.diagbot.util.DateUtil;
|
|
|
|
+import com.diagbot.util.EntityUtil;
|
|
|
|
+import com.diagbot.util.ListUtil;
|
|
import com.diagbot.util.StringUtil;
|
|
import com.diagbot.util.StringUtil;
|
|
import com.diagbot.util.SysUserUtils;
|
|
import com.diagbot.util.SysUserUtils;
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
@@ -22,6 +31,10 @@ import org.springframework.security.crypto.password.PasswordEncoder;
|
|
import org.springframework.security.oauth2.common.OAuth2AccessToken;
|
|
import org.springframework.security.oauth2.common.OAuth2AccessToken;
|
|
import org.springframework.stereotype.Component;
|
|
import org.springframework.stereotype.Component;
|
|
|
|
|
|
|
|
+import java.util.ArrayList;
|
|
|
|
+import java.util.List;
|
|
|
|
+import java.util.Map;
|
|
|
|
+
|
|
/**
|
|
/**
|
|
* @Description: 用户业务层
|
|
* @Description: 用户业务层
|
|
* @author: gaodm
|
|
* @author: gaodm
|
|
@@ -36,6 +49,12 @@ public class SysUserFacade extends SysUserServiceImpl {
|
|
@Autowired
|
|
@Autowired
|
|
private AuthServiceClient authServiceClient;
|
|
private AuthServiceClient authServiceClient;
|
|
|
|
|
|
|
|
+ @Autowired
|
|
|
|
+ private SysMenuFacade sysMenuFacade;
|
|
|
|
+
|
|
|
|
+ @Autowired
|
|
|
|
+ private HospitalInfoFacade hospitalInfoFacade;
|
|
|
|
+
|
|
/**
|
|
/**
|
|
* 获取jwt
|
|
* 获取jwt
|
|
*
|
|
*
|
|
@@ -180,4 +199,71 @@ public class SysUserFacade extends SysUserServiceImpl {
|
|
return true;
|
|
return true;
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+ /**
|
|
|
|
+ * 登录
|
|
|
|
+ *
|
|
|
|
+ * @return 登录相关信息
|
|
|
|
+ */
|
|
|
|
+ public LoginDTO getUserOrgMenu() {
|
|
|
|
+ LoginDTO data = new LoginDTO();
|
|
|
|
+
|
|
|
|
+ Long userId = Long.parseLong(SysUserUtils.getCurrentPrincipleID());
|
|
|
|
+ SysUser user = this.getOne(new QueryWrapper<SysUser>()
|
|
|
|
+ .eq("is_deleted", IsDeleteEnum.N.getKey())
|
|
|
|
+ .eq("status", StatusEnum.Enable.getKey())
|
|
|
|
+ .eq("id", userId), false);
|
|
|
|
+ if (user == null) {
|
|
|
|
+ throw new CommonException(CommonErrorCode.SERVER_IS_ERROR,
|
|
|
|
+ "用户不存在【" + userId + "】");
|
|
|
|
+ }
|
|
|
|
+ //添加用户
|
|
|
|
+ UserLoginDTO userLoginDTO = new UserLoginDTO();
|
|
|
|
+ BeanUtil.copyProperties(user, userLoginDTO);
|
|
|
|
+ data.setUserLoginDTO(userLoginDTO);
|
|
|
|
+
|
|
|
|
+ //添加医院信息
|
|
|
|
+ if (user.getType().equals(ConstantEnum.OUTER_USER.getKey())) {
|
|
|
|
+ QueryWrapper<HospitalInfo> queryWrapper = new QueryWrapper<>();
|
|
|
|
+ queryWrapper.eq("is_deleted", IsDeleteEnum.N.getKey())
|
|
|
|
+ .eq("id", SysUserUtils.getCurrentHospitalID());
|
|
|
|
+ HospitalInfo hospitalInfo = hospitalInfoFacade.getOne(queryWrapper, false);
|
|
|
|
+ HospitalLoginDTO hospitalLoginDTO = new HospitalLoginDTO();
|
|
|
|
+ BeanUtil.copyProperties(hospitalInfo, hospitalLoginDTO);
|
|
|
|
+ data.setHospitalLoginDTO(hospitalLoginDTO);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ //添加菜单信息
|
|
|
|
+ List<SysMenuWrapper> menuList = sysMenuFacade.getByRole(user.getId());
|
|
|
|
+ Map<Long, List<SysMenuWrapper>> menuMap = EntityUtil.makeEntityListMap(menuList, "parentId");
|
|
|
|
+ List<SysMenuWrapper> menuRes = menuMap.get(-1L);
|
|
|
|
+ if (ListUtil.isNotEmpty(menuRes)){
|
|
|
|
+ for (SysMenuWrapper bean : menuRes) {
|
|
|
|
+ getSonMenu(bean, menuMap);
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ data.setMenuWrappers(menuRes);
|
|
|
|
+ return data;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+ /**
|
|
|
|
+ * 递归获取菜单结构
|
|
|
|
+ *
|
|
|
|
+ * @param menu 当前菜单
|
|
|
|
+ * @param menuMap 菜单集
|
|
|
|
+ * @return 菜单结构
|
|
|
|
+ */
|
|
|
|
+ public List<SysMenuWrapper> getSonMenu(SysMenuWrapper menu,
|
|
|
|
+ Map<Long, List<SysMenuWrapper>> menuMap) {
|
|
|
|
+ List<SysMenuWrapper> res = new ArrayList<>();
|
|
|
|
+ List<SysMenuWrapper> list = menuMap.get(menu.getId());
|
|
|
|
+ if (ListUtil.isNotEmpty(list)) {
|
|
|
|
+ menu.setSubMenuList(list);
|
|
|
|
+ for (SysMenuWrapper bean : list) {
|
|
|
|
+ getSonMenu(bean, menuMap);
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ return res;
|
|
|
|
+ }
|
|
|
|
+
|
|
}
|
|
}
|