mirror of
				https://github.com/continew-org/continew-admin.git
				synced 2025-10-26 18:58:37 +08:00 
			
		
		
		
	chore: continew-starter 2.7.1 => 2.7.2
1.重构代码生成(PostgreSQL 数据库兼容更完整) 2.适配 Tree 树结构生成 3.适配字典扩展配置
This commit is contained in:
		| @@ -22,6 +22,7 @@ import cn.hutool.core.bean.BeanUtil; | ||||
| import cn.hutool.core.collection.CollUtil; | ||||
| import cn.hutool.core.lang.tree.Tree; | ||||
| import cn.hutool.core.lang.tree.TreeNodeConfig; | ||||
| import cn.hutool.core.lang.tree.TreeUtil; | ||||
| import cn.hutool.core.util.IdUtil; | ||||
| import cn.hutool.core.util.ObjectUtil; | ||||
| import cn.hutool.core.util.RandomUtil; | ||||
| @@ -61,7 +62,7 @@ import top.continew.starter.cache.redisson.util.RedisUtils; | ||||
| import top.continew.starter.core.autoconfigure.project.ProjectProperties; | ||||
| import top.continew.starter.core.util.validate.CheckUtils; | ||||
| import top.continew.starter.extension.crud.annotation.TreeField; | ||||
| import top.continew.starter.extension.crud.util.TreeUtils; | ||||
| import top.continew.starter.extension.crud.autoconfigure.CrudProperties; | ||||
| import top.continew.starter.messaging.websocket.util.WebSocketUtils; | ||||
| import top.continew.starter.web.util.SpringWebUtils; | ||||
|  | ||||
| @@ -83,6 +84,7 @@ import static top.continew.admin.system.enums.PasswordPolicyEnum.PASSWORD_EXPIRA | ||||
| public class LoginServiceImpl implements LoginService { | ||||
|  | ||||
|     private final ProjectProperties projectProperties; | ||||
|     private final CrudProperties crudProperties; | ||||
|     private final PasswordEncoder passwordEncoder; | ||||
|     private final ThreadPoolTaskExecutor threadPoolTaskExecutor; | ||||
|     private final UserService userService; | ||||
| @@ -178,8 +180,8 @@ public class LoginServiceImpl implements LoginService { | ||||
|         List<MenuResp> menuList = menuSet.stream().filter(m -> !MenuTypeEnum.BUTTON.equals(m.getType())).toList(); | ||||
|         // 构建路由树 | ||||
|         TreeField treeField = MenuResp.class.getDeclaredAnnotation(TreeField.class); | ||||
|         TreeNodeConfig treeNodeConfig = TreeUtils.genTreeNodeConfig(treeField); | ||||
|         List<Tree<Long>> treeList = TreeUtils.build(menuList, treeNodeConfig, (m, tree) -> { | ||||
|         TreeNodeConfig treeNodeConfig = crudProperties.getTree().genTreeNodeConfig(treeField); | ||||
|         List<Tree<Long>> treeList = TreeUtil.build(menuList, treeField.rootId(), treeNodeConfig, (m, tree) -> { | ||||
|             tree.setId(m.getId()); | ||||
|             tree.setParentId(m.getParentId()); | ||||
|             tree.setName(m.getTitle()); | ||||
|   | ||||
| @@ -37,7 +37,7 @@ import java.time.LocalDateTime; | ||||
|  * @since 2022/12/21 20:42 | ||||
|  */ | ||||
| @Data | ||||
| @DictField(labelKey = "nickname") | ||||
| @DictField(labelKey = "nickname", extraKeys = {"username"}) | ||||
| @TableName("sys_user") | ||||
| public class UserDO extends BaseDO { | ||||
|  | ||||
|   | ||||
| @@ -2,14 +2,14 @@ | ||||
| <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" > | ||||
| <mapper namespace="top.continew.admin.system.mapper.UserPasswordHistoryMapper"> | ||||
|     <delete id="deleteExpired"> | ||||
|         DELETE t1 FROM sys_user_password_history t1 | ||||
|         DELETE t1 FROM sys_user_password_history AS t1 | ||||
|         LEFT JOIN ( | ||||
|             SELECT id | ||||
|             FROM sys_user_password_history | ||||
|             WHERE user_id = #{userId} | ||||
|             ORDER BY create_time DESC | ||||
|             LIMIT #{count} | ||||
|         ) t2 ON t2.id = t1.id | ||||
|         ) AS t2 ON t2.id = t1.id | ||||
|         WHERE t2.id IS NULL | ||||
|     </delete> | ||||
| </mapper> | ||||
		Reference in New Issue
	
	Block a user