dpapi
This utility performs DPAPI related functions.
Deep-dive
In order to decrpyt a file/blob/data of any kind you must obtain a masterkey. The Masterkey can be obtained either from the LSASS process, or by decrypting a masterkeyfile. LSASS is straightforward, successfully dumping it will give you all the plaintext masterkeys with the appropriate GUID.
But if you can't use LSASS, you have to obtain the masterkey file, and decrypt it with an appropriate key. (too many keys, I know...)
Masterkey files can be located in %APPDATA%\Microsoft\Protect\%SID%
for each user or %SYSTEMDIR%\Microsoft\Protect
for the SYSTEM user. But how to decrypt them?
A masterkeyfile can contain multiple different keys, a masterkey is one of them. The masterkey is stored encrypted in the masterkeyfile, and is encrypted with a key that can be either a key stored in registry (LSA secrets) or not. In case the LSA DPAPI keys are not valid, you will need to use the NT hash of the user's password or the user's plaintext password itself. BUT! deriving the key from the password and the SID will yield 3 different keys, and so far noone could tell what key is the correct one to be used.
The solution for decrypting a masterkey in the mastereky file: harvest as many key candidates as possible and try to decrypt the masterkey. Much to our luck, verifying the signature data after decryption can tell us if the decrpytion was successful, so we can tell if the masterkey decrypted correctly or not.
But you may ask: I see a lot of different masterkey files, how can I tell which one is used for my <credential file/vault files/blob>
. The answer: a masterkeyfile stores the GUID of the keys it stores (eg. the masterkey), and so does your <secret>
data structure for the appropriate key. Therefore it's easy to tell which file to decrypt for a given <secret>
.
BUT WAIT! THERE IS MORE!
DPAPI is also used to decrypt stored secrets in Windows Vault and Credential files.
Credential files:
- standalone file, inside it there is a DPAPI_BLOB.
- DPAPI_BLOB can be decrypted with the corresponding masterkey
- After decryption you'll find a CREDENTIAL_BLOB structure.
- The CREDENTIAL_BLOB structure has the plain-text secrets, but it's not possible to tell in which file they are stored. You'll need to check them by hand :)
Vault files (VCRD and VPOL)
VCRD files hold the secrets encrypted. The decryption key is stored in the VPOL file, but also encrypted. The VPOL file's decryption key is a masterkey. The masterkey is stored in a Masterkeyfile...
- Need to find the masterkey to decrypt the VPOL file
- VPOL file will give two keys after successful decryption
- There is no way to tell (atm) which key will be the correct one to decrypt the VCRD file
- The VCRD file has a lot of stored secrets, called attributes. Each attribute is encrypted with one of the keys from the VPOL file
- For each attribute: for each key: decrypt attribute.
- Check manually if one of them succeeded because there are no integrity checks, so no way to tell programatically which key worked.
Path to decrypt stuff
Sub-sections are options of how to get the keys
-
pre_masterkey:
- from user password and SID
- from user NT hash and SID
- from live registry SYSTEM cached DPAPI key or SAM cache NT hash and SID
- from offline registry hives
-
masterkey:
- from masterkeyfile + pre_masterkey
- from live LSASS dump
- from offline LSASS dump
-
credential file:
- masterkey + credential_file
-
VPOL file:
- masterkey + VPOL file
-
VCRED file:
- VPOL file + VCRED file
-
DPAPI_BLOB:
- masterkey
Tips
All pre-key
and masterkey
data will be automatically cached in the session to help you in the secrets extraction phase.
To perform any meaningful decryption, first you will need to generate pre-keys
, except if you have already decrypted masterkey secrets in the form of LSASS dump or you are a wizard Harry and from some unknown source you managed to get the keys (pls let me know how).
You can get pre-keys
by either using user SID and password or NT hash. Chances are that you have some pre-key
material already stored in the Credentials Window
in this case just smash the loadcreds
button. In case you have some not stored creds, use the commands in the PREKEY
command group.
Now that you have pre-keys
you can grab a Masterkey file
and try to decrypt the masterkey
using the masterkeys
or masterkey
command. The former will automatically search all masterkey files and try to decrypt if with all the pre-keys
cached from before. In case you have successfully decrypted a masterkey the key will be cached.
If you have masterkeys cached, then you can try to decrypt some actual secrets with the other command groups. Those commands do not need any masterkey specification because the blobs they are decrypting already contain the masterkey's ID which will be looked up in the hidden cache.
Commands
As usual, all functionalities will be discussed in command groups which logically group commands of similar nature.
LOADCREDS
loadcreds
Loads all useble credentials from the Credentials Window
.
minidump
Parses an LSASS minidump file to extract masterkeys.
masterkeys
Searches the given path for Masterkey files (filenames with GUID format) and tries to decrypt them all with previously loaded pre-keys
PREKEY
clearprekeys
Clears the pre-key
cache
prekey_nt
Generates pre-keys from user's SID and NT hash
prekey_password
Generates pre-keys from user SID and plaintext password
prekey_registry
Fetches pre-keys from registry hives
MASTERKEY
clearmasterkeys
Clears the masterkey
cache
masterkey
Tries to decrypt a Maskterkey file using all cached pre-keys
BLOB
blob
Decrypts a DPAPI blob (in hex please) using the exisiting masterkey cache
describe
Shows metadata of the DPAPI Blob data without performing decryption
BROWSER
chrome
Decrypts credentials stored by Google Chrome using the exisiting masterkey cache.
WIFI
wifi
Decrypts Windows stored WiFi passwords using the exisiting masterkey cache
VPOL/VCRED/CREDENTIAL
vpol
Decrypts .vpol files using the exisiting masterkey cache
vcred
Decrypts .vcred files using the exisiting masterkey cache
credential
Decrypts .cred files using the exisiting masterkey cache
CLOUDAP
cloudapkd
Decrypts CloudAP PRT secret using the exisiting masterkey cache
SECURESTRING
securestring
Decrypts Powershell SecureString blob using the exisiting masterkey cache