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/546e5/546e5381fb06cbae743dc109078eee90e506799e" 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/a69a3/a69a391137575e7c8cd0628e1c27ccd158028a59" alt="configuring-admin-group-int.png"
Assign admin-group-ext
as a member of this internal group.
data:image/s3,"s3://crabby-images/a4fe3/a4fe32e0f52ac0860d264418777d56a1739b646d" 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/5c969/5c9699e001c673132f76a4da1565654a3fc01fe0" 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/04bc0/04bc0874202a84fbc76b7de23ddc625fb48ec82a" alt="configuring-auth-group.png"
Assign authenticated
as a member of this internal group.
data:image/s3,"s3://crabby-images/e7079/e7079d41f01d68e0608e6b8fc1f5e91061c41c92" alt="auth-group.png"
Your root level groups will now look like:
data:image/s3,"s3://crabby-images/08d55/08d55b5bcacaae0e311ccf27502c43d6a9b46771" 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/7819a/7819a11a3a83952ddc7c095e7ba9a10d89d54243" 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/bf458/bf458e913135324e4a43a392055149326d6b8167" alt="team-a-folder-group-int.png"
Your team-A-folder
groups will now look like:
data:image/s3,"s3://crabby-images/51e18/51e18978d025f934da1cd66172a16d0392f86a4f" 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/f9d3e/f9d3e3f76dde2405f9e70169f73f3257b4821b5c" 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/daf14/daf14e7d197dd4482365ccec1f5a6570117035dc" alt="team-b-folder-group-int.png"
Your team-B-folder
groups will now look like:
data:image/s3,"s3://crabby-images/4ab17/4ab17c8ec159b0a12888e31712af5dc7c6a5e691" 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/b8576/b85769d91ebefa241d89f964ce092650dcc863f1" alt="admin-dashboard.png"
Log in as developer-a1
. Your dashboard will now look like:
data:image/s3,"s3://crabby-images/f12bb/f12bb1d424695a9d64dab6604c103944fa26b1f5" alt="tdeveloper-a1-dashboard.png"
Log in as developer-b1
. Your dashboard will now look like:
data:image/s3,"s3://crabby-images/7a7e3/7a7e34b9537088ffa7f985fce019ecd58d889e95" alt="developer-b1-dashboard.png"