|
@@ -19,12 +19,14 @@ package org.springblade.system.user.service.impl;
|
|
|
|
|
|
import com.baomidou.mybatisplus.core.conditions.Wrapper;
|
|
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
|
|
+import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
|
|
|
import com.baomidou.mybatisplus.core.metadata.IPage;
|
|
|
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
|
|
|
import lombok.AllArgsConstructor;
|
|
|
import org.springblade.common.constant.CommonConstant;
|
|
|
import org.springblade.common.constant.TenantConstant;
|
|
|
import org.springblade.core.log.exception.ServiceException;
|
|
|
+import org.springblade.core.mp.base.BaseEntity;
|
|
|
import org.springblade.core.mp.base.BaseServiceImpl;
|
|
|
import org.springblade.core.mp.support.Condition;
|
|
|
import org.springblade.core.mp.support.Query;
|
|
@@ -69,361 +71,383 @@ import static org.springblade.common.constant.CommonConstant.DEFAULT_PARAM_PASSW
|
|
|
@Service
|
|
|
@AllArgsConstructor
|
|
|
public class UserServiceImpl extends BaseServiceImpl<UserMapper, User> implements IUserService {
|
|
|
- private static final String GUEST_NAME = "guest";
|
|
|
-
|
|
|
- private final IUserDeptService userDeptService;
|
|
|
- private final IUserOauthService userOauthService;
|
|
|
- private final ISysClient sysClient;
|
|
|
- private final BladeTenantProperties tenantProperties;
|
|
|
-
|
|
|
- @Override
|
|
|
- @Transactional(rollbackFor = Exception.class)
|
|
|
- public boolean submit(User user) {
|
|
|
- if (StringUtil.isBlank(user.getTenantId())) {
|
|
|
- user.setTenantId(BladeConstant.ADMIN_TENANT_ID);
|
|
|
- }
|
|
|
- String tenantId = user.getTenantId();
|
|
|
- Tenant tenant = SysCache.getTenant(tenantId);
|
|
|
- if (Func.isNotEmpty(tenant)) {
|
|
|
- Integer accountNumber = tenant.getAccountNumber();
|
|
|
- if (tenantProperties.getLicense()) {
|
|
|
- String licenseKey = tenant.getLicenseKey();
|
|
|
- String decrypt = DesUtil.decryptFormHex(licenseKey, TenantConstant.DES_KEY);
|
|
|
- accountNumber = JsonUtil.parse(decrypt, Tenant.class).getAccountNumber();
|
|
|
- }
|
|
|
- Integer tenantCount = baseMapper.selectCount(Wrappers.<User>query().lambda().eq(User::getTenantId, tenantId));
|
|
|
- if (accountNumber != null && accountNumber > 0 && accountNumber <= tenantCount) {
|
|
|
- throw new ServiceException("当前租户已到最大账号额度!");
|
|
|
- }
|
|
|
- }
|
|
|
- if (Func.isNotEmpty(user.getPassword())) {
|
|
|
- user.setPassword(DigestUtil.encrypt(user.getPassword()));
|
|
|
- }
|
|
|
- Integer userCount = baseMapper.selectCount(Wrappers.<User>query().lambda().eq(User::getTenantId, tenantId).eq(User::getAccount, user.getAccount()));
|
|
|
- if (userCount > 0 && Func.isEmpty(user.getId())) {
|
|
|
- throw new ServiceException(StringUtil.format("当前用户 [{}] 已存在!", user.getAccount()));
|
|
|
- }
|
|
|
- return save(user) && submitUserDept(user);
|
|
|
- }
|
|
|
-
|
|
|
- @Override
|
|
|
- @Transactional(rollbackFor = Exception.class)
|
|
|
- public boolean updateUser(User user) {
|
|
|
- String tenantId = user.getTenantId();
|
|
|
- Integer userCount = baseMapper.selectCount(
|
|
|
- Wrappers.<User>query().lambda()
|
|
|
- .eq(User::getTenantId, tenantId)
|
|
|
- .eq(User::getAccount, user.getAccount())
|
|
|
- .notIn(User::getId, user.getId())
|
|
|
- );
|
|
|
- if (userCount > 0) {
|
|
|
- throw new ServiceException(StringUtil.format("当前用户 [{}] 已存在!", user.getAccount()));
|
|
|
- }
|
|
|
- return updateUserInfo(user) && submitUserDept(user);
|
|
|
- }
|
|
|
-
|
|
|
- @Override
|
|
|
- public boolean updateUserInfo(User user) {
|
|
|
- user.setPassword(null);
|
|
|
- return updateById(user);
|
|
|
- }
|
|
|
-
|
|
|
- private boolean submitUserDept(User user) {
|
|
|
- List<Long> deptIdList = Func.toLongList(user.getDeptId());
|
|
|
- List<UserDept> userDeptList = new ArrayList<>();
|
|
|
- deptIdList.forEach(deptId -> {
|
|
|
- UserDept userDept = new UserDept();
|
|
|
- userDept.setUserId(user.getId());
|
|
|
- userDept.setDeptId(deptId);
|
|
|
- userDeptList.add(userDept);
|
|
|
- });
|
|
|
- userDeptService.remove(Wrappers.<UserDept>update().lambda().eq(UserDept::getUserId, user.getId()));
|
|
|
- return userDeptService.saveBatch(userDeptList);
|
|
|
- }
|
|
|
-
|
|
|
- @Override
|
|
|
- public IPage<User> selectUserPage(IPage<User> page, User user, Long deptId, String tenantId) {
|
|
|
- List<Long> deptIdList = SysCache.getDeptChildIds(deptId);
|
|
|
- return page.setRecords(baseMapper.selectUserPage(page, user, deptIdList, tenantId));
|
|
|
- }
|
|
|
-
|
|
|
- @Override
|
|
|
- public IPage<UserVO> selectUserSearch(UserVO user, Query query) {
|
|
|
- LambdaQueryWrapper<User> queryWrapper = Wrappers.<User>query().lambda();
|
|
|
- if (StringUtil.isNotBlank(user.getName())) {
|
|
|
- queryWrapper.like(User::getName, user.getName());
|
|
|
- }
|
|
|
- if (StringUtil.isNotBlank(user.getDeptName())) {
|
|
|
- String deptIds = SysCache.getDeptIdsByFuzzy(AuthUtil.getTenantId(), user.getDeptName());
|
|
|
- if (StringUtil.isNotBlank(deptIds)) {
|
|
|
- queryWrapper.and(wrapper -> {
|
|
|
- List<String> ids = Func.toStrList(deptIds);
|
|
|
- ids.forEach(id -> wrapper.like(User::getDeptId, id).or());
|
|
|
- });
|
|
|
- }
|
|
|
- }
|
|
|
- if (StringUtil.isNotBlank(user.getPostName())) {
|
|
|
- String postIds = SysCache.getPostIdsByFuzzy(AuthUtil.getTenantId(), user.getPostName());
|
|
|
- if (StringUtil.isNotBlank(postIds)) {
|
|
|
- queryWrapper.and(wrapper -> {
|
|
|
- List<String> ids = Func.toStrList(postIds);
|
|
|
- ids.forEach(id -> wrapper.like(User::getPostId, id).or());
|
|
|
- });
|
|
|
- }
|
|
|
- }
|
|
|
- IPage<User> pages = this.page(Condition.getPage(query), queryWrapper);
|
|
|
- return UserWrapper.build().pageVO(pages);
|
|
|
- }
|
|
|
-
|
|
|
- @Override
|
|
|
- public User userByAccount(String tenantId, String account) {
|
|
|
- return baseMapper.selectOne(Wrappers.<User>query().lambda().eq(User::getTenantId, tenantId).eq(User::getAccount, account).eq(User::getIsDeleted, BladeConstant.DB_NOT_DELETED));
|
|
|
- }
|
|
|
-
|
|
|
- @Override
|
|
|
- public UserInfo userInfo(Long userId) {
|
|
|
- User user = baseMapper.selectById(userId);
|
|
|
- return buildUserInfo(user);
|
|
|
- }
|
|
|
-
|
|
|
- @Override
|
|
|
- public UserInfo userInfo(String tenantId, String account) {
|
|
|
- User user = baseMapper.getUser(tenantId, account);
|
|
|
- return buildUserInfo(user);
|
|
|
- }
|
|
|
-
|
|
|
- @Override
|
|
|
- public UserInfo userInfo(String tenantId, String account, UserEnum userEnum) {
|
|
|
- User user = baseMapper.getUser(tenantId, account);
|
|
|
- return buildUserInfo(user, userEnum);
|
|
|
- }
|
|
|
-
|
|
|
- private UserInfo buildUserInfo(User user) {
|
|
|
- return buildUserInfo(user, UserEnum.WEB);
|
|
|
- }
|
|
|
-
|
|
|
- private UserInfo buildUserInfo(User user, UserEnum userEnum) {
|
|
|
- if (ObjectUtil.isEmpty(user)) {
|
|
|
- return null;
|
|
|
- }
|
|
|
- UserInfo userInfo = new UserInfo();
|
|
|
- userInfo.setUser(user);
|
|
|
- if (Func.isNotEmpty(user)) {
|
|
|
- R<List<String>> result = sysClient.getRoleAliases(user.getRoleId());
|
|
|
- if (result.isSuccess()) {
|
|
|
- List<String> roleAlias = result.getData();
|
|
|
- userInfo.setRoles(roleAlias);
|
|
|
- }
|
|
|
- }
|
|
|
- // 根据每个用户平台,建立对应的detail表,通过查询将结果集写入到detail字段
|
|
|
- Kv detail = Kv.create().set("type", userEnum.getName());
|
|
|
- if (userEnum == UserEnum.WEB) {
|
|
|
- UserWeb userWeb = new UserWeb();
|
|
|
- UserWeb query = userWeb.selectOne(Wrappers.<UserWeb>lambdaQuery().eq(UserWeb::getUserId, user.getId()));
|
|
|
- if (ObjectUtil.isNotEmpty(query)) {
|
|
|
- detail.set("ext", query.getUserExt());
|
|
|
- }
|
|
|
- } else if (userEnum == UserEnum.APP) {
|
|
|
- UserApp userApp = new UserApp();
|
|
|
- UserApp query = userApp.selectOne(Wrappers.<UserApp>lambdaQuery().eq(UserApp::getUserId, user.getId()));
|
|
|
- if (ObjectUtil.isNotEmpty(query)) {
|
|
|
- detail.set("ext", query.getUserExt());
|
|
|
- }
|
|
|
- } else {
|
|
|
- UserOther userOther = new UserOther();
|
|
|
- UserOther query = userOther.selectOne(Wrappers.<UserOther>lambdaQuery().eq(UserOther::getUserId, user.getId()));
|
|
|
- if (ObjectUtil.isNotEmpty(query)) {
|
|
|
- detail.set("ext", query.getUserExt());
|
|
|
- }
|
|
|
- }
|
|
|
- userInfo.setDetail(detail);
|
|
|
- return userInfo;
|
|
|
- }
|
|
|
-
|
|
|
- @Override
|
|
|
- @Transactional(rollbackFor = Exception.class)
|
|
|
- public UserInfo userInfo(UserOauth userOauth) {
|
|
|
- UserOauth uo = userOauthService.getOne(Wrappers.<UserOauth>query().lambda().eq(UserOauth::getUuid, userOauth.getUuid()).eq(UserOauth::getSource, userOauth.getSource()));
|
|
|
- UserInfo userInfo;
|
|
|
- if (Func.isNotEmpty(uo) && Func.isNotEmpty(uo.getUserId())) {
|
|
|
- userInfo = this.userInfo(uo.getUserId());
|
|
|
- userInfo.setOauthId(Func.toStr(uo.getId()));
|
|
|
- } else {
|
|
|
- userInfo = new UserInfo();
|
|
|
- if (Func.isEmpty(uo)) {
|
|
|
- userOauthService.save(userOauth);
|
|
|
- userInfo.setOauthId(Func.toStr(userOauth.getId()));
|
|
|
- } else {
|
|
|
- userInfo.setOauthId(Func.toStr(uo.getId()));
|
|
|
- }
|
|
|
- User user = new User();
|
|
|
- user.setAccount(userOauth.getUsername());
|
|
|
- user.setTenantId(userOauth.getTenantId());
|
|
|
- userInfo.setUser(user);
|
|
|
- userInfo.setRoles(Collections.singletonList(GUEST_NAME));
|
|
|
- }
|
|
|
- return userInfo;
|
|
|
- }
|
|
|
-
|
|
|
- @Override
|
|
|
- public boolean grant(String userIds, String roleIds) {
|
|
|
- User user = new User();
|
|
|
- user.setRoleId(roleIds);
|
|
|
- return this.update(user, Wrappers.<User>update().lambda().in(User::getId, Func.toLongList(userIds)));
|
|
|
- }
|
|
|
-
|
|
|
- @Override
|
|
|
- public boolean resetPassword(String userIds) {
|
|
|
- User user = new User();
|
|
|
- user.setPassword(DigestUtil.encrypt(CommonConstant.DEFAULT_PASSWORD));
|
|
|
- user.setUpdateTime(DateUtil.now());
|
|
|
- return this.update(user, Wrappers.<User>update().lambda().in(User::getId, Func.toLongList(userIds)));
|
|
|
- }
|
|
|
-
|
|
|
- @Override
|
|
|
- public boolean updatePassword(Long userId, String oldPassword, String newPassword, String newPassword1) {
|
|
|
- User user = getById(userId);
|
|
|
- if (!newPassword.equals(newPassword1)) {
|
|
|
- throw new ServiceException("请输入正确的确认密码!");
|
|
|
- }
|
|
|
- if (!user.getPassword().equals(DigestUtil.hex(oldPassword))) {
|
|
|
- throw new ServiceException("原密码不正确!");
|
|
|
- }
|
|
|
- return this.update(Wrappers.<User>update().lambda().set(User::getPassword, DigestUtil.hex(newPassword)).eq(User::getId, userId));
|
|
|
- }
|
|
|
-
|
|
|
- @Override
|
|
|
- public boolean removeUser(String userIds) {
|
|
|
- if (Func.contains(Func.toLongArray(userIds), AuthUtil.getUserId())) {
|
|
|
- throw new ServiceException("不能删除本账号!");
|
|
|
- }
|
|
|
- return deleteLogic(Func.toLongList(userIds));
|
|
|
- }
|
|
|
-
|
|
|
- @Override
|
|
|
- @Transactional(rollbackFor = Exception.class)
|
|
|
- public void importUser(List<UserExcel> data, Boolean isCovered) {
|
|
|
- data.forEach(userExcel -> {
|
|
|
- User user = Objects.requireNonNull(BeanUtil.copy(userExcel, User.class));
|
|
|
- // 设置用户平台
|
|
|
- user.setUserType(Func.toInt(DictCache.getKey(DictEnum.USER_TYPE, userExcel.getUserTypeName()), 1));
|
|
|
- // 设置部门ID
|
|
|
- user.setDeptId(SysCache.getDeptIds(userExcel.getTenantId(), userExcel.getDeptName()));
|
|
|
- // 设置岗位ID
|
|
|
- user.setPostId(SysCache.getPostIds(userExcel.getTenantId(), userExcel.getPostName()));
|
|
|
- // 设置角色ID
|
|
|
- user.setRoleId(SysCache.getRoleIds(userExcel.getTenantId(), userExcel.getRoleName()));
|
|
|
- // 设置租户ID
|
|
|
- if (!AuthUtil.isAdministrator() || StringUtil.isBlank(user.getTenantId())) {
|
|
|
- user.setTenantId(AuthUtil.getTenantId());
|
|
|
- }
|
|
|
- // 覆盖数据
|
|
|
- if (isCovered) {
|
|
|
- // 查询用户是否存在
|
|
|
- User oldUser = UserCache.getUser(userExcel.getTenantId(), userExcel.getAccount());
|
|
|
- if (oldUser != null && oldUser.getId() != null) {
|
|
|
- user.setId(oldUser.getId());
|
|
|
- this.updateUser(user);
|
|
|
- return;
|
|
|
- }
|
|
|
- }
|
|
|
- // 获取默认密码配置
|
|
|
- String initPassword = ParamCache.getValue(DEFAULT_PARAM_PASSWORD);
|
|
|
- user.setPassword(initPassword);
|
|
|
- this.submit(user);
|
|
|
- });
|
|
|
- }
|
|
|
-
|
|
|
- @Override
|
|
|
- public List<UserExcel> exportUser(Wrapper<User> queryWrapper) {
|
|
|
- List<UserExcel> userList = baseMapper.exportUser(queryWrapper);
|
|
|
- userList.forEach(user -> {
|
|
|
- user.setUserTypeName(DictCache.getValue(DictEnum.USER_TYPE, user.getUserType()));
|
|
|
- user.setRoleName(StringUtil.join(SysCache.getRoleNames(user.getRoleId())));
|
|
|
- user.setDeptName(StringUtil.join(SysCache.getDeptNames(user.getDeptId())));
|
|
|
- user.setPostName(StringUtil.join(SysCache.getPostNames(user.getPostId())));
|
|
|
- });
|
|
|
- return userList;
|
|
|
- }
|
|
|
-
|
|
|
- @Override
|
|
|
- @Transactional(rollbackFor = Exception.class)
|
|
|
- public boolean registerGuest(User user, Long oauthId) {
|
|
|
- Tenant tenant = SysCache.getTenant(user.getTenantId());
|
|
|
- if (tenant == null || tenant.getId() == null) {
|
|
|
- throw new ServiceException("租户信息错误!");
|
|
|
- }
|
|
|
- UserOauth userOauth = userOauthService.getById(oauthId);
|
|
|
- if (userOauth == null || userOauth.getId() == null) {
|
|
|
- throw new ServiceException("第三方登陆信息错误!");
|
|
|
- }
|
|
|
- user.setRealName(user.getName());
|
|
|
- user.setAvatar(userOauth.getAvatar());
|
|
|
- user.setRoleId(StringPool.MINUS_ONE);
|
|
|
- user.setDeptId(StringPool.MINUS_ONE);
|
|
|
- user.setPostId(StringPool.MINUS_ONE);
|
|
|
- boolean userTemp = this.submit(user);
|
|
|
- userOauth.setUserId(user.getId());
|
|
|
- userOauth.setTenantId(user.getTenantId());
|
|
|
- boolean oauthTemp = userOauthService.updateById(userOauth);
|
|
|
- return (userTemp && oauthTemp);
|
|
|
- }
|
|
|
- @Override
|
|
|
- public boolean updatePlatform(Long userId, Integer userType, String userExt) {
|
|
|
- if (userType.equals(UserEnum.WEB.getCategory())) {
|
|
|
- UserWeb userWeb = new UserWeb();
|
|
|
- UserWeb query = userWeb.selectOne(Wrappers.<UserWeb>lambdaQuery().eq(UserWeb::getUserId, userId));
|
|
|
- if (ObjectUtil.isNotEmpty(query)) {
|
|
|
- userWeb.setId(query.getId());
|
|
|
- }
|
|
|
- userWeb.setUserId(userId);
|
|
|
- userWeb.setUserExt(userExt);
|
|
|
- return userWeb.insertOrUpdate();
|
|
|
- } else if (userType.equals(UserEnum.APP.getCategory())) {
|
|
|
- UserApp userApp = new UserApp();
|
|
|
- UserApp query = userApp.selectOne(Wrappers.<UserApp>lambdaQuery().eq(UserApp::getUserId, userId));
|
|
|
- if (ObjectUtil.isNotEmpty(query)) {
|
|
|
- userApp.setId(query.getId());
|
|
|
- }
|
|
|
- userApp.setUserId(userId);
|
|
|
- userApp.setUserExt(userExt);
|
|
|
- return userApp.insertOrUpdate();
|
|
|
- } else {
|
|
|
- UserOther userOther = new UserOther();
|
|
|
- UserOther query = userOther.selectOne(Wrappers.<UserOther>lambdaQuery().eq(UserOther::getUserId, userId));
|
|
|
- if (ObjectUtil.isNotEmpty(query)) {
|
|
|
- userOther.setId(query.getId());
|
|
|
- }
|
|
|
- userOther.setUserId(userId);
|
|
|
- userOther.setUserExt(userExt);
|
|
|
- return userOther.insertOrUpdate();
|
|
|
- }
|
|
|
- }
|
|
|
-
|
|
|
- @Override
|
|
|
- public UserVO platformDetail(User user) {
|
|
|
- User detail = baseMapper.selectOne(Condition.getQueryWrapper(user));
|
|
|
- UserVO userVO = UserWrapper.build().entityVO(detail);
|
|
|
- if (userVO.getUserType().equals(UserEnum.WEB.getCategory())) {
|
|
|
- UserWeb userWeb = new UserWeb();
|
|
|
- UserWeb query = userWeb.selectOne(Wrappers.<UserWeb>lambdaQuery().eq(UserWeb::getUserId, user.getId()));
|
|
|
- if (ObjectUtil.isNotEmpty(query)) {
|
|
|
- userVO.setUserExt(query.getUserExt());
|
|
|
- }
|
|
|
- } else if (userVO.getUserType().equals(UserEnum.APP.getCategory())) {
|
|
|
- UserApp userApp = new UserApp();
|
|
|
- UserApp query = userApp.selectOne(Wrappers.<UserApp>lambdaQuery().eq(UserApp::getUserId, user.getId()));
|
|
|
- if (ObjectUtil.isNotEmpty(query)) {
|
|
|
- userVO.setUserExt(query.getUserExt());
|
|
|
- }
|
|
|
- } else {
|
|
|
- UserOther userOther = new UserOther();
|
|
|
- UserOther query = userOther.selectOne(Wrappers.<UserOther>lambdaQuery().eq(UserOther::getUserId, user.getId()));
|
|
|
- if (ObjectUtil.isNotEmpty(query)) {
|
|
|
- userVO.setUserExt(query.getUserExt());
|
|
|
- }
|
|
|
- }
|
|
|
- return userVO;
|
|
|
- }
|
|
|
+ private static final String GUEST_NAME = "guest";
|
|
|
+
|
|
|
+ private final IUserDeptService userDeptService;
|
|
|
+ private final IUserOauthService userOauthService;
|
|
|
+ private final ISysClient sysClient;
|
|
|
+ private final BladeTenantProperties tenantProperties;
|
|
|
+
|
|
|
+ @Override
|
|
|
+ @Transactional(rollbackFor = Exception.class)
|
|
|
+ public boolean submit(User user) {
|
|
|
+ if (StringUtil.isBlank(user.getTenantId())) {
|
|
|
+ user.setTenantId(BladeConstant.ADMIN_TENANT_ID);
|
|
|
+ }
|
|
|
+ String tenantId = user.getTenantId();
|
|
|
+ Tenant tenant = SysCache.getTenant(tenantId);
|
|
|
+ if (Func.isNotEmpty(tenant)) {
|
|
|
+ Integer accountNumber = tenant.getAccountNumber();
|
|
|
+ if (tenantProperties.getLicense()) {
|
|
|
+ String licenseKey = tenant.getLicenseKey();
|
|
|
+ String decrypt = DesUtil.decryptFormHex(licenseKey, TenantConstant.DES_KEY);
|
|
|
+ accountNumber = JsonUtil.parse(decrypt, Tenant.class).getAccountNumber();
|
|
|
+ }
|
|
|
+ Integer tenantCount = baseMapper.selectCount(Wrappers.<User>query().lambda().eq(User::getTenantId, tenantId));
|
|
|
+ if (accountNumber != null && accountNumber > 0 && accountNumber <= tenantCount) {
|
|
|
+ throw new ServiceException("当前租户已到最大账号额度!");
|
|
|
+ }
|
|
|
+ }
|
|
|
+ if (Func.isNotEmpty(user.getPassword())) {
|
|
|
+ user.setPassword(DigestUtil.encrypt(user.getPassword()));
|
|
|
+ }
|
|
|
+ Integer userCount = baseMapper.selectCount(Wrappers.<User>query().lambda().eq(User::getTenantId, tenantId).eq(User::getAccount, user.getAccount()));
|
|
|
+ if (userCount > 0 && Func.isEmpty(user.getId())) {
|
|
|
+ throw new ServiceException(StringUtil.format("当前用户 [{}] 已存在!", user.getAccount()));
|
|
|
+ }
|
|
|
+ return save(user) && submitUserDept(user);
|
|
|
+ }
|
|
|
+
|
|
|
+ @Override
|
|
|
+ @Transactional(rollbackFor = Exception.class)
|
|
|
+ public boolean updateUser(User user) {
|
|
|
+ String tenantId = user.getTenantId();
|
|
|
+ Integer userCount = baseMapper.selectCount(
|
|
|
+ Wrappers.<User>query().lambda()
|
|
|
+ .eq(User::getTenantId, tenantId)
|
|
|
+ .eq(User::getAccount, user.getAccount())
|
|
|
+ .notIn(User::getId, user.getId())
|
|
|
+ );
|
|
|
+ if (userCount > 0) {
|
|
|
+ throw new ServiceException(StringUtil.format("当前用户 [{}] 已存在!", user.getAccount()));
|
|
|
+ }
|
|
|
+ return updateUserInfo(user) && submitUserDept(user);
|
|
|
+ }
|
|
|
+
|
|
|
+ @Override
|
|
|
+ public boolean updateUserInfo(User user) {
|
|
|
+ user.setPassword(null);
|
|
|
+ return updateById(user);
|
|
|
+ }
|
|
|
+
|
|
|
+ private boolean submitUserDept(User user) {
|
|
|
+ List<Long> deptIdList = Func.toLongList(user.getDeptId());
|
|
|
+ List<UserDept> userDeptList = new ArrayList<>();
|
|
|
+ deptIdList.forEach(deptId -> {
|
|
|
+ UserDept userDept = new UserDept();
|
|
|
+ userDept.setUserId(user.getId());
|
|
|
+ userDept.setDeptId(deptId);
|
|
|
+ userDeptList.add(userDept);
|
|
|
+ });
|
|
|
+ userDeptService.remove(Wrappers.<UserDept>update().lambda().eq(UserDept::getUserId, user.getId()));
|
|
|
+ return userDeptService.saveBatch(userDeptList);
|
|
|
+ }
|
|
|
+
|
|
|
+ @Override
|
|
|
+ public IPage<User> selectUserPage(IPage<User> page, User user, Long deptId, String tenantId) {
|
|
|
+ List<Long> deptIdList = SysCache.getDeptChildIds(deptId);
|
|
|
+ return page.setRecords(baseMapper.selectUserPage(page, user, deptIdList, tenantId));
|
|
|
+ }
|
|
|
+
|
|
|
+ @Override
|
|
|
+ public IPage<UserVO> selectUserSearch(UserVO user, Query query) {
|
|
|
+ LambdaQueryWrapper<User> queryWrapper = Wrappers.<User>query().lambda();
|
|
|
+ if (StringUtil.isNotBlank(user.getName())) {
|
|
|
+ queryWrapper.like(User::getName, user.getName());
|
|
|
+ }
|
|
|
+ if (StringUtil.isNotBlank(user.getDeptName())) {
|
|
|
+ String deptIds = SysCache.getDeptIdsByFuzzy(AuthUtil.getTenantId(), user.getDeptName());
|
|
|
+ if (StringUtil.isNotBlank(deptIds)) {
|
|
|
+ queryWrapper.and(wrapper -> {
|
|
|
+ List<String> ids = Func.toStrList(deptIds);
|
|
|
+ ids.forEach(id -> wrapper.like(User::getDeptId, id).or());
|
|
|
+ });
|
|
|
+ }
|
|
|
+ }
|
|
|
+ if (StringUtil.isNotBlank(user.getPostName())) {
|
|
|
+ String postIds = SysCache.getPostIdsByFuzzy(AuthUtil.getTenantId(), user.getPostName());
|
|
|
+ if (StringUtil.isNotBlank(postIds)) {
|
|
|
+ queryWrapper.and(wrapper -> {
|
|
|
+ List<String> ids = Func.toStrList(postIds);
|
|
|
+ ids.forEach(id -> wrapper.like(User::getPostId, id).or());
|
|
|
+ });
|
|
|
+ }
|
|
|
+ }
|
|
|
+ IPage<User> pages = this.page(Condition.getPage(query), queryWrapper);
|
|
|
+ return UserWrapper.build().pageVO(pages);
|
|
|
+ }
|
|
|
+
|
|
|
+ @Override
|
|
|
+ public User userByAccount(String tenantId, String account) {
|
|
|
+ return baseMapper.selectOne(Wrappers.<User>query().lambda().eq(User::getTenantId, tenantId).eq(User::getAccount, account).eq(User::getIsDeleted, BladeConstant.DB_NOT_DELETED));
|
|
|
+ }
|
|
|
+
|
|
|
+ @Override
|
|
|
+ public UserInfo userInfo(Long userId) {
|
|
|
+ User user = baseMapper.selectById(userId);
|
|
|
+ return buildUserInfo(user);
|
|
|
+ }
|
|
|
+
|
|
|
+ @Override
|
|
|
+ public UserInfo userInfo(String tenantId, String account) {
|
|
|
+ User user = baseMapper.getUser(tenantId, account);
|
|
|
+ return buildUserInfo(user);
|
|
|
+ }
|
|
|
+
|
|
|
+ @Override
|
|
|
+ public UserInfo userInfo(String tenantId, String account, UserEnum userEnum) {
|
|
|
+ User user = baseMapper.getUser(tenantId, account);
|
|
|
+ return buildUserInfo(user, userEnum);
|
|
|
+ }
|
|
|
+
|
|
|
+ private UserInfo buildUserInfo(User user) {
|
|
|
+ return buildUserInfo(user, UserEnum.WEB);
|
|
|
+ }
|
|
|
+
|
|
|
+ private UserInfo buildUserInfo(User user, UserEnum userEnum) {
|
|
|
+ if (ObjectUtil.isEmpty(user)) {
|
|
|
+ return null;
|
|
|
+ }
|
|
|
+ UserInfo userInfo = new UserInfo();
|
|
|
+ userInfo.setUser(user);
|
|
|
+ if (Func.isNotEmpty(user)) {
|
|
|
+ R<List<String>> result = sysClient.getRoleAliases(user.getRoleId());
|
|
|
+ if (result.isSuccess()) {
|
|
|
+ List<String> roleAlias = result.getData();
|
|
|
+ userInfo.setRoles(roleAlias);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ // 根据每个用户平台,建立对应的detail表,通过查询将结果集写入到detail字段
|
|
|
+ Kv detail = Kv.create().set("type", userEnum.getName());
|
|
|
+ if (userEnum == UserEnum.WEB) {
|
|
|
+ UserWeb userWeb = new UserWeb();
|
|
|
+ UserWeb query = userWeb.selectOne(Wrappers.<UserWeb>lambdaQuery().eq(UserWeb::getUserId, user.getId()));
|
|
|
+ if (ObjectUtil.isNotEmpty(query)) {
|
|
|
+ detail.set("ext", query.getUserExt());
|
|
|
+ }
|
|
|
+ } else if (userEnum == UserEnum.APP) {
|
|
|
+ UserApp userApp = new UserApp();
|
|
|
+ UserApp query = userApp.selectOne(Wrappers.<UserApp>lambdaQuery().eq(UserApp::getUserId, user.getId()));
|
|
|
+ if (ObjectUtil.isNotEmpty(query)) {
|
|
|
+ detail.set("ext", query.getUserExt());
|
|
|
+ }
|
|
|
+ } else {
|
|
|
+ UserOther userOther = new UserOther();
|
|
|
+ UserOther query = userOther.selectOne(Wrappers.<UserOther>lambdaQuery().eq(UserOther::getUserId, user.getId()));
|
|
|
+ if (ObjectUtil.isNotEmpty(query)) {
|
|
|
+ detail.set("ext", query.getUserExt());
|
|
|
+ }
|
|
|
+ }
|
|
|
+ userInfo.setDetail(detail);
|
|
|
+ return userInfo;
|
|
|
+ }
|
|
|
+
|
|
|
+ @Override
|
|
|
+ @Transactional(rollbackFor = Exception.class)
|
|
|
+ public UserInfo userInfo(UserOauth userOauth) {
|
|
|
+ UserOauth uo = userOauthService.getOne(Wrappers.<UserOauth>query().lambda().eq(UserOauth::getUuid, userOauth.getUuid()).eq(UserOauth::getSource, userOauth.getSource()));
|
|
|
+ UserInfo userInfo;
|
|
|
+ if (Func.isNotEmpty(uo) && Func.isNotEmpty(uo.getUserId())) {
|
|
|
+ userInfo = this.userInfo(uo.getUserId());
|
|
|
+ userInfo.setOauthId(Func.toStr(uo.getId()));
|
|
|
+ } else {
|
|
|
+ userInfo = new UserInfo();
|
|
|
+ if (Func.isEmpty(uo)) {
|
|
|
+ userOauthService.save(userOauth);
|
|
|
+ userInfo.setOauthId(Func.toStr(userOauth.getId()));
|
|
|
+ } else {
|
|
|
+ userInfo.setOauthId(Func.toStr(uo.getId()));
|
|
|
+ }
|
|
|
+ User user = new User();
|
|
|
+ user.setAccount(userOauth.getUsername());
|
|
|
+ user.setTenantId(userOauth.getTenantId());
|
|
|
+ userInfo.setUser(user);
|
|
|
+ userInfo.setRoles(Collections.singletonList(GUEST_NAME));
|
|
|
+ }
|
|
|
+ return userInfo;
|
|
|
+ }
|
|
|
+
|
|
|
+ @Override
|
|
|
+ public boolean grant(String userIds, String roleIds) {
|
|
|
+ User user = new User();
|
|
|
+ user.setRoleId(roleIds);
|
|
|
+ return this.update(user, Wrappers.<User>update().lambda().in(User::getId, Func.toLongList(userIds)));
|
|
|
+ }
|
|
|
+
|
|
|
+ @Override
|
|
|
+ public boolean resetPassword(String userIds) {
|
|
|
+ User user = new User();
|
|
|
+ user.setPassword(DigestUtil.encrypt(CommonConstant.DEFAULT_PASSWORD));
|
|
|
+ user.setUpdateTime(DateUtil.now());
|
|
|
+ return this.update(user, Wrappers.<User>update().lambda().in(User::getId, Func.toLongList(userIds)));
|
|
|
+ }
|
|
|
+
|
|
|
+ @Override
|
|
|
+ public boolean updatePassword(Long userId, String oldPassword, String newPassword, String newPassword1) {
|
|
|
+ User user = getById(userId);
|
|
|
+ if (!newPassword.equals(newPassword1)) {
|
|
|
+ throw new ServiceException("请输入正确的确认密码!");
|
|
|
+ }
|
|
|
+ if (!user.getPassword().equals(DigestUtil.hex(oldPassword))) {
|
|
|
+ throw new ServiceException("原密码不正确!");
|
|
|
+ }
|
|
|
+ return this.update(Wrappers.<User>update().lambda().set(User::getPassword, DigestUtil.hex(newPassword)).eq(User::getId, userId));
|
|
|
+ }
|
|
|
+
|
|
|
+ @Override
|
|
|
+ public boolean removeUser(String userIds) {
|
|
|
+ if (Func.contains(Func.toLongArray(userIds), AuthUtil.getUserId())) {
|
|
|
+ throw new ServiceException("不能删除本账号!");
|
|
|
+ }
|
|
|
+ return deleteLogic(Func.toLongList(userIds));
|
|
|
+ }
|
|
|
+
|
|
|
+ @Override
|
|
|
+ @Transactional(rollbackFor = Exception.class)
|
|
|
+ public void importUser(List<UserExcel> data, Boolean isCovered) {
|
|
|
+ data.forEach(userExcel -> {
|
|
|
+ User user = Objects.requireNonNull(BeanUtil.copy(userExcel, User.class));
|
|
|
+ // 设置用户平台
|
|
|
+ user.setUserType(Func.toInt(DictCache.getKey(DictEnum.USER_TYPE, userExcel.getUserTypeName()), 1));
|
|
|
+ // 设置部门ID
|
|
|
+ user.setDeptId(SysCache.getDeptIds(userExcel.getTenantId(), userExcel.getDeptName()));
|
|
|
+ // 设置岗位ID
|
|
|
+ user.setPostId(SysCache.getPostIds(userExcel.getTenantId(), userExcel.getPostName()));
|
|
|
+ // 设置角色ID
|
|
|
+ user.setRoleId(SysCache.getRoleIds(userExcel.getTenantId(), userExcel.getRoleName()));
|
|
|
+ // 设置租户ID
|
|
|
+ if (!AuthUtil.isAdministrator() || StringUtil.isBlank(user.getTenantId())) {
|
|
|
+ user.setTenantId(AuthUtil.getTenantId());
|
|
|
+ }
|
|
|
+ // 覆盖数据
|
|
|
+ if (isCovered) {
|
|
|
+ // 查询用户是否存在
|
|
|
+ User oldUser = UserCache.getUser(userExcel.getTenantId(), userExcel.getAccount());
|
|
|
+ if (oldUser != null && oldUser.getId() != null) {
|
|
|
+ user.setId(oldUser.getId());
|
|
|
+ this.updateUser(user);
|
|
|
+ return;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ // 获取默认密码配置
|
|
|
+ String initPassword = ParamCache.getValue(DEFAULT_PARAM_PASSWORD);
|
|
|
+ user.setPassword(initPassword);
|
|
|
+ this.submit(user);
|
|
|
+ });
|
|
|
+ }
|
|
|
+
|
|
|
+ @Override
|
|
|
+ public List<UserExcel> exportUser(Wrapper<User> queryWrapper) {
|
|
|
+ List<UserExcel> userList = baseMapper.exportUser(queryWrapper);
|
|
|
+ userList.forEach(user -> {
|
|
|
+ user.setUserTypeName(DictCache.getValue(DictEnum.USER_TYPE, user.getUserType()));
|
|
|
+ user.setRoleName(StringUtil.join(SysCache.getRoleNames(user.getRoleId())));
|
|
|
+ user.setDeptName(StringUtil.join(SysCache.getDeptNames(user.getDeptId())));
|
|
|
+ user.setPostName(StringUtil.join(SysCache.getPostNames(user.getPostId())));
|
|
|
+ });
|
|
|
+ return userList;
|
|
|
+ }
|
|
|
+
|
|
|
+ @Override
|
|
|
+ @Transactional(rollbackFor = Exception.class)
|
|
|
+ public boolean registerGuest(User user, Long oauthId) {
|
|
|
+ Tenant tenant = SysCache.getTenant(user.getTenantId());
|
|
|
+ if (tenant == null || tenant.getId() == null) {
|
|
|
+ throw new ServiceException("租户信息错误!");
|
|
|
+ }
|
|
|
+ UserOauth userOauth = userOauthService.getById(oauthId);
|
|
|
+ if (userOauth == null || userOauth.getId() == null) {
|
|
|
+ throw new ServiceException("第三方登陆信息错误!");
|
|
|
+ }
|
|
|
+ user.setRealName(user.getName());
|
|
|
+ user.setAvatar(userOauth.getAvatar());
|
|
|
+ user.setRoleId(StringPool.MINUS_ONE);
|
|
|
+ user.setDeptId(StringPool.MINUS_ONE);
|
|
|
+ user.setPostId(StringPool.MINUS_ONE);
|
|
|
+ boolean userTemp = this.submit(user);
|
|
|
+ userOauth.setUserId(user.getId());
|
|
|
+ userOauth.setTenantId(user.getTenantId());
|
|
|
+ boolean oauthTemp = userOauthService.updateById(userOauth);
|
|
|
+ return (userTemp && oauthTemp);
|
|
|
+ }
|
|
|
+
|
|
|
+ @Override
|
|
|
+ public boolean updatePlatform(Long userId, Integer userType, String userExt) {
|
|
|
+ if (userType.equals(UserEnum.WEB.getCategory())) {
|
|
|
+ UserWeb userWeb = new UserWeb();
|
|
|
+ UserWeb query = userWeb.selectOne(Wrappers.<UserWeb>lambdaQuery().eq(UserWeb::getUserId, userId));
|
|
|
+ if (ObjectUtil.isNotEmpty(query)) {
|
|
|
+ userWeb.setId(query.getId());
|
|
|
+ }
|
|
|
+ userWeb.setUserId(userId);
|
|
|
+ userWeb.setUserExt(userExt);
|
|
|
+ return userWeb.insertOrUpdate();
|
|
|
+ } else if (userType.equals(UserEnum.APP.getCategory())) {
|
|
|
+ UserApp userApp = new UserApp();
|
|
|
+ UserApp query = userApp.selectOne(Wrappers.<UserApp>lambdaQuery().eq(UserApp::getUserId, userId));
|
|
|
+ if (ObjectUtil.isNotEmpty(query)) {
|
|
|
+ userApp.setId(query.getId());
|
|
|
+ }
|
|
|
+ userApp.setUserId(userId);
|
|
|
+ userApp.setUserExt(userExt);
|
|
|
+ return userApp.insertOrUpdate();
|
|
|
+ } else {
|
|
|
+ UserOther userOther = new UserOther();
|
|
|
+ UserOther query = userOther.selectOne(Wrappers.<UserOther>lambdaQuery().eq(UserOther::getUserId, userId));
|
|
|
+ if (ObjectUtil.isNotEmpty(query)) {
|
|
|
+ userOther.setId(query.getId());
|
|
|
+ }
|
|
|
+ userOther.setUserId(userId);
|
|
|
+ userOther.setUserExt(userExt);
|
|
|
+ return userOther.insertOrUpdate();
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ @Override
|
|
|
+ public UserVO platformDetail(User user) {
|
|
|
+ User detail = baseMapper.selectOne(Condition.getQueryWrapper(user));
|
|
|
+ UserVO userVO = UserWrapper.build().entityVO(detail);
|
|
|
+ if (userVO.getUserType().equals(UserEnum.WEB.getCategory())) {
|
|
|
+ UserWeb userWeb = new UserWeb();
|
|
|
+ UserWeb query = userWeb.selectOne(Wrappers.<UserWeb>lambdaQuery().eq(UserWeb::getUserId, user.getId()));
|
|
|
+ if (ObjectUtil.isNotEmpty(query)) {
|
|
|
+ userVO.setUserExt(query.getUserExt());
|
|
|
+ }
|
|
|
+ } else if (userVO.getUserType().equals(UserEnum.APP.getCategory())) {
|
|
|
+ UserApp userApp = new UserApp();
|
|
|
+ UserApp query = userApp.selectOne(Wrappers.<UserApp>lambdaQuery().eq(UserApp::getUserId, user.getId()));
|
|
|
+ if (ObjectUtil.isNotEmpty(query)) {
|
|
|
+ userVO.setUserExt(query.getUserExt());
|
|
|
+ }
|
|
|
+ } else {
|
|
|
+ UserOther userOther = new UserOther();
|
|
|
+ UserOther query = userOther.selectOne(Wrappers.<UserOther>lambdaQuery().eq(UserOther::getUserId, user.getId()));
|
|
|
+ if (ObjectUtil.isNotEmpty(query)) {
|
|
|
+ userVO.setUserExt(query.getUserExt());
|
|
|
+ }
|
|
|
+ }
|
|
|
+ return userVO;
|
|
|
+ }
|
|
|
+
|
|
|
+ @Override
|
|
|
+ @Transactional(rollbackFor = Exception.class)
|
|
|
+ public void updateUserById(User user) {
|
|
|
+
|
|
|
+ updateById(user);
|
|
|
+
|
|
|
+ if (ObjectUtil.isNotEmpty(user.getAppletOpenId())) {
|
|
|
+ LambdaUpdateWrapper<User> updateWrapper = Wrappers.lambdaUpdate();
|
|
|
+ updateWrapper.set(User::getAppletKey, null)
|
|
|
+ .set(User::getAppletOpenId, null)
|
|
|
+ .ne(BaseEntity::getId, user.getId());
|
|
|
+ }
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+ @Override
|
|
|
+ public User getUserInfoByAppletOpenId(String openId) {
|
|
|
+ LambdaQueryWrapper<User> wrapper = Wrappers.<User>lambdaQuery().eq(User::getAppletOpenId, openId);
|
|
|
+ return getOne(wrapper);
|
|
|
+ }
|
|
|
|
|
|
}
|