I am using PHP with LDAP to manage some aspects of user accounts within Active Directory. One of the things I needed to do was to reset the accounts of users who had incorrectly entered their password too many times. Initially I thought that the ‘useraccountcontrol’ field was what I needed as this is used to disable an account. However I then realised that locked accounts are a different field (locktimeout) and have a different tickbox in the Active Directory GUI:
data:image/s3,"s3://crabby-images/adf9a/adf9aea39c89ddb1a98b93c0ec33c33120dc6f06" alt="Selection_077"
I tested it by locking an account out see below:
data:image/s3,"s3://crabby-images/dc688/dc6888fa389b175c1993b9dbe7ed8b6b3c581d87" alt="Active Directory Account Locked Disabled"
And checking the LDAP values of the locked out account I see that the field ‘lockouttime’ is set as follows:
data:image/s3,"s3://crabby-images/558d6/558d63c1324e79522e425b6390822143fcdb28ec" alt="Selection_078"
So in my PHP I just needed to check whether lockouttime exists / is_numeric and unlock it by setting it to zero using ldap_mod_replace.
data:image/s3,"s3://crabby-images/29686/2968604344f7d250002115dabd7209e22adadc24" alt="PHP LDAP Modify"