我想访问用户角色/角色,在Jenkins2管道(工作流)中的角色策略插件中配置:
node {
// Get the user Role
}
import jenkins.model.Jenkins
import com.michelin.cio.hudson.plugins.rolestrategy.RoleBasedAuthorizationStrategy
import com.michelin.cio.hudson.plugins.rolestrategy.Role
node {
stage('Get Role') {
def user = Jenkins.getInstance().getUser(
Jenkins.getInstance().getItemByFullName(env.JOB_BASE_NAME, Job.class).getBuildByNumber(env.BUILD_ID as int).getCause(Cause.UserIdCause).getUserId()
)
def authorization = Jenkins.getInstance().getAuthorizationStrategy()
//RoleBasedAuthorizationStrategy.{GLOBAL, PROJECT, SLAVE, MACRO_ROLE, MACRO_USER}
def grantedRoles = authorization.getGrantedRoles(RoleBasedAuthorizationStrategy.GLOBAL)
for (Role grantedRole : grantedRoles.entrySet()) {
if (grantedRole.getValue().contains(user.getId())) {
echo grantedRole.getKey().getName()
}
}
}
}