mirror of
https://github.com/PlayEdu/PlayEdu
synced 2025-12-22 18:29:51 +08:00
学员代码优化
This commit is contained in:
@@ -23,4 +23,8 @@ public interface UserService extends IService<User> {
|
||||
void removeRelateDepartmentsByUserId(Integer userId);
|
||||
|
||||
User findOrFail(Integer id) throws NotFoundException;
|
||||
|
||||
User createWithDepIds(String email, String name, String avatar, String password, String idCard, Integer[] depIds);
|
||||
|
||||
User updateWithDepIds(User user, String email, String nickname, String name, String avatar, String password, String idCard, Integer[] depIds);
|
||||
}
|
||||
|
||||
@@ -5,6 +5,8 @@ import com.baomidou.mybatisplus.core.metadata.IPage;
|
||||
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
||||
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
import org.springframework.transaction.annotation.Transactional;
|
||||
import xyz.playedu.api.constant.SystemConstant;
|
||||
import xyz.playedu.api.domain.User;
|
||||
import xyz.playedu.api.domain.UserDepartment;
|
||||
import xyz.playedu.api.exception.NotFoundException;
|
||||
@@ -14,9 +16,10 @@ import xyz.playedu.api.mapper.UserMapper;
|
||||
import org.springframework.stereotype.Service;
|
||||
import xyz.playedu.api.types.paginate.PaginationResult;
|
||||
import xyz.playedu.api.types.paginate.UserPaginateFilter;
|
||||
import xyz.playedu.api.util.HelperUtil;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.Arrays;
|
||||
import java.util.Date;
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
@@ -115,6 +118,81 @@ public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements Us
|
||||
}
|
||||
return user;
|
||||
}
|
||||
|
||||
@Override
|
||||
@Transactional
|
||||
public User createWithDepIds(String email, String name, String avatar, String password, String idCard, Integer[] depIds) {
|
||||
String salt = HelperUtil.randomString(6);
|
||||
String passwordHashed = HelperUtil.MD5(password + salt);
|
||||
|
||||
User user = new User();
|
||||
user.setEmail(email);
|
||||
user.setName(name);
|
||||
user.setNickname(name);
|
||||
user.setAvatar(avatar);
|
||||
user.setPassword(passwordHashed);
|
||||
user.setSalt(salt);
|
||||
user.setIdCard(idCard);
|
||||
user.setCredit1(0);
|
||||
user.setIsSetPassword(0);
|
||||
user.setIsActive(1);
|
||||
user.setIsLock(0);
|
||||
user.setCreateIp(SystemConstant.INTERNAL_IP);
|
||||
user.setCreateCity(SystemConstant.INTERNAL_IP_AREA);
|
||||
user.setCreatedAt(new Date());
|
||||
user.setUpdatedAt(new Date());
|
||||
|
||||
if (idCard != null && idCard.length() > 0) {
|
||||
user.setVerifyAt(new Date());
|
||||
user.setIsVerify(1);
|
||||
}
|
||||
|
||||
save(user);
|
||||
userDepartmentService.storeDepIds(user.getId(), depIds);
|
||||
return user;
|
||||
}
|
||||
|
||||
@Override
|
||||
@Transactional
|
||||
public User updateWithDepIds(User user, String email, String nickname, String name, String avatar, String password, String idCard, Integer[] depIds) {
|
||||
User newUser = new User();
|
||||
newUser.setId(user.getId());
|
||||
|
||||
if (!user.getEmail().equals(email)) {
|
||||
newUser.setEmail(email);
|
||||
}
|
||||
if (!user.getNickname().equals(nickname)) {
|
||||
newUser.setNickname(nickname);
|
||||
}
|
||||
if (!user.getName().equals(name)) {
|
||||
newUser.setName(name);
|
||||
}
|
||||
if (!user.getAvatar().equals(avatar)) {
|
||||
newUser.setAvatar(avatar);
|
||||
}
|
||||
if (password != null && password.length() > 0) {
|
||||
newUser.setPassword(HelperUtil.MD5(password + user.getSalt()));
|
||||
}
|
||||
if (!user.getIdCard().equals(idCard)) {
|
||||
newUser.setIdCard(idCard);
|
||||
}
|
||||
|
||||
if (newUser.getName() != null && newUser.getName().length() > 0 && newUser.getIdCard() != null && newUser.getIdCard().length() > 0) {
|
||||
if (user.getVerifyAt() == null) {
|
||||
newUser.setIsVerify(1);
|
||||
newUser.setVerifyAt(new Date());
|
||||
}
|
||||
} else {
|
||||
if (user.getIsVerify() == 1) {
|
||||
newUser.setIsVerify(0);
|
||||
newUser.setVerifyAt(null);
|
||||
}
|
||||
}
|
||||
|
||||
updateById(newUser);
|
||||
userDepartmentService.resetStoreDepIds(newUser.getId(), depIds);
|
||||
return newUser;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
@@ -1,6 +1,7 @@
|
||||
package xyz.playedu.api.service.impl.internal;
|
||||
|
||||
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
||||
import org.springframework.transaction.annotation.Transactional;
|
||||
import xyz.playedu.api.domain.UserDepartment;
|
||||
import xyz.playedu.api.service.internal.UserDepartmentService;
|
||||
import xyz.playedu.api.mapper.UserDepartmentMapper;
|
||||
@@ -16,8 +17,7 @@ import java.util.List;
|
||||
* @createDate 2023-02-23 15:08:38
|
||||
*/
|
||||
@Service
|
||||
public class UserDepartmentServiceImpl extends ServiceImpl<UserDepartmentMapper, UserDepartment>
|
||||
implements UserDepartmentService {
|
||||
public class UserDepartmentServiceImpl extends ServiceImpl<UserDepartmentMapper, UserDepartment> implements UserDepartmentService {
|
||||
|
||||
@Override
|
||||
public List<Integer> getUserIdsByDepIds(Integer[] depIds) {
|
||||
@@ -30,6 +30,27 @@ public class UserDepartmentServiceImpl extends ServiceImpl<UserDepartmentMapper,
|
||||
}
|
||||
return ids;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void storeDepIds(Integer userId, Integer[] depIds) {
|
||||
if (depIds == null) {
|
||||
return;
|
||||
}
|
||||
List<UserDepartment> userDepartments = new ArrayList<>();
|
||||
for (int i = 0; i < depIds.length; i++) {
|
||||
UserDepartment userDepartment = new UserDepartment();
|
||||
userDepartment.setUserId(userId);
|
||||
userDepartment.setDepId(depIds[i]);
|
||||
userDepartments.add(userDepartment);
|
||||
}
|
||||
saveBatch(userDepartments);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void resetStoreDepIds(Integer userId, Integer[] depIds) {
|
||||
remove(query().getWrapper().eq("user_id", userId));
|
||||
storeDepIds(userId, depIds);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
@@ -12,4 +12,8 @@ import java.util.List;
|
||||
*/
|
||||
public interface UserDepartmentService extends IService<UserDepartment> {
|
||||
List<Integer> getUserIdsByDepIds(Integer[] depIds);
|
||||
|
||||
void storeDepIds(Integer userId, Integer[] depIds);
|
||||
|
||||
void resetStoreDepIds(Integer userId, Integer[] depIds);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user