Intro
After creating my domain trust between AD and FreeIPA, I was left wanting to access restricted resources in Linux using my AD accounts. To circumvent this, I mapped a group from AD to FreeIPA and gave it the appropriate permissions.
Create the group in AD
The first step would be to create a group in AD to which sudo will be mapped. In my case, I created a group named ‘sudo’ to match the Linux counterpart. To do this, navigate to Server Manager -> Active Directory Users and Computers -> Users. Then, right-click and go to New -> Group. In the name, type ‘sudo’. After the item is created, it should look like:
data:image/s3,"s3://crabby-images/a2cac/a2cac9a91f843657e95657df00f85a1f1c6f3220" alt="sudo group in AD"
Create policies
Navigate to Policy -> Sudo -> Sudo Rules. Here, you can create a new rule or directly use the ‘All’ rule. In my case, I created a rule titled ‘sudorule’.
data:image/s3,"s3://crabby-images/42e96/42e96b41df8b1293af57a3f782dde3b14e5c794e" alt="sudorule in FreeIPA"
To allow commands, navigate to ‘Run Commands’ and click ‘Any Command’. This will essentially make users root (very dangerous). It should look something like:
data:image/s3,"s3://crabby-images/219f5/219f502f1661a0f722987c4dacad491b05ffe1d7" alt="allow any command"
Add the external group to the sudo rule
Connect to your FreeIPA server as an admin. Then issue the command
ipa sudorule-add-user sudorule --groups '[email protected]'
This will map the external AD group to the sudo rule you just created. Navigate to the FreeIPA web interface under Policy -> Sudo -> Sudo Rules -> sudorule and It should look like:
data:image/s3,"s3://crabby-images/1c556/1c556cf3b9319dbd98d9d816782c68fef5a38a1b" alt="external group in sudorule"
Done!
Once everything is set-up, members of this group should be limited/allowed to elements and commands as defined by the policies set in place.