-
Notifications
You must be signed in to change notification settings - Fork 166
Prerequisites
github-actions edited this page May 25, 2021
·
14 revisions
- Create the Service Principal
- Assign the permissions at the required scope (/)
- Assign the Directory role permissions
The PowerShell snippets provided below simplify this process. You may need to elevate your access in Azure before being able to create a root scoped assignment.
Please check if the Az and AzureAD modules are installed locally before executing these scripts. Alternatively, these command can be run within a Cloud Shell instance.
#
# Install module
#
Install-Module -Name Az
#
# Connect to Azure
#
Connect-AzAccount
#
# Create Service Principal and assign
# 'Owner' role to tenant root scope '/'
#
$servicePrincipal = New-AzADServicePrincipal -Role Owner -Scope / -DisplayName AzOps
#
# Display the generated Service Principal
#
Write-Host "ARM_TENANT_ID: $((Get-AzContext).Tenant.Id)"
Write-Host "ARM_SUBSCRIPTION_ID: $((Get-AzContext).Subscription.Id)"
Write-Host "ARM_CLIENT_ID: $($servicePrincipal.ApplicationId)"
Write-Host "ARM_CLIENT_SECRET: $($servicePrincipal.Secret))"
#
# Install module
# If not installed
#
Install-Module -Name AzureAD
#
# Connect to Azure Active Directory
#
Connect-AzureAD
#
# Get Service Principal from Azure AD
#
$servicePrincipal = Get-AzureADServicePrincipal -Filter "DisplayName eq 'AzOps'"
#
# Assign Azure AD Directory Role
#
$directoryRole = Get-AzureADDirectoryRole -Filter "DisplayName eq 'Directory Readers'"
if ($directoryRole -eq $null) {
Write-Warning "Directory Reader role not found"
}
else {
Add-AzureADDirectoryRoleMember -ObjectId $directoryRole.ObjectId -RefObjectId $servicePrincipal.ObjectId
}
If you receiving the warning message "Directory Reader role not found." this usually occurs when the role has not yet been used in your directory. As a workaround, try assigning this role manually to the AzOps App in the Azure portal