T1059.004

Command and Scripting Interpreter Unix Shell

Description from ATT&CK

Adversaries may abuse Unix shell commands and scripts for execution. Unix shells are the primary command prompt on Linux, macOS, and ESXi systems, though many variations of the Unix shell exist (e.g. sh, ash, bash, zsh, etc.) depending on the specific OS or distribution.(Citation: DieNet Bash)(Citation: Apple ZShell) Unix shells can control every aspect of a system, with certain commands requiring elevated privileges.

Unix shells also support scripts that enable sequential execution of commands as well as other typical programming operations such as conditionals and loops. Common uses of shell scripts include long or repetitive tasks, or the need to run the same set of commands on multiple systems.

Adversaries may abuse Unix shells to execute various commands or payloads. Interactive shells may be accessed through command and control channels or during lateral movement such as with SSH. Adversaries may also leverage shell scripts to deliver and execute multiple commands on victims or as part of payloads used for persistence.

Some systems, such as embedded devices, lightweight Linux distributions, and ESXi servers, may leverage stripped-down Unix shells via Busybox, a small executable that contains a variety of tools, including a simple shell.

Tests

Test #1 - Execute shell script

Adversaries use the Unix shell to execute commands and scripts.

Input Arguments:

ArgumentTypeDefault Value
bashCommandstrsw_vers -productVersion
do shell script "sw_vers -productVersion"

Download Files

Download .scpt Download .swift Download Binary Download Application Bundle

Test #2 - Execute shell script using administrator privileges

Adversaries use the Unix shell to execute commands and scripts.

Input Arguments:

ArgumentTypeDefault Value
bashCommandstrwhoami
do shell script "whoami" with administrator privileges

Download Files

Download .scpt Download .swift Download Binary Download Application Bundle

Test #3 - Execute shell commands in Terminal

Adversaries use the Unix shell to execute commands and scripts.

Input Arguments:

ArgumentTypeDefault Value
bashCommandstrsw_vers -productVersion
tell application "Terminal"
  do script "sw_vers -productVersion"
  delay 3
  try
    quit
  end try
end tell

Download Files

Download .scpt Download .swift Download Binary Download Application Bundle

References