Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
FIY695
jenkins
提交
c1b60f18
J
jenkins
项目概览
FIY695
/
jenkins
与 Fork 源项目一致
从无法访问的项目Fork
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
J
jenkins
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
c1b60f18
编写于
8月 16, 2015
作者:
D
Daniel Beck
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #1796 from jtnord/jenkins-29936
[JENKINS-29936] when removing an item use ACL.SYSTEM.
上级
6bfbe0c7
8a077a80
变更
1
显示空白变更内容
内联
并排
Showing
1 changed file
with
23 addition
and
6 deletion
+23
-6
core/src/main/java/hudson/diagnosis/OldDataMonitor.java
core/src/main/java/hudson/diagnosis/OldDataMonitor.java
+23
-6
未找到文件。
core/src/main/java/hudson/diagnosis/OldDataMonitor.java
浏览文件 @
c1b60f18
...
...
@@ -25,6 +25,7 @@ package hudson.diagnosis;
import
com.google.common.base.Predicate
;
import
com.thoughtworks.xstream.converters.UnmarshallingContext
;
import
hudson.Extension
;
import
hudson.XmlFile
;
import
hudson.model.AdministrativeMonitor
;
...
...
@@ -36,8 +37,10 @@ import hudson.model.Saveable;
import
hudson.model.listeners.ItemListener
;
import
hudson.model.listeners.RunListener
;
import
hudson.model.listeners.SaveableListener
;
import
hudson.security.ACL
;
import
hudson.util.RobustReflectionConverter
;
import
hudson.util.VersionNumber
;
import
java.io.IOException
;
import
java.util.ArrayList
;
import
java.util.Collection
;
...
...
@@ -48,8 +51,13 @@ import java.util.Map;
import
java.util.TreeSet
;
import
java.util.logging.Level
;
import
java.util.logging.Logger
;
import
javax.annotation.CheckForNull
;
import
jenkins.model.Jenkins
;
import
org.acegisecurity.context.SecurityContext
;
import
org.acegisecurity.context.SecurityContextHolder
;
import
org.kohsuke.stapler.HttpRedirect
;
import
org.kohsuke.stapler.HttpResponse
;
import
org.kohsuke.stapler.HttpResponses
;
...
...
@@ -102,7 +110,11 @@ public class OldDataMonitor extends AdministrativeMonitor {
}
private
static
void
remove
(
Saveable
obj
,
boolean
isDelete
)
{
OldDataMonitor
odm
=
get
(
Jenkins
.
getInstance
());
Jenkins
j
=
Jenkins
.
getInstance
();
if
(
j
!=
null
)
{
OldDataMonitor
odm
=
get
(
j
);
SecurityContext
oldContext
=
ACL
.
impersonate
(
ACL
.
SYSTEM
);
try
{
synchronized
(
odm
)
{
odm
.
data
.
remove
(
referTo
(
obj
));
if
(
isDelete
&&
obj
instanceof
Job
<?,?>)
...
...
@@ -110,6 +122,11 @@ public class OldDataMonitor extends AdministrativeMonitor {
odm
.
data
.
remove
(
referTo
(
r
));
}
}
finally
{
SecurityContextHolder
.
setContext
(
oldContext
);
}
}
}
// Listeners to remove data here if resaved or deleted in regular Hudson usage
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录