package com.moral.api.service.impl;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.moral.api.entity.ManageAccount;
import com.moral.api.entity.ManageMenu;
import com.moral.api.entity.ManageRole;
import com.moral.api.mapper.ManageAccountMapper;
import com.moral.api.mapper.ManageMenuMapper;
import com.moral.api.mapper.ManageRoleMapper;
import com.moral.api.pojo.dto.AccountInfoDTO;
import com.moral.api.pojo.dto.LoginDTO;
import com.moral.api.service.ManageAccountService;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.moral.util.AESUtils;
import com.moral.util.MD5Utils;
import com.moral.util.TokenUtils;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Service;
import org.springframework.util.ObjectUtils;
import javax.annotation.Resource;
import java.util.*;
/**
*
* 后台账户表 服务实现类
*
*
* @author moral
* @since 2021-03-09
*/
@Service
public class ManageAccountServiceImpl extends ServiceImpl implements ManageAccountService {
@Value("${AES.KEY}")
private String AESKey;
@Resource
ManageAccountMapper accountMapper;
@Resource
ManageRoleMapper roleMapper;
@Resource
ManageMenuMapper manageMenuMapper;
/**
* @Description: 登陆
* @Param: [parameters]
* @return: java.util.Map
* @Author: 陈凯裕
* @Date: 2021/3/11
*/
@Override
public LoginDTO login(String AESAccount,String AESPassword) {
LoginDTO loginDTO = new LoginDTO();
//解密
String account = AESUtils.decrypt(AESAccount, AESKey);
String password = AESUtils.decrypt(AESPassword, AESKey);
//查询是否存在
QueryWrapper wrapper = new QueryWrapper<>();
wrapper.eq("account", account);
ManageAccount manageAccount = accountMapper.selectOne(wrapper);
if (ObjectUtils.isEmpty(manageAccount)) {
loginDTO.setCode(LoginDTO.NOT_EXIST);
return loginDTO;
}
//查询是否逻辑删除
if (manageAccount.getIsDelete().equals("1")) {
loginDTO.setCode(LoginDTO.IS_DELETE);
return loginDTO;
}
//校验密码
if (!MD5Utils.saltMD5Verify(password, manageAccount.getPassword())) {
loginDTO.setCode(LoginDTO.PASSWORD_ERROR);
return loginDTO;
}
//查询角色
List roles = roleMapper.getManageRoleByAccountId(manageAccount.getId());
if (ObjectUtils.isEmpty(roles)) {//判断账号是否存在角色
loginDTO.setCode(LoginDTO.ROLE_EMPTY);
return loginDTO;
}
//查询菜单
List menus = manageMenuMapper.getParentChildrenMenusByRoles(roles);
if (ObjectUtils.isEmpty(menus)) {//判断账号是否存在菜单
loginDTO.setCode(LoginDTO.MENU_EMPTY);
return loginDTO;
}
//封装用户信息
AccountInfoDTO accountInfoDTO = new AccountInfoDTO();
/*获取角色名称集合*/
ArrayList roleNames = new ArrayList<>();
roles.forEach(role->roleNames.add(role.getName()));
/*过滤menu无用属性*/
for (ManageMenu menu : menus) {
menu.setCreateTime(null);
menu.setIsDelete(null);
menu.setUpdateTime(null);
menu.setParentId(null);
List children = menu.getChildren();
for (ManageMenu child : children) {
child.setCreateTime(null);
child.setIsDelete(null);
child.setUpdateTime(null);
child.setParentId(null);
}
}
accountInfoDTO.setAccountId(String.valueOf(manageAccount.getId()));
accountInfoDTO.setAccountName(manageAccount.getUserName());
accountInfoDTO.setMenus(menus);
accountInfoDTO.setRoles(roleNames);
//获取token 并且存入缓存
String token = TokenUtils.getToken(String.valueOf(manageAccount.getId()), accountInfoDTO);
//封装返回结果
loginDTO.setCode(LoginDTO.SUCCESS);
loginDTO.setAccountInfo(accountInfoDTO);
loginDTO.setToken(token);
return loginDTO;
}
/**
* @Description: 注销
* @Param: [parameters]
* @return: java.util.Map
* @Author: 陈凯裕
* @Date: 2021/3/11
*/
@Override
public boolean logout(String accountId,String token) {
TokenUtils.destoryToken(accountId,token);
return true;
}
}