| | |
| | | package com.kidgrow.usercenter.service.impl; |
| | | |
| | | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; |
| | | import com.kidgrow.common.constant.CommonConstant; |
| | | import com.kidgrow.common.constant.SecurityConstants; |
| | | import com.kidgrow.common.model.ResultBody; |
| | | import com.kidgrow.common.model.SysUser; |
| | | import com.kidgrow.common.model.*; |
| | | import com.kidgrow.common.service.impl.SuperServiceImpl; |
| | | import com.kidgrow.common.utils.StringUtils; |
| | | import com.kidgrow.redis.util.RedisConstant; |
| | | import com.kidgrow.redis.util.RedisUtils; |
| | | import com.kidgrow.usercenter.mapper.SysDoctorMapper; |
| | | import com.kidgrow.usercenter.mapper.SysRoleMapper; |
| | | import com.kidgrow.usercenter.mapper.SysUserRoleMapper; |
| | | import com.kidgrow.usercenter.model.SysDoctor; |
| | | import com.kidgrow.usercenter.model.SysRoleUser; |
| | | import com.kidgrow.usercenter.service.ISysDoctorService; |
| | | import com.kidgrow.usercenter.service.ISysUserOrgService; |
| | | import com.kidgrow.usercenter.service.ISysUserService; |
| | | import com.kidgrow.usercenter.vo.SysDoctorDto; |
| | | import com.kidgrow.usercenter.vo.SysDoctorVo; |
| | | import lombok.extern.slf4j.Slf4j; |
| | | import org.apache.commons.collections4.MapUtils; |
| | | import org.springframework.beans.factory.annotation.Autowired; |
| | | import org.springframework.cglib.beans.BeanCopier; |
| | | import org.springframework.security.crypto.password.PasswordEncoder; |
| | | import org.springframework.stereotype.Service; |
| | | import com.kidgrow.common.model.PageResult; |
| | | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; |
| | | import com.kidgrow.common.service.impl.SuperServiceImpl; |
| | | |
| | | import java.util.ArrayList; |
| | | import java.util.Date; |
| | | import java.util.List; |
| | | import java.util.Map; |
| | | |
| | | import org.apache.commons.collections4.MapUtils; |
| | | import lombok.extern.slf4j.Slf4j; |
| | | |
| | | import com.kidgrow.usercenter.model.SysDoctor; |
| | | import com.kidgrow.usercenter.mapper.SysDoctorMapper; |
| | | import com.kidgrow.usercenter.service.ISysDoctorService; |
| | | import org.springframework.transaction.annotation.Transactional; |
| | | |
| | | import javax.servlet.http.HttpServletRequest; |
| | | import java.util.*; |
| | | |
| | | /** |
| | | * 石家庄喜高科技有限责任公司 版权所有 © Copyright 2020<br> |
| | |
| | | private ISysUserService iSysUserService; |
| | | @Autowired |
| | | private PasswordEncoder passwordEncoder; |
| | | @Autowired |
| | | private ISysUserOrgService sysUserOrgService; |
| | | @Autowired |
| | | private RedisUtils redisUtils; |
| | | @Autowired |
| | | private SysRoleOrganizationServiceImpl SysRoleOrganizationServiceImpl; |
| | | @Autowired |
| | | private SysRoleMapper sysRoleMapper; |
| | | @Autowired |
| | | private SysUserRoleMapper sysUserRoleMapper; |
| | | |
| | | private final String HOSPITAL_ADMIN="hospital_admin"; |
| | | |
| | | @Override |
| | | public PageResult<SysDoctorVo> findList(Map<String, Object> params) { |
| | | public PageResult<SysDoctorVo> findList(Map<String, Object> params, SysUser user) { |
| | | Page<SysDoctor> page = new Page<>(MapUtils.getInteger(params, "page"), MapUtils.getInteger(params, "limit")); |
| | | //添加权限 |
| | | SysRoleOrganizationServiceImpl.getRoleOrg(params, user); |
| | | List<SysDoctor> list = baseMapper.findList(page, params); |
| | | List<SysDoctorVo> listvo = new ArrayList<>(); |
| | | list.forEach(e -> { |
| | |
| | | public ResultBody enable(Map<String, Object> params) { |
| | | Long aLong = MapUtils.getLong(params,"id"); |
| | | SysDoctor sysDoctor = baseMapper.selectById(aLong); |
| | | Boolean enabled = MapUtils.getBoolean(params, "enabled"); |
| | | if (sysDoctor != null && sysDoctor.getUserId() != null) { |
| | | SysUser byId = iSysUserService.getById(sysDoctor.getUserId()); |
| | | if(byId!=null){ |
| | | byId.setEnabled(true); |
| | | byId.setEnabled(enabled); |
| | | iSysUserService.updateById(byId); |
| | | } |
| | | } |
| | | if(sysDoctor!=null){ |
| | | sysDoctor.setEnabled(true); |
| | | |
| | | sysDoctor.setEnabled(enabled); |
| | | baseMapper.updateById(sysDoctor); |
| | | }else { |
| | | return ResultBody.failed("禁用失败"); |
| | |
| | | |
| | | @Override |
| | | @Transactional |
| | | public boolean saveOrUpdateSer(SysDoctorDto sysDoctor, HttpServletRequest request) { |
| | | public boolean saveOrUpdateSer(SysDoctorDto sysDoctor, HttpServletRequest request,SysUser user) { |
| | | String id = request.getHeader(SecurityConstants.USER_ID_HEADER); |
| | | if(null==sysDoctor){ |
| | | return false; |
| | |
| | | sysUser.setNickname(sysDoctor.getHospitalName()); |
| | | sysUser.setHeadImgUrl(sysDoctor.getDoctorLogo()); |
| | | sysUser.setMobile(sysDoctor.getDoctorTel()); |
| | | sysUser.setType("doctor"); |
| | | sysUser.setTenantId("hospital"); |
| | | sysUser.setType(CommonConstant.H_DOCTOR); |
| | | sysUser.setTenantId(CommonConstant.H_TENANT); |
| | | sysUser.setCreateTime(new Date()); |
| | | SysUser byId = iSysUserService.getById(id); |
| | | if(byId!=null){ |
| | |
| | | sysUser.setCreateUserName(byId.getUsername()); |
| | | } |
| | | iSysUserService.save(sysUser); |
| | | //保存 角色信息 |
| | | Map<String,Object> map= new HashMap<>(); |
| | | map.put("code",HOSPITAL_ADMIN); |
| | | map.put("enabled",1); |
| | | map.put("is_del",0); |
| | | List<SysRole> sysRoles = sysRoleMapper.selectByMap(map); |
| | | if(sysRoles.size()>0){ |
| | | //保存一个角色 |
| | | SysRole sysRole = sysRoles.get(0); |
| | | SysRoleUser sysRoleUser=new SysRoleUser(); |
| | | sysRoleUser.setRoleId(sysRole.getId()); |
| | | sysRoleUser.setUserId(sysUser.getId()); |
| | | int insert = sysUserRoleMapper.insert(sysRoleUser); |
| | | } |
| | | //保存doctor的数据 |
| | | SysDoctor sysDoc=new SysDoctor(); |
| | | BeanCopier beanCopier = BeanCopier.create(SysDoctorDto.class, SysDoctor.class, false); |
| | | beanCopier.copy(sysDoctor,sysDoc,null); |
| | | sysDoc.setUserId(sysUser.getId()); |
| | | if(user.getOrganizations()!=null){ |
| | | List<SysOrganization> organizations = user.getOrganizations(); |
| | | sysDoc.setCreateUserOrgCode(organizations.get(organizations.size()-1).getOrgCode()); |
| | | } |
| | | |
| | | baseMapper.insert(sysDoc); |
| | | //保存将sys_user_org 保存部门 |
| | | SysUserOrg sysUserOrg=new SysUserOrg(); |
| | | sysUserOrg.setUserId(sysUser.getId()); |
| | | sysUserOrg.setOrgId(sysDoctor.getDepartmentId()); |
| | | //保存公司 |
| | | sysUserOrgService.saveOrUpdate(sysUserOrg); |
| | | SysUserOrg sysGongsi=new SysUserOrg(); |
| | | sysGongsi.setUserId(sysUser.getId()); |
| | | sysGongsi.setOrgId(sysDoctor.getHospitalId()); |
| | | sysUserOrgService.saveOrUpdate(sysGongsi); |
| | | //保存到Redis |
| | | boolean hset = redisUtils.hset(RedisConstant.USER_ORGANIZATION, sysUserOrg.getUserId().toString(), sysUserOrg); |
| | | }else { |
| | | //更新 |
| | | SysDoctor getOne = baseMapper.selectById(sysDoctor.getId()); |
| | | Map<String, Object> columnMap=new HashMap<>(); |
| | | columnMap.put("user_id",sysDoctor.getUserId()); |
| | | boolean b = sysUserOrgService.removeByMap(columnMap); |
| | | //保存将sys_user_org |
| | | SysUserOrg sysUserOrg=new SysUserOrg(); |
| | | sysUserOrg.setUserId(getOne.getUserId()); |
| | | sysUserOrg.setEnabled(false); |
| | | sysUserOrg.setOrgId(sysDoctor.getDepartmentId()); |
| | | sysUserOrg.setCreateTime(new Date()); |
| | | sysUserOrgService.saveOrUpdate(sysUserOrg); |
| | | SysUserOrg sysGongsi=new SysUserOrg(); |
| | | sysGongsi.setUserId(getOne.getId()); |
| | | sysGongsi.setOrgId(sysDoctor.getHospitalId()); |
| | | sysUserOrgService.saveOrUpdate(sysGongsi); |
| | | baseMapper.updateById(sysDoctor); |
| | | if(redisUtils.hHasKey(RedisConstant.USER_ORGANIZATION, getOne.getUserId().toString())){ |
| | | redisUtils.hdel(RedisConstant.USER_ORGANIZATION, getOne.getUserId().toString()); |
| | | } |
| | | redisUtils.hset(RedisConstant.USER_ORGANIZATION, getOne.getUserId().toString(), sysUserOrg); |
| | | } |
| | | } |
| | | return true; |
| | | } |
| | | |
| | | @Override |
| | | public List<SysDoctor> findByMap(Map<String, Object> map) { |
| | | map.put("enabled",1); |
| | | map.put("is_del",0); |
| | | return baseMapper.selectByMap(map); |
| | | } |
| | | |
| | | @Override |
| | | @Transactional |
| | | public ResultBody setAdminDoctor(Map<String, Object> params) { |
| | | Long id = MapUtils.getLong(params, "id"); |
| | | Long adminId = MapUtils.getLong(params, "adminId"); |
| | | if (id>0&&adminId>0) { |
| | | Map<String,Object> map= new HashMap<>(); |
| | | map.put("id",adminId); |
| | | SysDoctor sysDoctor=baseMapper.selectById(adminId); |
| | | //先检查操作用户是否管理员 |
| | | if(sysDoctor!=null){ |
| | | if (sysDoctor.getIsAdminUser()) { |
| | | //现将操作人员设为非管理 |
| | | sysDoctor=new SysDoctor(); |
| | | sysDoctor.setIsAdminUser(false); |
| | | if(baseMapper.updateById(sysDoctor)>0) |
| | | { |
| | | //再将新用户设为管理 |
| | | sysDoctor=baseMapper.selectById(id); |
| | | if (sysDoctor != null) { |
| | | if (!sysDoctor.getIsAdminUser()) { |
| | | sysDoctor=new SysDoctor(); |
| | | sysDoctor.setIsAdminUser(true); |
| | | if (baseMapper.updateById(sysDoctor)>0) { |
| | | return ResultBody.ok().data(true).msg("管理员设置成功!"); |
| | | } |
| | | else |
| | | { |
| | | return ResultBody.failed("设为管理失败!").data(false); |
| | | } |
| | | } |
| | | else |
| | | { |
| | | return ResultBody.failed("设为管理失败,改用户就是管理员!").data(false); |
| | | } |
| | | } |
| | | else |
| | | { |
| | | return ResultBody.failed("用户信息有误!").data(false); |
| | | } |
| | | } |
| | | else |
| | | { |
| | | return ResultBody.failed("设为管理失败!").data(false); |
| | | } |
| | | } |
| | | else |
| | | { |
| | | return ResultBody.failed("当前操作用户不是管理员!").data(false); |
| | | } |
| | | } |
| | | else |
| | | { |
| | | return ResultBody.failed("用户信息有误!").data(false); |
| | | } |
| | | |
| | | } |
| | | else |
| | | { |
| | | return ResultBody.failed("业务参数有误!").data(false); |
| | | } |
| | | } |
| | | |
| | | /** |
| | | * 判断用户名是否管理员 |
| | | * @param userName |
| | | * @return |
| | | */ |
| | | @Override |
| | | public ResultBody userIsAdmin(String userName) { |
| | | if (StringUtils.isNotBlank(userName)) { |
| | | SysDoctor sysDoctor= baseMapper.userIsAdmin(userName); |
| | | if (sysDoctor != null) { |
| | | return ResultBody.ok().data(sysDoctor.getIsAdminUser()); |
| | | } |
| | | else |
| | | { |
| | | return ResultBody.failed().data(false); |
| | | } |
| | | }else |
| | | { |
| | | return ResultBody.failed("用户名不能为空!").data(false); |
| | | } |
| | | } |
| | | } |