data:image/s3,"s3://crabby-images/db6f0/db6f0d95afb6b7132dc0e5eff50faf2e6b1c6af4" alt=""
During a running project, we were facing a problem with a provisioning of an AzureAD-User and his mailbox. During first Dir-Sync user got a provisioning error and could not be modified or used. We have removed the On-Prem AD user object, in hope that we can simply restore the use in the cloud. After we have deleted On-Prem User object, our Cloud-Object were just stuck in the cloud is was waiting for a successful synchronization for a very long time. So we have created a new user with another UPN and Email-Address, but the old E-mail address was still in use. So we needed to release the old E-mail address from the broken Cloud-Object and add it to the new “Hybrid-User”
In this article I am going to explain:
- How to change ImmutableID for a directory synchronized user
- How to resolve synchronization conflict
Page navigation
What is ImmutableID?
ImmutableID is an attribute on an AzureAD-User, or MSOL-User. This attribute is an unique identifier to match an On-Premise ADUser with a AzureAD user.
data:image/s3,"s3://crabby-images/1c9e0/1c9e0c17d9eaea098f62154a601ad8f8edaa7ee3" alt=""
Standard configuration of AzureAD-Connect is using immutableID as a source anchor attribute to match Cloud and Local identity.
How is immutableID generated?
ImmutableID is a “Base64” encoded identity of local objectGUID of an ADUser-object.
data:image/s3,"s3://crabby-images/51218/5121876bb7d6fa5bf7cefdf56fb4184b6e93a669" alt=""
So ImmutableID is simply the On-Prem objectGUID of an ADUser.
#ObjectGUID to ImmutableID
$aduser = Get-ADUser UserForestDemouser76 -Properties *
$immutableid = [Convert]::ToBase64String([guid]::New($aduser.ObjectGUID).ToByteArray())
data:image/s3,"s3://crabby-images/58e03/58e03f4aafe061277b741a8f65132188446df8f0" alt=""
mS-DS-ConsistancyGUID is the On-Prem Counterpart for ImmutableID and is also generated from ADUser objectGUID
#ObjectGUID to ms-DS-ConsistancyGUID
$aduser = Get-ADUser UserForestDemouser76 -Properties *
$msdsconsistancyguid = $aduser.ObjectGUID.ToByteArray()
data:image/s3,"s3://crabby-images/0cbe2/0cbe26b2f6c85ad2c67fc437536d6bd2cc2fc203" alt=""
How to change ImmutableID?
1. Login to you tenant with Global Administrator permissions, by using Connect-AzureAD command which is a part of AzureAD powershell module
If you are using a PIM role like User-Administrator you will get this error.
data:image/s3,"s3://crabby-images/39823/3982301c172656ee15f7dbff7a2d7a6f0286529f" alt=""
So you simply need Global Administrator permissions and not a PIM role.
2. Change UPN of your Cloud-User-Object to a *.microsoftonline.com (only for federated users)
data:image/s3,"s3://crabby-images/1af67/1af6751dfea9f39de4ac24dae62eafbe1d9228c8" alt=""
Get-MsolUser -UserPrincipalName UserForest.Demouser76@onpremto.cloud |Set-MsolUser -UserPrincipalName 'UserForest.Demouser76@fromonpremtocloud.onmicrosoft.com'
3. Use Set-ADUser -ImmutableID command to change ImmutableID
data:image/s3,"s3://crabby-images/29c82/29c82386f42afea0136338bee4abd088eea8b3df" alt=""
How to resolve synchronization conflict?
data:image/s3,"s3://crabby-images/f41d2/f41d220f3c69a6830ee46e67f78615e099c52f3e" alt=""
1. Generate immutableID from the right objectGUID as mentioned above.
2. Connect to AzureAD with Global Administrator permissions
3. Change the immutableID by running Set-AzureADUser -immutableID command
Get-AzureADUser -SearchString 'UserForest.Demouser76' | Set-AzureADUser -ImmutableId $immutableid
data:image/s3,"s3://crabby-images/82628/826287cbbfae3028239f93e7829525ff2baddcbb" alt=""
ImmutableID is now recovered and you can
Start-AADSyncCycle -policytype Delta
Comments