L’utilisateur doit modifier le mot de passe à la prochaine ouverture de session (fournisseur LDAP)
Pour forcer un utilisateur à modifier son mot de passe lors de la prochaine ouverture de session, définissez l’attribut pwdLastSet sur zéro (0). Pour supprimer cette exigence, définissez l’attribut pwdLastSet sur -1. L’attribut pwdLastSet ne peut pas être défini sur une autre valeur que par le système.
L’exemple de code suivant montre comment définir l’option « L’utilisateur doit modifier le mot de passe lors de la prochaine ouverture de session ».
Dim usr as IADs
Set usr = GetObject("LDAP://CN=Jeff Smith,OU=Sales,DC=Fabrikam,DC=Com")
usr.Put "pwdLastSet", CLng(0)
usr.SetInfo
L’exemple de code suivant montre comment définir l’option « L’utilisateur doit modifier le mot de passe lors de la prochaine ouverture de session ».
/***************************************************************************
SetUserMustChangePassword()
***************************************************************************/
HRESULT SetUserMustChangePassword(LPCWSTR pwszUserADsPath,
LPCWSTR pwszUsername,
LPCWSTR pwszPassword)
{
IADs *pUser;
HRESULT hr;
hr = ADsOpenObject(pwszUserADsPath,
pwszUsername,
pwszPassword,
ADS_SECURE_AUTHENTICATION,
IID_IADs,
(void**)&pUser);
if(SUCCEEDED(hr))
{
VARIANT var;
VariantInit(&var);
V_I4(&var) = 0;
V_VT(&var) = VT_I4;
hr = pUser->Put(CComBSTR("pwdLastSet"), var);
hr = pUser->SetInfo();
VariantClear(&var);
pUser->Release();
}
return hr;
}