Skip to content
Toggle navigation
Projects
Groups
Snippets
Help
yangxiujun
/
paidan_demo
This project
Loading...
Sign in
Toggle navigation
Go to a project
Project
Repository
Issues
0
Merge Requests
0
Pipelines
Wiki
Snippets
Settings
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Commit 85d8723a
authored
Jul 12, 2023
by
chamberone
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
feat: 返回权限结果排序
1 parent
b78b3d3c
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
64 additions
and
25 deletions
project-interface/src/main/java/com/dituhui/pea/pojo/ResourceInfo.java
project-user/src/main/java/com/dituhui/pea/user/dao/ResourceDao.java
project-user/src/main/java/com/dituhui/pea/user/service/UserService.java
project-interface/src/main/java/com/dituhui/pea/pojo/ResourceInfo.java
View file @
85d8723
package
com
.
dituhui
.
pea
.
pojo
;
import
java.util.List
;
import
javax.validation.constraints.NotBlank
;
import
lombok.Data
;
...
...
@@ -10,26 +12,31 @@ import lombok.Data;
@Data
public
class
ResourceInfo
{
/**
* 主键
*/
private
String
id
;
/**
* 名称
*/
@NotBlank
(
message
=
"资源名称不能为空!"
)
private
String
name
;
/**
* 用户自定义条件
*/
private
String
extra
;
/**
* 描述
*/
private
String
description
;
/**
* 资源类型1菜单2功能点3所属组织
*/
private
Integer
type
;
/**
* 主键
*/
private
String
id
;
/**
* 名称
*/
@NotBlank
(
message
=
"资源名称不能为空!"
)
private
String
name
;
/**
* 用户自定义条件
*/
private
String
extra
;
// 菜单字段
private
String
code
;
private
Integer
order
;
/**
* 描述
*/
private
String
description
;
/**
* 资源类型1菜单2功能点3所属组织
*/
private
Integer
type
;
private
List
<
ResourceInfo
>
children
;
}
project-user/src/main/java/com/dituhui/pea/user/dao/ResourceDao.java
View file @
85d8723
...
...
@@ -21,6 +21,14 @@ public interface ResourceDao extends JpaRepository<ResourceEntity, String>,
* @return
*/
List
<
ResourceEntity
>
findByIdIn
(
List
<
String
>
ids
);
/**
* 查询子资源
*
* @param parentIds
* @return
*/
List
<
ResourceEntity
>
findByParentId
(
String
parentId
);
...
...
project-user/src/main/java/com/dituhui/pea/user/service/UserService.java
View file @
85d8723
package
com
.
dituhui
.
pea
.
user
.
service
;
import
java.util.Comparator
;
import
java.util.Date
;
import
java.util.List
;
import
java.util.stream.Collectors
;
...
...
@@ -31,6 +32,7 @@ import com.dituhui.pea.user.dao.RoleDao;
import
com.dituhui.pea.user.dao.RoleResourceDao
;
import
com.dituhui.pea.user.dao.UserDao
;
import
com.dituhui.pea.user.dao.UserRoleDao
;
import
com.dituhui.pea.user.entity.ResourceEntity
;
import
com.dituhui.pea.user.entity.RoleEntity
;
import
com.dituhui.pea.user.entity.RoleResourceEntity
;
import
com.dituhui.pea.user.entity.UserEntity
;
...
...
@@ -111,19 +113,41 @@ public class UserService {
// 获取资源
List
<
RoleResourceEntity
>
roleResources
=
roleResourceDao
.
findByRoleIdIn
(
ids
);
log
.
info
(
"role
size:{} roleResources:{}"
,
ids
.
size
()
,
CollectionUtils
.
isNotEmpty
(
roleResources
));
log
.
info
(
"role
: {} roleResources:{}"
,
ids
,
CollectionUtils
.
isNotEmpty
(
roleResources
));
if
(
CollectionUtils
.
isNotEmpty
(
roleResources
))
{
List
<
String
>
resourceIds
=
roleResources
.
stream
().
map
(
r
->
r
.
getResourceId
())
.
collect
(
Collectors
.
toList
());
userDTO
.
setResources
(
resourceDao
.
findAllById
(
resourceIds
).
stream
()
.
map
(
r
->
BeanUtil
.
copyProperties
(
r
,
ResourceInfo
.
class
)).
collect
(
Collectors
.
toList
()));
List
<
ResourceEntity
>
resources
=
resourceDao
.
findAllById
(
resourceIds
);
// 子菜单嵌套处理+菜单排序
List
<
ResourceInfo
>
levelOne
=
resources
.
stream
()
.
filter
(
r
->
StringUtils
.
isNotEmpty
(
r
.
getParentId
())
&&
r
.
getType
()
==
1
)
.
map
(
r
->
BeanUtil
.
copyProperties
(
r
,
ResourceInfo
.
class
)).
collect
(
Collectors
.
toList
());
for
(
ResourceInfo
resourceInfo
:
levelOne
)
{
splitExtra
(
resourceInfo
);
List
<
ResourceEntity
>
levelTow
=
resourceDao
.
findByParentId
(
resourceInfo
.
getId
());
List
<
ResourceInfo
>
levelTowResourceInfo
=
levelTow
.
stream
().
map
(
r
->
{
ResourceInfo
res
=
BeanUtil
.
copyProperties
(
r
,
ResourceInfo
.
class
);
splitExtra
(
res
);
return
res
;
}).
sorted
(
Comparator
.
comparing
(
ResourceInfo:
:
getOrder
)).
collect
(
Collectors
.
toList
());
resourceInfo
.
setChildren
(
levelTowResourceInfo
);
}
levelOne
=
levelOne
.
stream
().
sorted
(
Comparator
.
comparing
(
ResourceInfo:
:
getOrder
))
.
collect
(
Collectors
.
toList
());
userDTO
.
setResources
(
levelOne
);
}
}
}
return
userDTO
;
}
private
void
splitExtra
(
ResourceInfo
resourceInfo
)
{
String
[]
temp
=
resourceInfo
.
getExtra
().
split
(
","
);
resourceInfo
.
setCode
(
temp
[
0
]);
resourceInfo
.
setOrder
(
Integer
.
parseInt
(
temp
[
1
]));
resourceInfo
.
setExtra
(
null
);
}
public
Result
<?>
getUserInfo
(
String
token
)
{
UserEntity
user
=
(
UserEntity
)
redisService
.
get
(
RedisKeyGroup
.
authToken
+
":"
+
token
);
UserLoginDTO
userDTO
=
convertToUserLoginDTO
(
user
);
...
...
Write
Preview
Markdown
is supported
Attach a file
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to post a comment