How to Enable Azure AD Self-service and Password Writeback to an On-premises Environment

With Azure Active Directory (Azure AD) self-service password reset (SSPR), users can update their password or unlock their account using a web browser. We recommend this video on How to enable and configure SSPR in Azure AD. In a hybrid environment where Azure AD is connected to an on-premises Active Directory Domain Services (AD DS) environment, this scenario can cause passwords to be different between the two directories.

Password writeback can be used to synchronize password changes in Azure AD back to your on-premises AD DS environment. Azure AD Connect provides a secure mechanism to send these password changes back to an existing on-premises directory from Azure AD.

 Important

This tutorial shows an administrator how to enable self-service password reset back to an on-premises environment. If you’re an end user already registered for self-service password reset and need to get back into your account, go to https://aka.ms/sspr.

If your IT team hasn’t enabled the ability to reset your own password, reach out to your helpdesk for additional assistance.

In this tutorial, you learn how to:

  • Configure the required permissions for password writeback
  • Enable the password writeback option in Azure AD Connect
  • Enable password writeback in Azure AD SSPR

Prerequisites

To complete this tutorial, you need the following resources and privileges:

Configure account permissions for Azure AD Connect

Azure AD Connect lets you synchronize users, groups, and credential between an on-premises AD DS environment and Azure AD. You typically install Azure AD Connect on a Windows Server 2016 or later computer that’s joined to the on-premises AD DS domain.

To correctly work with SSPR writeback, the account specified in Azure AD Connect must have the appropriate permissions and options set. If you’re not sure which account is currently in use, open Azure AD Connect and select the View current configuration option. The account that you need to add permissions to is listed under Synchronized Directories. The following permissions and options must be set on the account:

  • Reset password
  • Write permissions on lockoutTime
  • Write permissions on pwdLastSet
  • Extended rights for “Unexpire Password” on the root object of each domain in that forest, if not already set.

If you don’t assign these permissions, writeback may appear to be configured correctly, but users encounter errors when they manage their on-premises passwords from the cloud. When setting “Unexpire Password” permissions in Active Directory, it must be applied to This object and all descendant objectsThis object only, or All descendant objects, or the “Unexpire Password” permission can’t be displayed.

 Tip

If passwords for some user accounts aren’t written back to the on-premises directory, make sure that inheritance isn’t disabled for the account in the on-prem AD DS environment. Write permissions for passwords must be applied to descendant objects for the feature to work correctly.

To set up the appropriate permissions for password writeback to occur, complete the following steps:

  1. In your on-premises AD DS environment, open Active Directory Users and Computers with an account that has the appropriate domain administrator permissions.
  2. From the View menu, make sure that Advanced features are turned on.
  3. In the left panel, right-select the object that represents the root of the domain and select Properties > Security > Advanced.
  4. From the Permissions tab, select Add.
  5. For Principal, select the account that permissions should be applied to (the account used by Azure AD Connect).
  6. In the Applies to drop-down list, select Descendant User objects.
  7. Under Permissions, select the box for the following option:
    • Reset password
  8. Under Properties, select the boxes for the following options. Scroll through the list to find these options, which may already be set by default:
    • Write lockoutTime
    • Write pwdLastSet
  9. When ready, select Apply / OK to apply the changes.
  10. From the Permissions tab, select Add.
  11. For Principal, select the account that permissions should be applied to (the account used by Azure AD Connect).
  12. In the Applies to drop-down list, select This object and all descendant objects
  13. Under Permissions, select the box for the following option:
    • Unexpire Password
  14. When ready, select Apply / OK to apply the changes and exit any open dialog boxes.

When you update permissions, it might take up to an hour or more for these permissions to replicate to all the objects in your directory.

Password policies in the on-premises AD DS environment may prevent password resets from being correctly processed. For password writeback to work most efficiently, the group policy for Minimum password age must be set to 0. This setting can be found under Computer Configuration > Policies > Windows Settings > Security Settings > Account Policies within gpmc.msc.

If you update the group policy, wait for the updated policy to replicate, or use the gpupdate /force command.

 Note

