Adversaries may search local file systems and remote file shares for files containing insecurely stored credentials. These can be files created by users to store their own credentials, shared credential stores for a group of individuals, configuration files containing passwords for a system or service, or source code/binary files containing embedded passwords.It is possible to extract passwords from backups or saved virtual machines through OS Credential Dumping. (Citation: CG 2014) Passwords may also be obtained from Group Policy Preferences stored on the Windows Domain Controller. (Citation: SRD GPP)
In cloud and/or containerized environments, authenticated user and service account credentials are often stored in local configuration and credential files.(Citation: Unit 42 Hildegard Malware) They may also be found as parameters to deployment commands in container logs.(Citation: Unit 42 Unsecured Docker Daemons) In some cases, these files can be copied and reused on another machine or the contents can be read and then used to authenticate without needing to copy any files.(Citation: Specter Ops - Cloud Credential Storage)
Supported Platforms: macOS
python2 laZagne.py all
Extracting credentials from files
Supported Platforms: macOS, Linux
Name | Description | Type | Default Value |
---|---|---|---|
file_path | Path to search | String | / |
grep -ri password #{file_path}
Extracting Credentials from Files. Upon execution, the contents of files that contain the word "password" will be displayed.
Supported Platforms: Windows
findstr /si pass *.xml *.doc *.txt *.xls
ls -R | select-string -Pattern password
Attempts to access unattend.xml, where credentials are commonly stored, within the Panther directory where installation logs are stored. If these files exist, their contents will be displayed. They are used to store credentials/answers during the unattended windows install process.
Supported Platforms: Windows
type C:\Windows\Panther\unattend.xml
type C:\Windows\Panther\Unattend\unattend.xml
This test looks for .netrc files (which stores github credentials in clear text )and dumps its contents if found.
Supported Platforms: macOS, Linux
for file in $(find / -name .netrc 2> /dev/null);do echo $file ; cat $file ; done