Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
J
jira-sso
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
图表
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
胡帅
jira-sso
Commits
1c179f68
提交
1c179f68
authored
8月 13, 2024
作者:
husishuai
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
新增注释
上级
54fa72fc
显示空白字符变更
内嵌
并排
正在显示
1 个修改的文件
包含
39 行增加
和
5 行删除
+39
-5
SSOSeraphAuthenticator.java
...m/atlassian/jira/security/sso/SSOSeraphAuthenticator.java
+39
-5
没有找到文件。
atlassian-plugins-sso/src/main/java/com/atlassian/jira/security/sso/SSOSeraphAuthenticator.java
浏览文件 @
1c179f68
...
...
@@ -47,12 +47,13 @@ import java.util.*;
public
class
SSOSeraphAuthenticator
extends
DefaultAuthenticator
{
// jira服务中的rest请求地址前缀
private
static
final
String
BASE_URL
=
"http://192.168.1.113:8080/rest/api/2"
;
// 管理员的用户密码拼接后生成的base64加密串。格式: base64(账号:密码)
private
static
final
String
AUTHORIZATION_HEADER
=
"Basic cm9vdDpBZG1pbkAxMjM="
;
// Replace with your base64 encoded auth header
// 本地缓存(客户要求需要加缓存),过期时间为一天
// 本地缓存,过期时间为一天
private
static
final
TimedCache
<
Object
,
Object
>
GROUP_NAME_CACHE
=
CacheUtil
.
newTimedCache
((
60
*
60
*
24
*
1000L
));
// 日志
private
static
final
Logger
log
=
LoggerFactory
.
getLogger
(
SSOSeraphAuthenticator
.
class
);
private
EventPublisher
eventPublisher
;
...
...
@@ -61,8 +62,39 @@ public class SSOSeraphAuthenticator extends DefaultAuthenticator {
public
SSOSeraphAuthenticator
()
{
}
/**
* 登出
* @param httpServletRequest
* @param httpServletResponse
* @return
* @throws AuthenticatorException
*/
@Override
public
boolean
logout
(
HttpServletRequest
httpServletRequest
,
HttpServletResponse
httpServletResponse
)
throws
AuthenticatorException
{
System
.
out
.
println
(
"logout...."
);
return
super
.
logout
(
httpServletRequest
,
httpServletResponse
);
}
/**
* 登录
* @param httpServletRequest
* @param httpServletResponse
* @param username
* @param password
* @param setRememberMeCookie
* @return
* @throws AuthenticatorException
*/
@Override
public
boolean
login
(
HttpServletRequest
httpServletRequest
,
HttpServletResponse
httpServletResponse
,
String
username
,
String
password
,
boolean
setRememberMeCookie
)
throws
AuthenticatorException
{
// 登出时请求的地址 http://ip:port/login.html?isLogout=true
String
isLogout
=
httpServletRequest
.
getParameter
(
"isLogout"
);
System
.
out
.
println
(
"isLogout = "
+
isLogout
);
if
(
isLogout
.
equals
(
"true"
))
{
System
.
out
.
println
(
"开始退出..."
);
this
.
logout
(
httpServletRequest
,
httpServletResponse
);
}
else
{
System
.
out
.
println
(
"开始登录..."
);
// jira请求标识
httpServletRequest
.
setAttribute
(
"com.atlassian.confluence.login.direct"
,
true
);
...
...
@@ -155,6 +187,8 @@ public class SSOSeraphAuthenticator extends DefaultAuthenticator {
// 用户名及密码登录校验
return
this
.
doLogin
(
httpServletRequest
,
httpServletResponse
,
username
,
password
,
setRememberMeCookie
,
false
);
}
}
return
false
;
}
...
...
@@ -397,7 +431,7 @@ public class SSOSeraphAuthenticator extends DefaultAuthenticator {
* 给组添加应用权限
*/
private
void
addGroupApplicationRole
(
String
groupName
)
{
// 获取应用程序授权信息
// 获取应用程序授权信息
(包含原本已授权的信息)
HashMap
<
String
,
List
<
String
>>
applicationRole
=
getApplicationRole
();
System
.
out
.
println
(
"addGroupApplicationRole - applicationRole: "
+
applicationRole
);
List
<
String
>
groups
=
applicationRole
.
get
(
"groups"
);
...
...
@@ -405,7 +439,7 @@ public class SSOSeraphAuthenticator extends DefaultAuthenticator {
if
(!
groups
.
contains
(
groupName
))
{
groups
.
add
(
groupName
);
}
// 原本默认的组信息
List
<
String
>
defaultGroups
=
applicationRole
.
get
(
"defaultGroups"
);
// 创建请求对象
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论