All product names, logos, and brands used in this post are property of their respective owners.
This post is yet another about Azure AD and setting attributes on accounts. I recently worked on performance tuning a PowerShell script that was designed to set attribute values on Azure AD accounts in bulk. The script used a combination of the Set-AzureADUser
and Set-AzureADUserExtension
cmdlets to achieve that, which doubled the number of Graph API calls and ultimately doubled the execution time of the script.
As it turns out, the Set-AzureADUserExtension
cmdlet can set any attribute that Set-AzureADUser
can (or at least the ones I was interested in). With that in mind, I opted to combine the commands into a single instance of Set-AzureADUserExtension
and use the -ExtensionNameValues
parameter (which accepts a “dictionary of strings” or Dictionary<TKey,TValue> Class variable). The documentation for -ExtensionNameValues
lacks an example, and the Dictionary<TKey,TValue>[System.String,System.String] type was not immediately obvious to me, but I muscled through it and derived the following:
-
Install the Azure AD PowerShell module and authenticate:
Install-Module AzureAD Connect-AzureAD
-
Create a dictionary of strings to store the attribute/value pairs:
$setAzureADUserExtensionValues = New-Object 'System.Collections.Generic.Dictionary[String,String]'
-
Add attribute/value pairs to the dictionary:
Note that the first value in each pair is the name of the Azure AD account attribute and the second pair is the desired value of the attribute.$setAzureADUserExtensionValues.Add("CompanyName", "E Corp") $setAzureADUserExtensionValues.Add("JobTitle", "CEO") $setAzureADUserExtensionValues.Add("GivenName", "Phillip") $setAzureADUserExtensionValues.Add("Surname", "Price") $setAzureADUserExtensionValues.Add("DisplayName", "Phillip Price") $setAzureADUserExtensionValues.Add("PhysicalDeliveryOfficeName", "135 East 57th Street") $setAzureADUserExtensionValues.Add("extensionAttribute10", "CW892451")
-
Finally, set the attributes on an Azure AD account:
Set-AzureADUserExtension -ObjectID 32ac1405-ee40-4eff-ac14-6ddd9ae99a9b -ExtensionNameValues $setAzureADUserExtensionValues
Pump users and values through that in a loop, and you can update most (all?) attributes on an Azure AD account (including Guest and B2B users) with a single cmdlet. I hope this helps someone looking to achieve a similar result.