Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
J
jira-sso
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
图表
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
胡帅
jira-sso
Commits
231cc987
提交
231cc987
authored
7月 29, 2024
作者:
husishuai
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
init
上级
5b198ff5
显示空白字符变更
内嵌
并排
正在显示
1 个修改的文件
包含
24 行增加
和
26 行删除
+24
-26
SSOSeraphAuthenticator.java
...m/atlassian/jira/security/sso/SSOSeraphAuthenticator.java
+24
-26
没有找到文件。
atlassian-plugins-sso/src/main/java/com/atlassian/jira/security/sso/SSOSeraphAuthenticator.java
浏览文件 @
231cc987
...
@@ -6,6 +6,8 @@ package com.atlassian.jira.security.sso;
...
@@ -6,6 +6,8 @@ package com.atlassian.jira.security.sso;
* @createTime 2024年02月22日
* @createTime 2024年02月22日
*/
*/
import
cn.hutool.cache.CacheUtil
;
import
cn.hutool.cache.impl.TimedCache
;
import
cn.hutool.core.text.CharSequenceUtil
;
import
cn.hutool.core.text.CharSequenceUtil
;
import
cn.hutool.http.HttpRequest
;
import
cn.hutool.http.HttpRequest
;
import
cn.hutool.http.HttpResponse
;
import
cn.hutool.http.HttpResponse
;
...
@@ -46,9 +48,9 @@ public class SSOSeraphAuthenticator extends DefaultAuthenticator {
...
@@ -46,9 +48,9 @@ public class SSOSeraphAuthenticator extends DefaultAuthenticator {
private
static
final
String
BASE_URL
=
"http://192.168.1.113:8080/rest/api/2"
;
private
static
final
String
BASE_URL
=
"http://192.168.1.113:8080/rest/api/2"
;
private
static
final
String
AUTHORIZATION_HEADER
=
"Basic cm9vdDpBZG1pbkAxMjM="
;
// Replace with your base64 encoded auth header
private
static
final
String
AUTHORIZATION_HEADER
=
"Basic cm9vdDpBZG1pbkAxMjM="
;
// Replace with your base64 encoded auth header
private
static
final
Logger
log
=
LoggerFactory
.
getLogger
(
SSOSeraphAuthenticator
.
class
);
private
static
final
TimedCache
<
Object
,
Object
>
GROUP_NAME_CACHE
=
CacheUtil
.
newTimedCache
(
120000
);
private
static
final
HashMap
<
String
,
Object
>
localGroupCache
=
new
HashMap
<>(
);
private
static
final
Logger
log
=
LoggerFactory
.
getLogger
(
SSOSeraphAuthenticator
.
class
);
private
EventPublisher
eventPublisher
;
private
EventPublisher
eventPublisher
;
//private UserAccessor userAccessor;
//private UserAccessor userAccessor;
...
@@ -76,16 +78,15 @@ public class SSOSeraphAuthenticator extends DefaultAuthenticator {
...
@@ -76,16 +78,15 @@ public class SSOSeraphAuthenticator extends DefaultAuthenticator {
// }
// }
// 3. 判断:用户是否走了登录页进行登录(保证原有登录页可以正常登录)
// 如果是空,则表示未走登录页。那么从auap中获取用户名称
if
(
CharSequenceUtil
.
isBlank
(
username
)
&&
CharSequenceUtil
.
isBlank
(
password
))
{
// 3.1 获取:用户、组信息
HashMap
<
String
,
Object
>
auapUserInfo
=
new
HashMap
<>();
HashMap
<
String
,
Object
>
auapUserInfo
=
new
HashMap
<>();
auapUserInfo
.
put
(
"username"
,
"zhangsan"
);
auapUserInfo
.
put
(
"username"
,
"zhangsan"
);
auapUserInfo
.
put
(
"staTruename"
,
"张三"
);
auapUserInfo
.
put
(
"staTruename"
,
"张三"
);
auapUserInfo
.
put
(
"deptId"
,
"1813"
);
auapUserInfo
.
put
(
"deptId"
,
"1813"
);
// jira-software-usersping
auapUserInfo
.
put
(
"deptName"
,
"分公司一-七组"
);
auapUserInfo
.
put
(
"deptName"
,
"分公司一-七组"
);
// 3. 判断:用户是否走了登录页进行登录
// 如果是空,则表示未走登录页。那么从auap中获取用户名称
if
(
CharSequenceUtil
.
isBlank
(
username
)
&&
CharSequenceUtil
.
isBlank
(
password
))
{
// auap账号名称
// auap账号名称
username
=
auapUserInfo
.
get
(
"username"
).
toString
();
username
=
auapUserInfo
.
get
(
"username"
).
toString
();
// 昵称
// 昵称
...
@@ -97,34 +98,31 @@ public class SSOSeraphAuthenticator extends DefaultAuthenticator {
...
@@ -97,34 +98,31 @@ public class SSOSeraphAuthenticator extends DefaultAuthenticator {
// 创建组名称
// 创建组名称
String
groupName
=
deptName
+
"-"
+
deptId
;
String
groupName
=
deptName
+
"-"
+
deptId
;
try
{
// 3.2 查询用户是否存在(不存在则创建)
// 获取用户对象
// 获取用户对象
Principal
user
=
this
.
getUser
(
username
);
Principal
user
=
this
.
getUser
(
username
);
try
{
// 如果用户不存在,则创建用户
// 如果用户不存在,则创建用户
if
(
ObjectUtils
.
isEmpty
(
user
))
{
if
(
ObjectUtils
.
isEmpty
(
user
))
{
// 判断缓存中是否存在用户组
System
.
out
.
println
(
"系统中不存在用户 = "
+
username
);
// if (localGroupCache.containsKey(groupName)) {
// 3.3 判断是否存在组
//
// }else {
//
// }
// 判断是否存在组
GroupManager
groupManager
=
ComponentAccessor
.
getGroupManager
();
GroupManager
groupManager
=
ComponentAccessor
.
getGroupManager
();
// 判断缓存中是否存在用户组
if
(!
GROUP_NAME_CACHE
.
containsKey
(
groupName
))
{
System
.
out
.
println
(
"缓存中不存在组 = "
+
groupName
);
boolean
groupExists
=
groupManager
.
groupExists
(
groupName
);
boolean
groupExists
=
groupManager
.
groupExists
(
groupName
);
System
.
out
.
println
(
"groupExists before = "
+
groupExists
);
// 不存在则创建组
// 不存在则创建
if
(!
groupExists
)
{
if
(!
groupExists
)
{
System
.
out
.
println
(
"系统中不存在组 = "
+
groupName
);
groupManager
.
createGroup
(
groupName
);
groupManager
.
createGroup
(
groupName
);
System
.
out
.
println
(
"groupExists after = "
+
groupManager
.
groupExists
(
groupName
));
// 给组授予应用程序访问权,否则无法登陆(调用rest api实现)
// 给组授予应用程序访问权
addGroupApplicationRole
(
groupName
);
addGroupApplicationRole
(
groupName
);
// 给组授权
// PermissionManager permissionManager = ComponentAccessor.getPermissionManager();
// Collection<ProjectPermission> allProjectPermissions = permissionManager.getAllProjectPermissions();
}
}
// 将组添加至缓存
GROUP_NAME_CACHE
.
put
(
groupName
,
groupName
);
}
// 新增用户
// 新增用户
UserManager
userManager
=
getUserManager
();
UserManager
userManager
=
getUserManager
();
UserDetails
userDetails
=
new
UserDetails
(
username
,
userFullName
).
withPassword
(
"123456"
).
withEmail
(
username
+
"@test.com"
);
UserDetails
userDetails
=
new
UserDetails
(
username
,
userFullName
).
withPassword
(
"123456"
).
withEmail
(
username
+
"@test.com"
);
...
@@ -387,7 +385,7 @@ public class SSOSeraphAuthenticator extends DefaultAuthenticator {
...
@@ -387,7 +385,7 @@ public class SSOSeraphAuthenticator extends DefaultAuthenticator {
* 给组添加应用权限
* 给组添加应用权限
*/
*/
private
void
addGroupApplicationRole
(
String
groupName
)
{
private
void
addGroupApplicationRole
(
String
groupName
)
{
// 获取应用程序授权
纤细
// 获取应用程序授权
信息
HashMap
<
String
,
List
<
String
>>
applicationRole
=
getApplicationRole
();
HashMap
<
String
,
List
<
String
>>
applicationRole
=
getApplicationRole
();
System
.
out
.
println
(
"addGroupApplicationRole - applicationRole: "
+
applicationRole
);
System
.
out
.
println
(
"addGroupApplicationRole - applicationRole: "
+
applicationRole
);
List
<
String
>
groups
=
applicationRole
.
get
(
"groups"
);
List
<
String
>
groups
=
applicationRole
.
get
(
"groups"
);
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论