Skip to content
项目
群组
代码片段
帮助
正在加载...
帮助
提交反馈
为 GitLab 提交贡献
登录
切换导航
iBiz4j Spring R7
项目
项目
详情
动态
版本
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
计划
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
统计图
创建新议题
作业
提交
议题看板
打开侧边栏
iBiz-R7后台标准模板
iBiz4j Spring R7
提交
fe1290d6
提交
fe1290d6
编写于
5月 26, 2020
作者:
zhouweidong
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
简化权限校验
上级
9e2009a8
变更
2
隐藏空白字符变更
内嵌
并排
正在显示
2 个修改的文件
包含
24 行增加
和
17 行删除
+24
-17
%ITEM%Resource.java.ftl
...YS_PKGPATH%/%SYSAPI_PKGPATH%/rest/%ITEM%Resource.java.ftl
+3
-5
AuthPermissionEvaluator.java.ftl
...S_PKGPATH%/util/security/AuthPermissionEvaluator.java.ftl
+21
-12
未找到文件。
SLN/%PUBPRJ%-provider/%PUBPRJ%-provider-%SYSAPI_PKGPATH%/src/main/java/%SYS_PKGPATH%/%SYSAPI_PKGPATH%/rest/%ITEM%Resource.java.ftl
浏览文件 @
fe1290d6
...
...
@@ -77,14 +77,12 @@ import ${pubPkgCodeName}.core.${deapideModuleCNLC}.service.I${deapideCN}Service;
public
class
${
itemCodeName
}
Resource
{
@
Autowired
p
rivate
I
${
deCodeName
}
Service
${
deCodeNameLC
}
Service
;
p
ublic
I
${
deCodeName
}
Service
${
deCodeNameLC
}
Service
;
@
Autowired
@
Lazy
public
${
itemCodeName
}
Mapping
${
itemCodeNameLC
}
Mapping
;
public
${
deCodeName
}
DTO
permissionDTO
=
new
${
deCodeName
}
DTO
();
<#--
嵌套服务对象
-->
<#
if
item
.
getPSDEServiceAPIRSs
()??>
<#
list
item
.
getPSDEServiceAPIRSs
()
as
apider
>
...
...
@@ -146,7 +144,7 @@ public class ${itemCodeName}Resource {
<#
if
noDEPrefield
>
<@
outputHasAnyAuthorityAnnotation
'${sys.codeName}-${de.codeName}-${deaction.codeName}-all'
/>
<#
else
>
<@
outputHasPermissionAnnotation
'this.${itemCodeNameLC}Mapping.toDomain(#${itemCodeNameLC}dto
s
)'
'${sys.codeName}-${de.codeName}-${deaction.codeName}'
/>
<@
outputHasPermissionAnnotation
'this.${itemCodeNameLC}Mapping.toDomain(#${itemCodeNameLC}dto)'
'${sys.codeName}-${de.codeName}-${deaction.codeName}'
/>
</#
if
>
@
ApiOperation
(
value
=
"${deaction.getLogicName()}"
,
tags
=
{
"${itemCodeName}"
},
notes
=
"${deaction.getLogicName()}"
)
@
RequestMapping
(
method
=
RequestMethod
.
POST
,
value
=
"${fullPath}"
)
...
...
@@ -657,7 +655,7 @@ public class ${itemCodeName}Resource {
<#
comment
>
输出实体资源鉴权注解
[
hasAnyAuthority
]</#
comment
>
<#
macro
outputHasPermissionAnnotation
param1
param2
>
//
@
PreAuthorize
(
"hasPermission(${param1},'${param2}')"
)
@
PreAuthorize
(
"hasPermission(${param1},'${param2}')"
)
</#
macro
>
<#
comment
>
输出实体批处理权限注解
[
hasAnyAuthority
]</#
comment
>
...
...
SLN/%PUBPRJ%-util/src/main/java/%SYS_PKGPATH%/util/security/AuthPermissionEvaluator.java.ftl
浏览文件 @
fe1290d6
...
...
@@ -53,7 +53,7 @@ public class AuthPermissionEvaluator implements PermissionEvaluator {
if
(
entity
instanceof
ArrayList
){
List
<
EntityBase
>
entities
=
(
List
<
EntityBase
>)
entity
;
for
(
EntityBase
entityBase
:
entities
){
boolean
result
=
actionValid
(
entityBase
,
entityDataRange
);
boolean
result
=
actionValid
(
entityBase
,
strAction
,
entityDataRange
);
if
(
!result){
return
false
;
}
...
...
@@ -61,7 +61,7 @@ public class AuthPermissionEvaluator implements PermissionEvaluator {
}
else
{
EntityBase
entityBase
=
(
EntityBase
)
entity
;
return
actionValid
(
entityBase
,
entityDataRange
);
return
actionValid
(
entityBase
,
strAction
,
entityDataRange
);
}
return
true
;
}
...
...
@@ -112,7 +112,7 @@ public class AuthPermissionEvaluator implements PermissionEvaluator {
*
@
param
entityDataRange
*
@
return
*/
private
boolean
actionValid
(
EntityBase
entity
,
Set
<
String
>
entityDataRange
){
private
boolean
actionValid
(
EntityBase
entity
,
S
tring
action
,
S
et
<
String
>
entityDataRange
){
Map
<
String
,
String
>
permissionField
=
getPermissionField
(
entity
);//
获取组织、部门预置属性
String
orgField
=
permissionField
.
get
(
"orgfield"
);
...
...
@@ -153,17 +153,26 @@ public class AuthPermissionEvaluator implements PermissionEvaluator {
}
}
if
(
!ObjectUtils.isEmpty(orgFieldValue) && !userOrg.contains(orgFieldValue)){
return
false
;
}
if
(
!ObjectUtils.isEmpty(orgDeptFieldValue) && !userOrgDept.contains(orgDeptFieldValue)){
return
false
;
}
if
(
!ObjectUtils.isEmpty(crateManFieldValue) && !crateManFieldValue.equals(authenticationUser.getUserid())){
return
false
;
if
(
action
.
endsWith
(
"Create"
)){
if
(
!ObjectUtils.isEmpty(orgFieldValue) && !userOrg.contains(orgFieldValue))
return
false
;
if
(
!ObjectUtils.isEmpty(orgDeptFieldValue) && !userOrgDept.contains(orgDeptFieldValue))
return
false
;
if
(
!ObjectUtils.isEmpty(crateManFieldValue) && !crateManFieldValue.equals(authenticationUser.getUserid()))
return
false
;
return
true
;
}
else
{
if
(
!ObjectUtils.isEmpty(orgFieldValue) && userOrg.contains(orgFieldValue))
return
true
;
if
(
!ObjectUtils.isEmpty(orgDeptFieldValue) && userOrgDept.contains(orgDeptFieldValue))
return
true
;
if
(
!ObjectUtils.isEmpty(crateManFieldValue) && crateManFieldValue.equals(authenticationUser.getUserid()))
return
true
;
return
true
;
return
false
;
}
}
/**
...
...
编辑
预览
Markdown
格式
0%
请重试
or
添加新附件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
先完成此消息的编辑!
取消
想要评论请
注册
或
登录