In addition to clearing system logs, an adversary may clear the command history of a compromised account to conceal the actions undertaken during an intrusion. macOS and Linux both keep track of the commands users type in their terminal so that users can retrace what they've done.These logs can be accessed in a few different ways. While logged in, this command history is tracked in a file pointed to by the environment variable
HISTFILE
. When a user logs off a system, this information is flushed to a file in the user's home directory called~/.bash_history
. The benefit of this is that it allows users to go back to commands they've used before in different sessions.Adversaries can use a variety of methods to prevent their own commands from appear in these logs, such as clearing the history environment variable (
unset HISTFILE
), setting the command history size to zero (export HISTFILESIZE=0
), manually clearing the history (history -c
), or deleting the bash history filerm ~/.bash_history
.
Clears bash history via rm
Supported Platforms: Linux, macOS
rm ~/.bash_history
Clears bash history via rm
Supported Platforms: Linux, macOS
echo "" > ~/.bash_history
Clears bash history via cat /dev/null
Supported Platforms: Linux, macOS
cat /dev/null > ~/.bash_history
Clears bash history via a symlink to /dev/null
Supported Platforms: Linux, macOS
ln -sf /dev/null ~/.bash_history
Clears bash history via truncate
Supported Platforms: Linux
truncate -s0 ~/.bash_history
Clears the history of a bunch of different shell types by setting the history size to zero
Supported Platforms: Linux, macOS
unset HISTFILE
export HISTFILESIZE=0
history -c
Clears the history and disable bash history logging of the current shell and future shell sessions
Supported Platforms: Linux, macOS
set +o history
echo 'set +o history' >> ~/.bashrc
. ~/.bashrc
history -c
Using a space before a command causes the command to not be logged in the Bash History file
Supported Platforms: Linux, macOS
hostname
whoami