Issue
-
You want to limit folder access to specific groups using the Role-Based Access Control plugin
-
You have multiple groups that should only have access to their own folder
Resolution
You have the following groups imported from LDAP/AD or Mock Security Realm on your Jenkins instance. You also have two folders called team-A-folder
and team-B-folder
along with a Freestyle project called root-folder-job
at the root Jenkins level.
| ------------ | ---------------- | | **User** | **Group** | | admin | admin-group-ext | | developer-a1 | team-A-group-ext | | developer-b1 | team-B-group-ext |
1. Allow admin users access to the full folder structure
Navigate to Roles->Manage
from the root Jenkins dashboard. Create an admin
role with the Overall/Administer
permission. Click Save
.
data:image/s3,"s3://crabby-images/e20df/e20df728d0697839a6e4a1d7c02a223621febdb8" alt="admin-manage-roles.png"
Navigate to Groups->New Group
from the root Jenkins dashboard. Name the group admin-group-int
and click OK
to create a group internal to Jenkins for role assignment. Check the Granted
checkbox for the admin
role, leave Propagates
checked, and click Save
.
data:image/s3,"s3://crabby-images/dde3e/dde3ea91488412af2e7e5c64fabe73b57ec158ca" alt="configuring-admin-group-int.png"
Assign admin-group-ext
as a member of this internal group.
data:image/s3,"s3://crabby-images/45d62/45d626ceb82b1bce2f75724917890268d97f76a9" alt="admin-group-int.png"
2. Allow read access to the root folder for all authenticated users, but restrict their view to only items which they have been given explicit permission to see
Navigate to Roles->Manage
from the root Jenkins dashboard. Create a read
role with the Overall/Read
and the Job/Read
permission. Remove all permissions from the authenticated
role. Click Save
.
data:image/s3,"s3://crabby-images/85b6a/85b6aa8f7f020623f1c58c7b82934a9899bf0298" alt="read-manage-roles.png"
Navigate to Groups->New Group
from the root Jenkins dashboard. Name the group auth-group
and click OK
. Check the Granted
checkbox for the read
role, uncheck the Propagates
checkbox, and click Save
.
data:image/s3,"s3://crabby-images/c555c/c555ce8b716da80ddd3ea4fcfa37bef333398afa" alt="configuring-auth-group.png"
Assign authenticated
as a member of this internal group.
data:image/s3,"s3://crabby-images/8ab97/8ab97ae49676cfefab8b0b88194c22e06a51fedf" alt="auth-group.png"
Your root level groups will now look like:
data:image/s3,"s3://crabby-images/e315b/e315bf779e371eef73829ea1a753d71ce818eba4" alt="root-groups.png"
3. Give team-A-group-ext
access to the team-A-folder
Navigate to Groups->New Group
from within the team-A-folder
. Name the group team-A-folder-group-int
and click OK
. Check the Granted
checkbox for the read
role, leave Propagates
checked, and click Save
.
data:image/s3,"s3://crabby-images/fc3ea/fc3ea7986a6e5609802b6fcf2a08e26895db957e" alt="configuring-team-a-folder-group-int.png"
Assign team-A-group-ext
as a member of this internal group.
data:image/s3,"s3://crabby-images/b850f/b850f209412c71649c4c5f9486e21d43b614536c" alt="team-a-folder-group-int.png"
Your team-A-folder
groups will now look like:
data:image/s3,"s3://crabby-images/7f61c/7f61c6dbf5c0bcf8e889ebb121adb98cdceebeff" alt="team-a-folder-groups.png"
4. Give team-B-group-ext
access to the team-B-folder
Navigate to Groups->New Group
from within the team-B-folder
. Name the group team-B-folder-group-int
and click OK
. Check the Granted
checkbox for the read
role, leave Propagates
checked, and click Save
.
data:image/s3,"s3://crabby-images/7a47c/7a47c4a7fca9e585000f5bb73a21a3fe51e60049" alt="configuring-team-b-folder-group-int.png"
Assign team-B-group-ext
as a member of this internal group.
data:image/s3,"s3://crabby-images/f0871/f0871ff0569535248a051788e73d7ebb7341107c" alt="team-b-folder-group-int.png"
Your team-B-folder
groups will now look like:
data:image/s3,"s3://crabby-images/f3c0f/f3c0f0980664539e61b9c5cd70798d6f9db5993b" alt="team-b-folder-groups.png"
5. Verify folder permissions
Log in as admin
. Your dashboard will now look like:
data:image/s3,"s3://crabby-images/b2309/b23096e1ab1900d129952b496822e40d2eaedd8b" alt="admin-dashboard.png"
Log in as developer-a1
. Your dashboard will now look like:
data:image/s3,"s3://crabby-images/c4819/c48190018ddcb1c333c269fd2f834bc4f127ce7f" alt="tdeveloper-a1-dashboard.png"
Log in as developer-b1
. Your dashboard will now look like:
data:image/s3,"s3://crabby-images/dca00/dca0054b7bfd1c6021dd9b1e1fe274154cb7ac95" alt="developer-b1-dashboard.png"