Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/GhostPack/KeeThief
Methods for attacking KeePass 2.X databases, including extracting of encryption key material from memory.
https://github.com/GhostPack/KeeThief
Last synced: about 2 months ago
JSON representation
Methods for attacking KeePass 2.X databases, including extracting of encryption key material from memory.
- Host: GitHub
- URL: https://github.com/GhostPack/KeeThief
- Owner: GhostPack
- License: bsd-3-clause
- Created: 2016-07-10T19:11:23.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2020-11-18T18:35:21.000Z (about 4 years ago)
- Last Synced: 2024-06-26T03:10:35.850Z (6 months ago)
- Language: C#
- Size: 4.69 MB
- Stars: 902
- Watchers: 34
- Forks: 152
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# KeeThief
Allows for the extraction of KeePass 2.X key material from memory, as well as the backdooring and enumeration
of the KeePass trigger system.Author: Lee Christensen ([@tifkin\_](https://twitter.com/tifkin_)), Will Schroeder ([@harmj0y](https://twitter.com/harmj0y))
License: BSD 3-Clause
Required Dependencies: None
Optional Dependencies: NoneThis project includes a number of components:
## DecryptionShellcode
A modified version of Matt Graeber ([@mattifestation](https://twitter.com/mattifestation))'s [PIC\_Bindshell](https://github.com/mattifestation/PIC_Bindshell) position-independent shellcode project, licensed under the 3-clause BSD license.
Modifications were made to build shellcode to inject into a KeePass.exe process that decrypts DPAPI blobs using RtlDecryptMemory.
## KeePass-2.34-Source-Patched
Patched source code of the KeePass project (version 2.34), licensed under the [GNU GENERAL PUBLIC LICENSE](http://keepass.info/help/v1/license.html) with the specific KeePass license [located here](http://keepass.info/help/v2/license.html). Modifications were made to allow the manual specification of key data (in the form of base64 strings) when decrypting a database. Changes are to KeePromptForm.cs, KeePromptForm.Designer.cs, KcpKeyFile.cs, and KcpUserAccount.cs.
## KeeTheft
The main KeeThief code, "where the magic happens".
KeeThief's GetKeePassMasterKeys() will attach to the target KeePass process using CLR MD and enumerate all CLR heap objects, searching for a KeePassLib.PwDatabase object. If one is found, the path is extracted from the m_strUrl field, and all referenced objects are enumerated, searching for a KeePassLib.Keys.CompositeKey.
If a composite master key is found, information for each key type (KcpPassword, KcpKeyFile, KcpUserAccount) is extracted, including the RtlEncryptMemory() encrypted data blobs of key data. For any encrypted blobs found, shellcode is injected into the KeePass process that calls MyRtlDecryptMemory() to decrypt the memory blobs, returning the plaintext/unprotected key data.
This is a different approach than denandz' excellent [KeeFarce project](https://github.com/denandz/KeeFarce), which injects code to load a bootstrap DLL into the KeePass process, which then loads an C# assembly along with CLR MD, and executes the 'Export' method on a KeePass.DataExchange.Formats.KeePassCsv1x object in order to export all existing passwords to disk. KeeTheft walks the heap for composite key information and injects shellcode to decrypt each encryption material component as appropriate.
Included in the project is a .NET 2.0 backport of the CLR MD project (necessary for PowerShell v2 compatibility). The [CLR MD](https://github.com/Microsoft/clrmd) project is licensed by Microsoft under
the MIT license.On building the project, a merged .\KeeTheft\bin\ReleaseKeeTheft.exe binary containing KeeTheft and the CLR MD will be produced.
## PowerShell
The **KeeThief.ps1** PowerShell file contains **Get-KeePassDatabaseKey**, which loads/executes the KeeTheft assembly in memory to extract KeePass material from an KeePass.exe process with an open database.
The **KeePassConfig.ps1** file contains method to enumerate KeePass config files on a system (**Find-KeePassconfig**), retrieve the set triggers for a KeePass.config.xml file (**Get-KeePassConfigTrigger**), add malicious KeePass triggers (**Add-KeePassConfigTrigger**), and remove KeePass triggers (**Remove-KeePassConfigTrigger**).
## KeeThief License
The KeeThief project and all individual scripts are under the [BSD 3-Clause license](https://raw.github.com/mattifestation/PowerSploit/master/LICENSE) unless explicitly noted otherwise.