Skip to content
项目
群组
代码片段
帮助
正在加载...
帮助
提交反馈
为 GitLab 提交贡献
登录
切换导航
I
ibzou
项目
项目
详情
动态
版本
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
计划
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
统计图
创建新议题
作业
提交
议题看板
打开侧边栏
ibiz4jteam
ibzou
提交
f3d0c546
提交
f3d0c546
编写于
9月 04, 2020
作者:
zhouweidong
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
USR代码
上级
cd34d861
变更
17
展开全部
显示空白字符变更
内嵌
并排
正在显示
17 个修改的文件
包含
1651 行增加
和
31 行删除
+1651
-31
DevBootSecurityConfig.java
...rc/main/java/cn/ibizlab/config/DevBootSecurityConfig.java
+7
-26
OUModelRefreshAspect.java
...izlab/core/ou/extensions/aspect/OUModelRefreshAspect.java
+58
-0
SysEmp2UserAspect.java
.../ibizlab/core/ou/extensions/aspect/SysEmp2UserAspect.java
+380
-0
DeptMap.java
...in/java/cn/ibizlab/core/ou/extensions/domain/DeptMap.java
+46
-0
DeptNode.java
...n/java/cn/ibizlab/core/ou/extensions/domain/DeptNode.java
+45
-0
EmpNode.java
...in/java/cn/ibizlab/core/ou/extensions/domain/EmpNode.java
+74
-0
OrgMap.java
...ain/java/cn/ibizlab/core/ou/extensions/domain/OrgMap.java
+46
-0
OrgNode.java
...in/java/cn/ibizlab/core/ou/extensions/domain/OrgNode.java
+43
-0
SysDept2NodeMapping.java
...izlab/core/ou/extensions/mapping/SysDept2NodeMapping.java
+18
-0
SysEmp2NodeMapping.java
...bizlab/core/ou/extensions/mapping/SysEmp2NodeMapping.java
+18
-0
SysEmp2UserMapping.java
...bizlab/core/ou/extensions/mapping/SysEmp2UserMapping.java
+18
-0
SysOrg2NodeMapping.java
...bizlab/core/ou/extensions/mapping/SysOrg2NodeMapping.java
+18
-0
OUCoreService.java
.../cn/ibizlab/core/ou/extensions/service/OUCoreService.java
+336
-0
OUModelService.java
...cn/ibizlab/core/ou/extensions/service/OUModelService.java
+236
-0
SysUSERServiceImpl.java
...bizlab/core/ou/extensions/service/SysUSERServiceImpl.java
+16
-0
apiSecurityConfig.java
...rc/main/java/cn/ibizlab/api/config/apiSecurityConfig.java
+7
-5
OUCoreResource.java
...n/java/cn/ibizlab/api/rest/extensions/OUCoreResource.java
+285
-0
未找到文件。
ou-boot/src/main/java/cn/ibizlab/config/DevBootSecurityConfig.java
浏览文件 @
f3d0c546
...
...
@@ -19,7 +19,6 @@ import org.springframework.security.config.http.SessionCreationPolicy;
import
org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder
;
import
org.springframework.security.crypto.password.PasswordEncoder
;
import
org.springframework.security.web.authentication.UsernamePasswordAuthenticationFilter
;
import
org.springframework.beans.factory.annotation.Qualifier
;
@Configuration
@EnableWebSecurity
...
...
@@ -41,18 +40,6 @@ public class DevBootSecurityConfig extends WebSecurityConfigurerAdapter {
@Value
(
"${ibiz.auth.path:v7/login}"
)
private
String
loginPath
;
@Value
(
"${ibiz.auth.logoutpath:v7/logout}"
)
private
String
logoutPath
;
@Value
(
"${ibiz.file.uploadpath:ibizutil/upload}"
)
private
String
uploadpath
;
@Value
(
"${ibiz.file.downloadpath:ibizutil/download}"
)
private
String
downloadpath
;
@Value
(
"${ibiz.file.previewpath:ibizutil/preview}"
)
private
String
previewpath
;
@Autowired
public
void
configureGlobal
(
AuthenticationManagerBuilder
auth
)
throws
Exception
{
auth
...
...
@@ -101,19 +88,13 @@ public class DevBootSecurityConfig extends WebSecurityConfigurerAdapter {
"/**/fonts/**"
,
"/**/js/**"
,
"/**/img/**"
,
"/"
,
"webjars/**"
,
"/swagger-resources/**"
,
"/v2/**"
"/"
).
permitAll
()
.
antMatchers
(
"/ibzou/org/**"
).
permitAll
()
.
antMatchers
(
"/ibzemployees/**/oumaps"
).
permitAll
()
.
antMatchers
(
"/dictionarys/**"
).
permitAll
()
//放行登录请求
.
antMatchers
(
HttpMethod
.
POST
,
"/"
+
loginPath
).
permitAll
()
//放行注销请求
.
antMatchers
(
HttpMethod
.
GET
,
"/"
+
logoutPath
).
permitAll
()
// 文件操作
.
antMatchers
(
"/"
+
downloadpath
+
"/**"
).
permitAll
()
.
antMatchers
(
"/"
+
uploadpath
).
permitAll
()
.
antMatchers
(
"/"
+
previewpath
+
"/**"
).
permitAll
()
.
anyRequest
().
authenticated
()
// 防止iframe 造成跨域
.
and
().
headers
().
frameOptions
().
disable
();
...
...
ou-core/src/main/java/cn/ibizlab/core/ou/extensions/aspect/OUModelRefreshAspect.java
0 → 100644
浏览文件 @
f3d0c546
package
cn
.
ibizlab
.
core
.
ou
.
extensions
.
aspect
;
import
cn.ibizlab.core.ou.extensions.service.OUModelService
;
import
org.aspectj.lang.JoinPoint
;
import
org.aspectj.lang.annotation.After
;
import
org.aspectj.lang.annotation.Aspect
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.context.annotation.Lazy
;
import
org.springframework.core.annotation.Order
;
import
org.springframework.stereotype.Component
;
/**
* 实体属性默认值切面,只有新建(Create)时才会填充默认值
*/
@Aspect
@Order
(
0
)
@Component
public
class
OUModelRefreshAspect
{
@Autowired
@Lazy
private
OUModelService
ouModelService
;
@After
(
value
=
"execution(* cn.ibizlab.core.ou.service.ISysOrganizationService.creat*(..))"
)
public
void
AfterCreateOrg
(
JoinPoint
point
)
throws
Exception
{
ouModelService
.
refreshModel
();
}
@After
(
value
=
"execution(* cn.ibizlab.core.ou.service.ISysOrganizationService.updat*(..))"
)
public
void
AfterUpdateOrg
(
JoinPoint
point
)
throws
Exception
{
ouModelService
.
refreshModel
();
}
@After
(
value
=
"execution(* cn.ibizlab.core.ou.service.ISysOrganizationService.remov*(..))"
)
public
void
AfterRemoveOrg
(
JoinPoint
point
)
throws
Exception
{
ouModelService
.
refreshModel
();
}
@After
(
value
=
"execution(* cn.ibizlab.core.ou.service.ISysOrganizationService.sav*(..))"
)
public
void
AfterSaveOrg
(
JoinPoint
point
)
throws
Exception
{
ouModelService
.
refreshModel
();
}
@After
(
value
=
"execution(* cn.ibizlab.core.ou.service.ISysDepartmentService.creat*(..))"
)
public
void
AfterCreateDept
(
JoinPoint
point
)
throws
Exception
{
ouModelService
.
refreshModel
();
}
@After
(
value
=
"execution(* cn.ibizlab.core.ou.service.ISysDepartmentService.updat*(..))"
)
public
void
AfterUpdateDept
(
JoinPoint
point
)
throws
Exception
{
ouModelService
.
refreshModel
();
}
@After
(
value
=
"execution(* cn.ibizlab.core.ou.service.ISysDepartmentService.remov*(..))"
)
public
void
AfterRemoveDept
(
JoinPoint
point
)
throws
Exception
{
ouModelService
.
refreshModel
();
}
@After
(
value
=
"execution(* cn.ibizlab.core.ou.service.ISysDepartmentService.sav*(..))"
)
public
void
AfterSaveDept
(
JoinPoint
point
)
throws
Exception
{
ouModelService
.
refreshModel
();
}
}
ou-core/src/main/java/cn/ibizlab/core/ou/extensions/aspect/SysEmp2UserAspect.java
0 → 100644
浏览文件 @
f3d0c546
此差异已折叠。
点击以展开。
ou-core/src/main/java/cn/ibizlab/core/ou/extensions/domain/DeptMap.java
0 → 100644
浏览文件 @
f3d0c546
package
cn
.
ibizlab
.
core
.
ou
.
extensions
.
domain
;
import
cn.ibizlab.core.ou.domain.SysDepartment
;
import
lombok.Data
;
import
org.springframework.util.StringUtils
;
import
java.util.LinkedHashSet
;
import
java.util.Set
;
@Data
public
class
DeptMap
{
private
String
deptid
;
private
SysDepartment
dept
;
private
Set
<
String
>
parent
=
new
LinkedHashSet
<>();
private
Set
<
String
>
sub
=
new
LinkedHashSet
<>();
private
Set
<
String
>
father
=
new
LinkedHashSet
<>();
private
Set
<
String
>
children
=
new
LinkedHashSet
<>();
public
String
getDeptid
()
{
if
(
StringUtils
.
isEmpty
(
deptid
)&&
dept
!=
null
)
deptid
=
dept
.
getDeptid
();
return
deptid
;
}
public
Set
<
String
>
getSub
()
{
if
(
sub
.
size
()==
0
&&(
dept
!=
null
||(!
StringUtils
.
isEmpty
(
getDeptid
()))))
sub
.
add
(
getDeptid
());
return
sub
;
}
public
Set
<
String
>
getParent
()
{
if
(
parent
.
size
()==
0
&&
dept
!=
null
&&(!
StringUtils
.
isEmpty
(
dept
.
getParentdeptid
())))
parent
.
add
(
dept
.
getParentdeptid
());
return
parent
;
}
public
Set
<
String
>
getFather
()
{
if
(
father
.
size
()==
0
&&
getParent
().
size
()>
0
)
father
.
add
(
parent
.
iterator
().
next
());
return
father
;
}
}
ou-core/src/main/java/cn/ibizlab/core/ou/extensions/domain/DeptNode.java
0 → 100644
浏览文件 @
f3d0c546
package
cn
.
ibizlab
.
core
.
ou
.
extensions
.
domain
;
import
com.alibaba.fastjson.annotation.JSONField
;
import
com.fasterxml.jackson.annotation.JsonProperty
;
import
lombok.Data
;
import
java.util.ArrayList
;
import
java.util.List
;
@Data
public
class
DeptNode
{
@JSONField
(
name
=
"id"
)
@JsonProperty
(
"id"
)
private
String
deptid
;
@JSONField
(
name
=
"label"
)
@JsonProperty
(
"label"
)
private
String
deptname
;
@JSONField
(
name
=
"code"
)
@JsonProperty
(
"code"
)
private
String
deptcode
;
@JSONField
(
name
=
"level"
)
@JsonProperty
(
"level"
)
private
Integer
deptlevel
;
@JSONField
(
name
=
"bcode"
)
@JsonProperty
(
"bcode"
)
private
String
bcode
;
@JSONField
(
name
=
"filter"
)
@JsonProperty
(
"filter"
)
private
List
<
String
>
filter
=
new
ArrayList
<>();
private
List
<
DeptNode
>
children
=
new
ArrayList
<>();
private
boolean
disabled
=
false
;
public
boolean
getIsLeaf
()
{
return
children
.
size
()==
0
;
}
}
ou-core/src/main/java/cn/ibizlab/core/ou/extensions/domain/EmpNode.java
0 → 100644
浏览文件 @
f3d0c546
package
cn
.
ibizlab
.
core
.
ou
.
extensions
.
domain
;
import
com.alibaba.fastjson.annotation.JSONField
;
import
com.fasterxml.jackson.annotation.JsonFormat
;
import
com.fasterxml.jackson.annotation.JsonProperty
;
import
lombok.Data
;
import
java.sql.Timestamp
;
@Data
public
class
EmpNode
{
@JSONField
(
name
=
"id"
)
@JsonProperty
(
"id"
)
private
String
userid
;
@JSONField
(
name
=
"label"
)
@JsonProperty
(
"label"
)
private
String
personname
;
@JSONField
(
name
=
"code"
)
@JsonProperty
(
"code"
)
private
String
usercode
;
private
String
loginname
;
private
String
domains
;
private
String
username
;
private
String
bcode
;
private
String
mdeptid
;
private
String
mdeptcode
;
private
String
mdeptname
;
private
String
postid
;
private
String
postcode
;
private
String
postname
;
private
String
orgid
;
private
String
orgcode
;
private
String
orgname
;
private
String
nickname
;
private
String
sex
;
private
String
certcode
;
private
String
phone
;
@JsonFormat
(
pattern
=
"yyyy-MM-dd"
,
locale
=
"zh"
,
timezone
=
"GMT+8"
)
@JSONField
(
format
=
"yyyy-MM-dd"
)
private
Timestamp
birthday
;
private
String
email
;
private
String
avatar
;
private
String
addr
;
public
String
getGroup
()
{
return
mdeptname
;
}
}
ou-core/src/main/java/cn/ibizlab/core/ou/extensions/domain/OrgMap.java
0 → 100644
浏览文件 @
f3d0c546
package
cn
.
ibizlab
.
core
.
ou
.
extensions
.
domain
;
import
cn.ibizlab.core.ou.domain.SysOrganization
;
import
lombok.Data
;
import
org.springframework.util.StringUtils
;
import
java.util.LinkedHashSet
;
import
java.util.Set
;
@Data
public
class
OrgMap
{
private
String
orgid
;
private
SysOrganization
org
;
private
Set
<
String
>
parent
=
new
LinkedHashSet
<>();
private
Set
<
String
>
sub
=
new
LinkedHashSet
<>();
private
Set
<
String
>
father
=
new
LinkedHashSet
<>();
private
Set
<
String
>
children
=
new
LinkedHashSet
<>();
public
String
getOrgid
()
{
if
(
StringUtils
.
isEmpty
(
orgid
)&&
org
!=
null
)
orgid
=
org
.
getOrgid
();
return
orgid
;
}
public
Set
<
String
>
getSub
()
{
if
(
sub
.
size
()==
0
&&(
org
!=
null
||(!
StringUtils
.
isEmpty
(
getOrgid
()))))
sub
.
add
(
getOrgid
());
return
sub
;
}
public
Set
<
String
>
getParent
()
{
if
(
parent
.
size
()==
0
&&
org
!=
null
&&(!
StringUtils
.
isEmpty
(
org
.
getParentorgid
())))
parent
.
add
(
org
.
getParentorgid
());
return
parent
;
}
public
Set
<
String
>
getFather
()
{
if
(
father
.
size
()==
0
&&
getParent
().
size
()>
0
)
father
.
add
(
parent
.
iterator
().
next
());
return
father
;
}
}
ou-core/src/main/java/cn/ibizlab/core/ou/extensions/domain/OrgNode.java
0 → 100644
浏览文件 @
f3d0c546
package
cn
.
ibizlab
.
core
.
ou
.
extensions
.
domain
;
import
com.alibaba.fastjson.annotation.JSONField
;
import
com.fasterxml.jackson.annotation.JsonProperty
;
import
lombok.Data
;
import
java.util.ArrayList
;
import
java.util.List
;
@Data
public
class
OrgNode
{
@JSONField
(
name
=
"id"
)
@JsonProperty
(
"id"
)
private
String
orgid
;
@JSONField
(
name
=
"label"
)
@JsonProperty
(
"label"
)
private
String
orgname
;
@JSONField
(
name
=
"code"
)
@JsonProperty
(
"code"
)
private
String
orgcode
;
@JSONField
(
name
=
"level"
)
@JsonProperty
(
"level"
)
private
Integer
orglevel
;
@JSONField
(
name
=
"filter"
)
@JsonProperty
(
"filter"
)
private
List
<
String
>
filter
=
new
ArrayList
<>();
private
List
<
OrgNode
>
children
=
new
ArrayList
<>();
private
boolean
disabled
=
false
;
public
boolean
getIsLeaf
()
{
return
children
.
size
()==
0
;
}
}
ou-core/src/main/java/cn/ibizlab/core/ou/extensions/mapping/SysDept2NodeMapping.java
0 → 100644
浏览文件 @
f3d0c546
package
cn
.
ibizlab
.
core
.
ou
.
extensions
.
mapping
;
import
cn.ibizlab.core.ou.domain.SysDepartment
;
import
cn.ibizlab.core.ou.extensions.domain.DeptNode
;
import
cn.ibizlab.util.domain.MappingBase
;
import
org.mapstruct.Mapper
;
import
org.mapstruct.NullValueCheckStrategy
;
import
org.mapstruct.NullValuePropertyMappingStrategy
;
@Mapper
(
componentModel
=
"spring"
,
uses
=
{},
nullValuePropertyMappingStrategy
=
NullValuePropertyMappingStrategy
.
IGNORE
,
nullValueCheckStrategy
=
NullValueCheckStrategy
.
ALWAYS
)
public
interface
SysDept2NodeMapping
extends
MappingBase
<
DeptNode
,
SysDepartment
>
{
}
ou-core/src/main/java/cn/ibizlab/core/ou/extensions/mapping/SysEmp2NodeMapping.java
0 → 100644
浏览文件 @
f3d0c546
package
cn
.
ibizlab
.
core
.
ou
.
extensions
.
mapping
;
import
cn.ibizlab.core.ou.domain.SysEmployee
;
import
cn.ibizlab.core.ou.extensions.domain.EmpNode
;
import
cn.ibizlab.util.domain.MappingBase
;
import
org.mapstruct.Mapper
;
import
org.mapstruct.NullValueCheckStrategy
;
import
org.mapstruct.NullValuePropertyMappingStrategy
;
@Mapper
(
componentModel
=
"spring"
,
uses
=
{},
nullValuePropertyMappingStrategy
=
NullValuePropertyMappingStrategy
.
IGNORE
,
nullValueCheckStrategy
=
NullValueCheckStrategy
.
ALWAYS
)
public
interface
SysEmp2NodeMapping
extends
MappingBase
<
EmpNode
,
SysEmployee
>
{
}
ou-core/src/main/java/cn/ibizlab/core/ou/extensions/mapping/SysEmp2UserMapping.java
0 → 100644
浏览文件 @
f3d0c546
package
cn
.
ibizlab
.
core
.
ou
.
extensions
.
mapping
;
import
cn.ibizlab.core.ou.domain.SysEmployee
;
import
cn.ibizlab.util.domain.IBZUSER
;
import
cn.ibizlab.util.domain.MappingBase
;
import
org.mapstruct.Mapper
;
import
org.mapstruct.NullValueCheckStrategy
;
import
org.mapstruct.NullValuePropertyMappingStrategy
;
@Mapper
(
componentModel
=
"spring"
,
uses
=
{},
nullValuePropertyMappingStrategy
=
NullValuePropertyMappingStrategy
.
IGNORE
,
nullValueCheckStrategy
=
NullValueCheckStrategy
.
ALWAYS
)
public
interface
SysEmp2UserMapping
extends
MappingBase
<
IBZUSER
,
SysEmployee
>
{
}
ou-core/src/main/java/cn/ibizlab/core/ou/extensions/mapping/SysOrg2NodeMapping.java
0 → 100644
浏览文件 @
f3d0c546
package
cn
.
ibizlab
.
core
.
ou
.
extensions
.
mapping
;
import
cn.ibizlab.core.ou.domain.SysOrganization
;
import
cn.ibizlab.core.ou.extensions.domain.OrgNode
;
import
cn.ibizlab.util.domain.MappingBase
;
import
org.mapstruct.Mapper
;
import
org.mapstruct.NullValueCheckStrategy
;
import
org.mapstruct.NullValuePropertyMappingStrategy
;
@Mapper
(
componentModel
=
"spring"
,
uses
=
{},
nullValuePropertyMappingStrategy
=
NullValuePropertyMappingStrategy
.
IGNORE
,
nullValueCheckStrategy
=
NullValueCheckStrategy
.
ALWAYS
)
public
interface
SysOrg2NodeMapping
extends
MappingBase
<
OrgNode
,
SysOrganization
>
{
}
ou-core/src/main/java/cn/ibizlab/core/ou/extensions/service/OUCoreService.java
0 → 100644
浏览文件 @
f3d0c546
package
cn
.
ibizlab
.
core
.
ou
.
extensions
.
service
;
import
cn.ibizlab.core.ou.domain.SysDepartment
;
import
cn.ibizlab.core.ou.domain.SysEmployee
;
import
cn.ibizlab.core.ou.domain.SysOrganization
;
import
cn.ibizlab.core.ou.extensions.domain.*
;
import
cn.ibizlab.core.ou.extensions.mapping.SysDept2NodeMapping
;
import
cn.ibizlab.core.ou.extensions.mapping.SysEmp2NodeMapping
;
import
cn.ibizlab.core.ou.extensions.mapping.SysOrg2NodeMapping
;
import
cn.ibizlab.core.ou.service.ISysEmployeeService
;
import
com.baomidou.mybatisplus.core.conditions.query.QueryWrapper
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.context.annotation.Lazy
;
import
org.springframework.stereotype.Service
;
import
org.springframework.util.StringUtils
;
import
java.util.*
;
@Service
public
class
OUCoreService
{
@Autowired
@Lazy
private
OUModelService
ouModelService
;
@Autowired
@Lazy
private
ISysEmployeeService
iibzEmployeeService
;
public
List
<
SysEmployee
>
getEmpByOrg
(
String
orgid
)
{
if
(
StringUtils
.
isEmpty
(
orgid
)
||
"nullorgid"
.
equals
(
orgid
))
return
new
ArrayList
<>();
return
iibzEmployeeService
.
list
(
new
QueryWrapper
<
SysEmployee
>().
eq
(
"orgid"
,
orgid
).
orderByAsc
(
"showorder"
));
}
public
List
<
SysEmployee
>
getEmpByDept
(
String
deptid
)
{
if
(
StringUtils
.
isEmpty
(
deptid
)
||
"nulldeptid"
.
equals
(
deptid
))
return
new
ArrayList
<>();
return
iibzEmployeeService
.
list
(
new
QueryWrapper
<
SysEmployee
>().
eq
(
"mdeptid"
,
deptid
).
orderByAsc
(
"showorder"
));
}
public
List
<
SysEmployee
>
getSubEmpByOrg
(
String
orgid
)
{
if
(
StringUtils
.
isEmpty
(
orgid
)
||
"nullorgid"
.
equals
(
orgid
))
return
new
ArrayList
<>();
Map
<
String
,
OrgMap
>
store
=
ouModelService
.
getOrgModel
();
OrgMap
orgmodel
=
this
.
getOrgModel
(
orgid
);
if
(
orgmodel
.
getSub
().
size
()==
store
.
size
())
return
iibzEmployeeService
.
list
();
return
iibzEmployeeService
.
list
(
new
QueryWrapper
<
SysEmployee
>().
in
(
"orgid"
,
orgmodel
.
getSub
()));
}
public
List
<
SysEmployee
>
getSubEmpByDept
(
String
deptid
)
{
if
(
StringUtils
.
isEmpty
(
deptid
)
||
"nulldeptid"
.
equals
(
deptid
))
return
new
ArrayList
<>();
DeptMap
deptmodel
=
this
.
getDeptModel
(
deptid
);
return
iibzEmployeeService
.
list
(
new
QueryWrapper
<
SysEmployee
>().
in
(
"mdeptid"
,
deptmodel
.
getSub
()));
}
public
List
<
SysEmployee
>
getParentEmpByOrg
(
String
orgid
,
boolean
bRecurrence
)
{
if
(
StringUtils
.
isEmpty
(
orgid
)
||
"nullorgid"
.
equals
(
orgid
))
return
new
ArrayList
<>();
OrgMap
orgmodel
=
this
.
getOrgModel
(
orgid
);
List
<
String
>
parent
=
new
ArrayList
<>();
for
(
String
str:
orgmodel
.
getParent
())
{
parent
.
add
(
str
);
if
(!
bRecurrence
)
break
;
}
if
(
parent
.
size
()==
0
)
return
new
ArrayList
<>();
return
iibzEmployeeService
.
list
(
new
QueryWrapper
<
SysEmployee
>().
in
(
"orgid"
,
parent
));
}
public
List
<
SysEmployee
>
getParentEmpByDept
(
String
deptid
,
boolean
bRecurrence
)
{
if
(
StringUtils
.
isEmpty
(
deptid
)
||
"nulldeptid"
.
equals
(
deptid
))
return
new
ArrayList
<>();
DeptMap
deptmodel
=
this
.
getDeptModel
(
deptid
);
List
<
String
>
parent
=
new
ArrayList
<>();
for
(
String
str:
deptmodel
.
getParent
())
{
parent
.
add
(
str
);
if
(!
bRecurrence
)
break
;
}
if
(
parent
.
size
()==
0
)
return
new
ArrayList
<>();
return
iibzEmployeeService
.
list
(
new
QueryWrapper
<
SysEmployee
>().
in
(
"mdeptid"
,
parent
));
}
public
OrgMap
getOrgModel
(
String
orgid
)
{
Map
<
String
,
OrgMap
>
store
=
ouModelService
.
getOrgModel
();
if
(
store
.
containsKey
(
orgid
))
{
OrgMap
map
=
store
.
get
(
orgid
);
return
map
;
}
else
{
OrgMap
map
=
new
OrgMap
();
map
.
setOrgid
(
orgid
);
return
map
;
}
}
public
DeptMap
getDeptModel
(
String
deptid
)
{
Map
<
String
,
DeptMap
>
store
=
ouModelService
.
getDeptModel
(
ouModelService
.
getOrgModel
());
if
(
store
.
containsKey
(
deptid
))
{
DeptMap
map
=
store
.
get
(
deptid
);
return
map
;
}
else
{
DeptMap
map
=
new
DeptMap
();
map
.
setDeptid
(
deptid
);
return
map
;
}
}
@Autowired
private
SysOrg2NodeMapping
org2NodeMapping
;
public
List
<
OrgNode
>
getOrgNode
(
String
root
)
{
if
(
StringUtils
.
isEmpty
(
root
))
root
=
"alls"
;
List
<
OrgNode
>
list
=
new
ArrayList
<>();
Map
<
String
,
OrgMap
>
store
=
ouModelService
.
getOrgModel
();
if
(
root
.
equals
(
"alls"
))
{
int
rootcnt
=
0
;
String
tmp
=
""
;
for
(
OrgMap
map:
store
.
values
())
{
SysOrganization
org
=
map
.
getOrg
();
if
(
StringUtils
.
isEmpty
(
org
.
getParentorgid
()))
{
rootcnt
++;
tmp
=
org
.
getOrgid
();
}
}
if
(
rootcnt
==
1
)
root
=
tmp
;
}
for
(
OrgMap
map:
store
.
values
())
{
SysOrganization
org
=
map
.
getOrg
();
String
parent
=
org
.
getParentorgid
();
if
(
StringUtils
.
isEmpty
(
parent
))
parent
=
"alls"
;
if
(
parent
.
equals
(
root
)||
root
.
equals
(
org
.
getOrgid
()))
{
OrgNode
node
=
org2NodeMapping
.
toDto
(
org
);
node
.
getFilter
().
addAll
(
map
.
getParent
());
node
.
getFilter
().
add
(
node
.
getOrgid
());
if
(
root
.
equals
(
org
.
getOrgid
()))
{
list
.
add
(
0
,
node
);
}
else
{
looporg
(
node
,
store
);
list
.
add
(
node
);
}
}
}
return
list
;
}
private
void
looporg
(
OrgNode
node
,
Map
<
String
,
OrgMap
>
store
)
{
Set
<
String
>
children
=
store
.
get
(
node
.
getOrgid
()).
getChildren
();
for
(
String
child:
children
)
{
OrgMap
childMap
=
store
.
get
(
child
);
OrgNode
sub
=
org2NodeMapping
.
toDto
(
childMap
.
getOrg
());
sub
.
getFilter
().
addAll
(
childMap
.
getParent
());
sub
.
getFilter
().
add
(
sub
.
getOrgid
());
node
.
getChildren
().
add
(
sub
);
looporg
(
sub
,
store
);
}
}
@Autowired
private
SysDept2NodeMapping
dept2NodeMapping
;
public
List
<
DeptNode
>
getDeptNode
(
String
orgid
)
{
List
<
DeptNode
>
list
=
new
ArrayList
<>();
if
(
StringUtils
.
isEmpty
(
orgid
))
return
list
;
Map
<
String
,
DeptMap
>
store
=
ouModelService
.
getDeptModel
(
ouModelService
.
getOrgModel
());
for
(
DeptMap
map:
store
.
values
())
{
SysDepartment
dept
=
map
.
getDept
();
if
(
StringUtils
.
isEmpty
(
dept
.
getParentdeptid
())&&
orgid
.
equals
(
dept
.
getOrgid
()))
{
DeptNode
node
=
dept2NodeMapping
.
toDto
(
dept
);
loopdept
(
node
,
store
);
list
.
add
(
node
);
}
}
return
list
;
}
public
List
<
DeptNode
>
getOrgDeptNode
(
String
orgid
)
{
List
<
DeptNode
>
list
=
new
ArrayList
<>();
if
(
StringUtils
.
isEmpty
(
orgid
))
orgid
=
"alls"
;
Map
<
String
,
DeptNode
>
parentNode
=
new
HashMap
<>();
List
<
OrgNode
>
listOrg
=
getOrgNode
(
orgid
);
for
(
OrgNode
org:
listOrg
)
{
DeptNode
node
=
changeOrgNode2DeptNode
(
org
,
parentNode
);
list
.
add
(
node
);
}
Map
<
String
,
DeptMap
>
store
=
ouModelService
.
getDeptModel
(
ouModelService
.
getOrgModel
());
for
(
DeptMap
map:
store
.
values
())
{
SysDepartment
dept
=
map
.
getDept
();
if
(
StringUtils
.
isEmpty
(
dept
.
getParentdeptid
()))
{
DeptNode
node
=
dept2NodeMapping
.
toDto
(
dept
);
if
(
parentNode
.
containsKey
(
dept
.
getOrgid
()))
{
node
.
setFilter
(
parentNode
.
get
(
dept
.
getOrgid
()).
getFilter
());
parentNode
.
get
(
dept
.
getOrgid
()).
getChildren
().
add
(
node
);
loopdept
(
node
,
store
);
}
}
}
return
list
;
}
private
void
loopdept
(
DeptNode
node
,
Map
<
String
,
DeptMap
>
store
)
{
Set
<
String
>
children
=
store
.
get
(
node
.
getDeptid
()).
getChildren
();
for
(
String
child:
children
)
{
DeptMap
childMap
=
store
.
get
(
child
);
DeptNode
sub
=
dept2NodeMapping
.
toDto
(
childMap
.
getDept
());
sub
.
setFilter
(
node
.
getFilter
());
node
.
getChildren
().
add
(
sub
);
loopdept
(
sub
,
store
);
}
}
private
DeptNode
changeOrgNode2DeptNode
(
OrgNode
orgnode
,
Map
<
String
,
DeptNode
>
parentNode
)
{
DeptNode
node
=
new
DeptNode
();
node
.
setDeptid
(
orgnode
.
getOrgid
());
node
.
setDeptname
(
orgnode
.
getOrgname
());
node
.
setFilter
(
orgnode
.
getFilter
());
node
.
setDisabled
(
true
);
parentNode
.
put
(
orgnode
.
getOrgid
(),
node
);
for
(
OrgNode
org:
orgnode
.
getChildren
())
{
node
.
getChildren
().
add
(
changeOrgNode2DeptNode
(
org
,
parentNode
));
}
return
node
;
}
@Autowired
private
SysEmp2NodeMapping
emp2NodeMapping
;
public
List
<
EmpNode
>
getEmpNode
(
String
orgid
)
{
List
<
EmpNode
>
listemp
=
new
ArrayList
<>();
List
<
String
>
list
=
new
ArrayList
<>();
if
(
StringUtils
.
isEmpty
(
orgid
))
return
listemp
;
Map
<
String
,
DeptMap
>
store
=
ouModelService
.
getDeptModel
(
ouModelService
.
getOrgModel
());
for
(
DeptMap
map:
store
.
values
())
{
SysDepartment
dept
=
map
.
getDept
();
if
(
StringUtils
.
isEmpty
(
dept
.
getParentdeptid
())&&
orgid
.
equals
(
dept
.
getOrgid
()))
{
list
.
add
(
dept
.
getDeptid
());
loopdept
(
dept
.
getDeptid
(),
store
,
list
);
}
}
LinkedHashMap
<
String
,
List
<
EmpNode
>>
empmap
=
new
LinkedHashMap
<>();
for
(
String
deptid:
list
)
{
empmap
.
put
(
deptid
,
new
ArrayList
<>());
}
for
(
EmpNode
node:
emp2NodeMapping
.
toDto
(
this
.
getEmpByOrg
(
orgid
)))
{
if
(
empmap
.
containsKey
(
node
.
getMdeptid
()))
empmap
.
get
(
node
.
getMdeptid
()).
add
(
node
);
}
for
(
String
deptid:
list
)
{
listemp
.
addAll
(
empmap
.
get
(
deptid
));
}
return
listemp
;
}
private
void
loopdept
(
String
node
,
Map
<
String
,
DeptMap
>
store
,
List
<
String
>
list
)
{
Set
<
String
>
children
=
store
.
get
(
node
).
getChildren
();
for
(
String
child:
children
)
{
list
.
add
(
child
);
loopdept
(
child
,
store
,
list
);
}
}
}
ou-core/src/main/java/cn/ibizlab/core/ou/extensions/service/OUModelService.java
0 → 100644
浏览文件 @
f3d0c546
package
cn
.
ibizlab
.
core
.
ou
.
extensions
.
service
;
import
cn.ibizlab.core.ou.domain.SysDepartment
;
import
cn.ibizlab.core.ou.domain.SysOrganization
;
import
cn.ibizlab.core.ou.extensions.domain.DeptMap
;
import
cn.ibizlab.core.ou.extensions.domain.OrgMap
;
import
cn.ibizlab.core.ou.service.ISysDepartmentService
;
import
cn.ibizlab.core.ou.service.ISysOrganizationService
;
import
com.baomidou.mybatisplus.core.conditions.query.QueryWrapper
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.cache.annotation.CacheEvict
;
import
org.springframework.stereotype.Service
;
import
org.springframework.util.StringUtils
;
import
java.util.*
;
@Service
public
class
OUModelService
{
@Autowired
private
ISysOrganizationService
iibzOrganizationService
;
@Autowired
private
ISysDepartmentService
iibzDepartmentService
;
private
Map
<
String
,
OrgMap
>
orgmap
=
null
;
private
Object
lockOrg
=
new
Object
();
//@Cacheable( value="ibzou-model",key = "'orgmap'")
public
Map
<
String
,
OrgMap
>
getOrgModel
()
{
if
(
orgmap
!=
null
)
return
orgmap
;
synchronized
(
lockOrg
)
{
if
(
orgmap
!=
null
)
return
orgmap
;
Map
<
String
,
OrgMap
>
store
=
new
LinkedHashMap
<>();
List
<
SysOrganization
>
listOrg
=
iibzOrganizationService
.
list
(
new
QueryWrapper
<
SysOrganization
>().
orderByAsc
(
"showorder"
,
"orgcode"
));
for
(
SysOrganization
org:
listOrg
)
{
OrgMap
map
=
new
OrgMap
();
map
.
setOrg
(
org
);
store
.
put
(
org
.
getOrgid
(),
map
);
}
for
(
SysOrganization
org:
listOrg
)
{
loopOrg
(
org
,
store
);
if
(!
StringUtils
.
isEmpty
(
org
.
getParentorgid
()))
{
if
(
store
.
containsKey
(
org
.
getParentorgid
()))
{
store
.
get
(
org
.
getParentorgid
()).
getChildren
().
add
(
org
.
getOrgid
());
}
}
}
for
(
SysOrganization
org:
listOrg
)
{
for
(
String
sub:
store
.
get
(
org
.
getOrgid
()).
getSub
())
{
if
(!
org
.
getOrgid
().
equals
(
sub
))
store
.
get
(
sub
).
getParent
().
add
(
org
.
getOrgid
());
}
}
orgmap
=
store
;
}
return
orgmap
;
}
public
void
loopOrg
(
SysOrganization
org
,
Map
<
String
,
OrgMap
>
store
)
{
if
(!
StringUtils
.
isEmpty
(
org
.
getParentorgid
()))
{
if
(
store
.
containsKey
(
org
.
getParentorgid
()))
{
store
.
get
(
org
.
getParentorgid
()).
getSub
().
add
(
org
.
getOrgid
());
loopOrg
(
store
.
get
(
org
.
getParentorgid
()).
getOrg
(),
store
);
}
}
}
private
Map
<
String
,
DeptMap
>
deptmap
=
null
;
private
Object
lockDept
=
new
Object
();
//@Cacheable( value="ibzou-model",key = "'deptmap'")
public
Map
<
String
,
DeptMap
>
getDeptModel
(
Map
<
String
,
OrgMap
>
orgstore
)
{
if
(
deptmap
!=
null
)
return
deptmap
;
synchronized
(
lockDept
)
{
if
(
deptmap
!=
null
)
return
deptmap
;
if
(
orgstore
==
null
)
orgstore
=
this
.
getOrgModel
();
Map
<
String
,
DeptMap
>
store
=
new
LinkedHashMap
<>();
Map
<
String
,
Set
<
String
>>
bcmap
=
new
HashMap
<>();
List
<
SysDepartment
>
listDept
=
iibzDepartmentService
.
list
(
new
QueryWrapper
<
SysDepartment
>().
orderByAsc
(
"showorder"
,
"deptcode"
));
for
(
SysDepartment
dept:
listDept
)
{
DeptMap
map
=
new
DeptMap
();
map
.
setDept
(
dept
);
store
.
put
(
dept
.
getDeptid
(),
map
);
String
bc
=
dept
.
getBcode
();
if
(!
StringUtils
.
isEmpty
(
bc
))
{
bc
=
bc
.
replace
(
";"
,
","
).
replace
(
";"
,
","
).
replace
(
","
,
","
);
String
[]
bcs
=
bc
.
split
(
","
);
for
(
String
strbc:
bcs
)
{
strbc
=
strbc
.
trim
();
if
(!
StringUtils
.
isEmpty
(
strbc
))
{
if
(!
bcmap
.
containsKey
(
strbc
))
{
Set
<
String
>
bcset
=
new
HashSet
<>();
bcmap
.
put
(
strbc
,
bcset
);
}
bcmap
.
get
(
strbc
).
add
(
dept
.
getDeptid
()+
":"
+
dept
.
getOrgid
());
}
}
}
}
for
(
SysDepartment
dept:
listDept
)
{
loopDept
(
dept
,
store
);
if
(!
StringUtils
.
isEmpty
(
dept
.
getParentdeptid
()))
{
if
(
store
.
containsKey
(
dept
.
getParentdeptid
()))
{
store
.
get
(
dept
.
getParentdeptid
()).
getChildren
().
add
(
dept
.
getDeptid
());
}
}
}
for
(
SysDepartment
dept:
listDept
)
{
for
(
String
sub:
store
.
get
(
dept
.
getDeptid
()).
getSub
())
{
if
(!
dept
.
getDeptid
().
equals
(
sub
))
store
.
get
(
sub
).
getParent
().
add
(
dept
.
getDeptid
());
}
}
for
(
SysDepartment
dept:
listDept
)
{
String
orgid
=
dept
.
getOrgid
();
if
(
StringUtils
.
isEmpty
(
orgid
)||(!
orgstore
.
containsKey
(
orgid
)))
continue
;
String
bc
=
dept
.
getBcode
();
if
(!
StringUtils
.
isEmpty
(
bc
))
{
bc
=
bc
.
replace
(
";"
,
","
).
replace
(
";"
,
","
).
replace
(
","
,
","
);
String
[]
bcs
=
bc
.
split
(
","
);
for
(
String
strbc
:
bcs
)
{
strbc
=
strbc
.
trim
();
if
(!
StringUtils
.
isEmpty
(
strbc
))
{
if
(
bcmap
.
containsKey
(
strbc
))
{
Set
<
String
>
bcset
=
bcmap
.
get
(
strbc
);
for
(
String
bcstring:
bcset
)
{
String
[]
bcstringarr
=
bcstring
.
split
(
":"
);
if
(
bcstringarr
.
length
==
2
)
{
String
bcdept
=
bcstringarr
[
0
];
String
bcorg
=
bcstringarr
[
1
];
for
(
String
porg:
orgstore
.
get
(
orgid
).
getParent
())
{
if
(
bcorg
.
equals
(
porg
))
store
.
get
(
dept
.
getDeptid
()).
getParent
().
add
(
bcdept
);
}
for
(
String
sorg:
orgstore
.
get
(
orgid
).
getSub
())
{
if
(
bcorg
.
equals
(
sorg
))
store
.
get
(
dept
.
getDeptid
()).
getSub
().
add
(
bcdept
);
}
}
}
}
}
}
}
}
deptmap
=
store
;
}
return
deptmap
;
}
public
void
loopDept
(
SysDepartment
dept
,
Map
<
String
,
DeptMap
>
store
)
{
if
(!
StringUtils
.
isEmpty
(
dept
.
getParentdeptid
()))
{
if
(
store
.
containsKey
(
dept
.
getParentdeptid
()))
{
store
.
get
(
dept
.
getParentdeptid
()).
getSub
().
add
(
dept
.
getDeptid
());
loopDept
(
store
.
get
(
dept
.
getParentdeptid
()).
getDept
(),
store
);
}
}
}
@CacheEvict
(
value
=
"ibzou-model"
,
allEntries
=
true
)
public
synchronized
void
refreshModel
()
{
synchronized
(
lockDept
)
{
this
.
deptmap
=
null
;
}
synchronized
(
lockOrg
)
{
this
.
orgmap
=
null
;
}
}
}
ou-core/src/main/java/cn/ibizlab/core/ou/extensions/service/SysUSERServiceImpl.java
0 → 100644
浏览文件 @
f3d0c546
package
cn
.
ibizlab
.
core
.
ou
.
extensions
.
service
;
import
cn.ibizlab.util.domain.IBZUSER
;
import
cn.ibizlab.util.mapper.IBZUSERMapper
;
import
cn.ibizlab.util.service.IBZUSERService
;
import
com.baomidou.mybatisplus.extension.service.impl.ServiceImpl
;
import
org.springframework.stereotype.Service
;
/**
* 实体[IBZUSER] 服务对象接口实现
*/
@Service
(
"userservice"
)
public
class
SysUSERServiceImpl
extends
ServiceImpl
<
IBZUSERMapper
,
IBZUSER
>
implements
IBZUSERService
{
}
\ No newline at end of file
ou-provider/ou-provider-api/src/main/java/cn/ibizlab/api/config/apiSecurityConfig.java
浏览文件 @
f3d0c546
...
...
@@ -106,10 +106,7 @@ public class apiSecurityConfig extends WebSecurityConfigurerAdapter {
"/**/fonts/**"
,
"/**/js/**"
,
"/**/img/**"
,
"/"
,
"webjars/**"
,
"/swagger-resources/**"
,
"/v2/**"
"/"
).
permitAll
()
//放行登录请求
.
antMatchers
(
HttpMethod
.
POST
,
"/"
+
loginPath
).
permitAll
()
...
...
@@ -119,6 +116,11 @@ public class apiSecurityConfig extends WebSecurityConfigurerAdapter {
.
antMatchers
(
"/"
+
downloadpath
+
"/**"
).
permitAll
()
.
antMatchers
(
"/"
+
uploadpath
).
permitAll
()
.
antMatchers
(
"/"
+
previewpath
+
"/**"
).
permitAll
()
//开放组织机构关系查询
.
antMatchers
(
"/ibzemployees/**/oumaps"
).
permitAll
()
.
antMatchers
(
"/ibzorganizations/**/suborg/picker"
).
permitAll
()
.
antMatchers
(
"/dictionarys/**"
).
permitAll
()
// 所有请求都需要认证
.
anyRequest
().
authenticated
()
// 防止iframe 造成跨域
...
...
ou-provider/ou-provider-api/src/main/java/cn/ibizlab/api/rest/extensions/OUCoreResource.java
0 → 100644
浏览文件 @
f3d0c546
此差异已折叠。
点击以展开。
编辑
预览
Markdown
格式
0%
请重试
or
添加新附件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
先完成此消息的编辑!
取消
想要评论请
注册
或
登录