If you need to allow users to change or reset passwords more than one time per day, Minimum password age must be set to 0. Password writeback will work after on-premises password policies are successfully evaluated.

Enable password writeback in Azure AD Connect

One of the configuration options in Azure AD Connect is for password writeback. When this option is enabled, password change events cause Azure AD Connect to synchronize the updated credentials back to the on-premises AD DS environment.

To enable SSPR writeback, first enable the writeback option in Azure AD Connect. From your Azure AD Connect server, complete the following steps:

  1. Sign in to your Azure AD Connect server and start the Azure AD Connect configuration wizard.
  2. On the Welcome page, select Configure.
  3. On the Additional tasks page, select Customize synchronization options, and then select Next.
  4. On the Connect to Azure AD page, enter a global administrator credential for your Azure tenant, and then select Next.
  5. On the Connect directories and Domain/OU filtering pages, select Next.
  6. On the Optional features page, select the box next to Password writeback and select Next.Configure Azure AD Connect for password writeback
  7. On the Directory extensions page, select Next.
  8. On the Ready to configure page, select Configure and wait for the process to finish.
  9. When you see the configuration finish, select Exit.

Enable password writeback for SSPR

With password writeback enabled in Azure AD Connect, now configure Azure AD SSPR for writeback. SSPR can be configured to writeback through Azure AD Connect sync agents and Azure AD Connect provisioning agents (cloud sync). When you enable SSPR to use password writeback, users who change or reset their password have that updated password synchronized back to the on-premises AD DS environment as well.

To enable password writeback in SSPR, complete the following steps:

  1. Sign in to the Azure portal using a Hybrid Identity Administrator account.
  2. Search for and select Azure Active Directory, select Password reset, then choose On-premises integration.
  3. Check the option for Write back passwords to your on-premises directory .
  4. (optional) If Azure AD Connect provisioning agents are detected, you can additionally check the option for Write back passwords with Azure AD Connect cloud sync.
  5. Check the option for Allow users to unlock accounts without resetting their password to Yes.Configure Azure AD Connect for password writeback
  6. When ready, select Save.

Clean up resources

If you no longer want to use the SSPR writeback functionality you have configured as part of this tutorial, complete the following steps:

  1. Sign in to the Azure portal.
  2. Search for and select Azure Active Directory, select Password reset, then choose On-premises integration.
  3. Uncheck the option for Write back passwords to your on-premises directory.
  4. Uncheck the option for Write back passwords with Azure AD Connect cloud sync.
  5. Uncheck the option for Allow users to unlock accounts without resetting their password.
  6. When ready, select Save.

If you no longer want to use the Azure AD Connect cloud sync for SSPR writeback functionality but want to continue using Azure AD Connect sync agent for writebacks complete the following steps:

  1. Sign in to the Azure portal.
  2. Search for and select Azure Active Directory, select Password reset, then choose On-premises integration.
  3. Uncheck the option for Write back passwords with Azure AD Connect cloud sync.
  4. When ready, select Save.

If you no longer want to use any password functionality, complete the following steps from your Azure AD Connect server:

  1. Sign in to your Azure AD Connect server and start the Azure AD Connect configuration wizard.
  2. On the Welcome page, select Configure.
  3. On the Additional tasks page, select Customize synchronization options, and then select Next.
  4. On the Connect to Azure AD page, enter a global administrator credential for your Azure tenant, and then select Next.
  5. On the Connect directories and Domain/OU filtering pages, select Next.
  6. On the Optional features page, deselect the box next to Password writeback and select Next.
  7. On the Ready to configure page, select Configure and wait for the process to finish.
  8. When you see the configuration finish, select Exit.

 Important

Enabling password writeback for the first time may trigger password change events 656 and 657, even if a password change has not occurred. This is because all password hashes are re-synchronized after a password hash synchronization cycle has run.

Next steps

In this tutorial, you enabled Azure AD SSPR writeback to an on-premises AD DS environment. You learned how to:

  • Configure the required permissions for password writeback
  • Enable the password writeback option in Azure AD Connect
  • Enable password writeback in Azure AD SSPR

Ref: https://learn.microsoft.com/en-us/azure/active-directory/authentication/tutorial-enable-sspr-writeback