Created on
‎03-08-2021
11:57 PM
Edited on
‎07-10-2024
06:20 AM
By
Jean-Philippe_P
Description
This article provides basic guidelines and verification steps for setting up the following functionality with Active Directory.
FortiGate is able to process an expired password renewal for LDAP users during the user's login (e.g. with SSL-VPN).
Disclaimer:
The LDAP renewal method is designed to replace (reset) the user password, meaning the Active Directory password policy will not be enforced. For example, users may reuse the same password or use old ones.
Alternatively, use RADIUS authentication with password-renewal instead of LDAP, which will follow the password policy.
For limitations on LDAP and detailed guidance, contact Microsoft support.
Scope
Standard LDAP authentication is already configured and functional (except for the password renewal feature).
The section describing configuration changes within Active Directory is for informational purposes only.
It was tested with a default domain configuration in a domain running on Windows Server 2016.
If there are issues with setting or verifying the password reset delegation, refer to the Windows/Active Directory support contact, as troubleshooting Active Directory configurations is out of the scope of Fortinet TAC.
Solution
- Delegate the password reset rights for the LDAP account used by the FortiGate in Active Directory.
- Open Active Directory Users and Computers (aka ADUC, aka dsa.msc).
Navigate to the Organizational Unit (OU) that contains the users, select it, and select the option 'Delegate Control...'.
Note.
The password reset rights will apply only to users in the selected OU).
data:image/s3,"s3://crabby-images/a4798/a4798407b5b59410932388a326c2a76d37fc9c1f" alt=""
- The Delegation Control Wizard will open, press 'Next'.
On the 'Users and Groups' screen, select 'Add', and then add the LDAP account used by the FortiGate, or a group it belongs to, confirm with 'OK', and then select 'Next'.
- On the 'Tasks to Delegate' screen, select the option 'Reset user passwords and force password change at next logon' and then select 'Next'.
- On the final screen, select 'Finish' to apply the change.
-
Verify that the password reset delegation is functional.
The below method is only one example of such verification.
Other methods can be used as well, as long as they demonstrate the ability of the FortiGate's LDAP account to reset user passwords.
- Obtain the full distinguished name of a test user. In this example: 'CN=John Doe,OU=usr,DC=testdomain,DC=lab'.
- Start Powershell with the credentials of the FortiGate LDAP account (do not use the currently logged-in user, or another account, otherwise the results will not be representative).
- Run the following commands to attempt a password change:
$test = [adsi]"LDAP://CN=John Doe,OU=usr,DC=testdomain,DC=lab"
$test.psbase.invoke("SetPassword","NewPassword1234#")
$test.psbase.CommitChanges()Exception calling 'Invoke' with '2' argument(s): 'Access is denied. (Exception from HRESULT: 0x80070005(E_ACCESSDENIED))'.
- Enable the password renewal functionality for the LDAP server (CLI only):
edit "testdomain"
set server "10.109.51.52"
set cnid "sAMAccountName"
set dn "dc=testdomain,dc=lab"
set type regular
set username "TESTDOMAIN\\fortigate-ldap"
set password ENC ###
set secure ldaps # <-- Mandatory: Active Directory requires secure LDAP over TLS for password change action.
set port 636
set password-renewal enable
next
end
Perform a test LDAP authentication attempt with an LDAP account that has an already expired password.
The syntax of the test command is as follows:
If the delegation was configured correctly, enter a new password twice for confirmation, and then the CLI should print a confirmation line followed by the group membership of the user that was returned by the LDAP server.
Confirm Password:********
authenticate 'jdoe' against 'testdomain' succeeded!
Group membership(s) - CN=Domain Users,CN=Users,DC=testdomain,DC=lab
Confirm Password:**********
authenticate 'jdoe' against 'testdomain' failed!
If for any reason the user needs to remove the password reset rights, follow these steps:
- 'Open Active Directory Users and Computers', select the relevant OU, and then select 'Properties'.
- In the Security tab, select the FortiGate LDAP account in the list, select the 'Remove' button, and finally confirm the change with 'OK'.
data:image/s3,"s3://crabby-images/bdd1e/bdd1e833a42a3951fa438696dd1477f095cda75d" alt=""