我正在编写一个Jenkins插件,它增加了在某些情况下限制用户访问的权限。我目前有一个错误,当用户使用升级的builds插件促进构建时,插件不能像预期的那样工作。
我有两个用户(devuser,adminuser)和两个作业(作业-a,作业-b)。开发者首先构建作业-a。然后adminuser促进作业-a触发一个作业-b的构建。
当通过晋升触发作业-b时,我试图确定是谁执行了晋升。如果我查看抽象构建的原因,原因是空的,原因有一个UpstreamCause,它是devuser,而不是adminuser。
我怎样才能确定是谁引发了这次升职?如果我查看UI中的晋升,我可以看到管理员触发了晋升。我不知道如何才能在Jenkins插件中获得已执行的升级列表。
谢谢!
发布于 2016-05-12 16:30:29
虽然不是十全十美,但我想出了一个解决问题的办法。
在计划升级生成时,我会跟踪升级所属的生成,以及触发升级的用户。
if (build.getClass() == Promotion.class) {
Promotion promotion = (Promotion) build;
RECENTLY_PROMOTED.put(getBuildId(promotion.getRootBuild()), promotion.getUserName());
return new User(promotion.getUserName());
}在调度下游作业时,我检查最近提升的构建id,并获取用户。
UpstreamCause upstreamCause = (UpstreamCause) cause;
String upstreamBuildId = String.format("%s#%s", upstreamCause.getUpstreamProject(), upstreamCause.getUpstreamBuild());
if (RECENTLY_PROMOTED.containsKey(upstreamBuildId)) {
String promotedUser = RECENTLY_PROMOTED.get(upstreamBuildId);
RECENTLY_PROMOTED.remove(upstreamBuildId);
return new User(promotedUser);
}https://stackoverflow.com/questions/37147525
复制相似问题