Incorrect permission checks in Jenkins Role-based Authorization Strategy Plugin may allow accessing some items
Moderate severity
GitHub Reviewed
Published
May 24, 2022
to the GitHub Advisory Database
•
Updated Dec 20, 2023
Package
Affected versions
<= 3.1
Patched versions
3.1.1
Description
Published by the National Vulnerability Database
Mar 18, 2021
Published to the GitHub Advisory Database
May 24, 2022
Reviewed
Dec 14, 2022
Last updated
Dec 20, 2023
Items (like jobs) can be organized hierarchically in Jenkins, using the Folders Plugin or something similar. An item is expected to be accessible only if all its ancestors are accessible as well.
Role-based Authorization Strategy Plugin 3.1 and earlier does not correctly perform permission checks to determine whether an item should be accessible.
This allows attackers with Item/Read permission on nested items to access them, even if they lack Item/Read permission for parent folders.
Role-based Authorization Strategy Plugin 3.1.1 requires Item/Read permission on parent items to grant Item/Read permission on an individual item.
As a workaround in older releases, do not grant permissions on individual items to users who do not have access to parent items.
In case of problems, the Java system property
com.michelin.cio.hudson.plugins.rolestrategy.RoleMap.checkParentPermissions
can be set to false, completely disabling this fix.References