IoT Security: Backdooring a smart camera by creating a malicious firmware upgrade
Vložit
- čas přidán 12. 01. 2020
- In this video we look at reverse engineering a basic firmware format of a commonly found IoT camera - and then creating a backdoored firmware that calls back to our command & control server and allows us to remotely control it!
Camera in the video: Wyze Cam v2
Scripts from the video: github.com/ghidraninja/wyze_s...
A lot more information on the hardware and software, as well as an awesome custom firmware can be found here: github.com/EliasKotlyar/Xiaom... - Věda a technologie
Remember kids. The S in IoT stands for security.
eri bUt ThErE iS nO s In IoT
eri and the R for reliability, M for maintenance, U for upgradeability.
Ok deploy my IOTs please! :-)
@@AndreasDelleske sounds like you'd prefer some RUM
Well when you flash your own firmware to add security vulnerables...
Take a look at the access log of your server :)
"GET /Awesome_video_dude_Keep_up_the_great_work
Hah, love it! Thanks man!
@@stacksmashing awesome that the message got to you :) Really enjoyed the video. Hope you have some more planned ^^
/slow clap.
haha thats awesome
@xOr Vega sent a GET request to his server saying "/Awesome_video_dude_Keep_up_the_great_work"
The 19 dislikes are smart camera manufacturers
the 20 dislikes are fucking bots
@@fivethreeone2132 stop blaming everything on bots probably lol, maybe people tap on it by mistake. Happenes to me sometimes too.
The 75 people only like cat videos
This is EXACTLY what I was looking for when I bought this camera. I hate that the default firmware doesn't allow video streaming via the Wise app without an internet connection [via LAN]. So finally I have a means to circumvent their servers while still attaining live video footage.
We don't need to see the baby-monitors when we're out of the house.
Through all the video I was like '' ok that's very theoretical, how would you install the firmware in real life's and the you gave the example at the last second and my blood turned cold 😱
same for me haha
@@mshthn It would be perfect for a semi-targettted attack on someone by simply selling them a camera on ebay. You could just set up an ebay account that sell compromised cameras and no one would figure it out unless you sell one to an IT guy.
So if you buy one of these used, you should flash the official firmware. Apart from that, not restricting firmware flashing is not a big deal, since flashing it requires physical access to the camera anyway, and having the ability to flash a custom firmware means one can make custom security updates after the camera is discontinued and no longer receives official updates.
And hope that a return doesn't get repacked as new
" not restricting firmware flashing is not a big deal"
if this was the only way to install firmware, that might be true,
BUT, it can also be upgraded remotely, without touching the camera. i dont know if that has any extra security or not.
It's a big deal because I can tamper with that camera and then sell it on ebay. Then as luck will have it that camera winds up somewhere important.
@@statinskill but then the app won't work anymore.
@@statinskill also because now it is in the local network, any other not so secure home device can be hacked
Exactly what I was searching for, a well detailed CCTV firmware reversing tutorial. Hey Ninja, I really like your work and your way of explanation, Please Upload more videos, please make it a bit frequent like 1v/month.
We’ve only had the cameras up and running for a short time. czcams.com/users/postUgkxOXxsTZ3ptV_Pk0fFl8bNZvVqeoqBQFwe So far we love them! I got the outdoor mounting kit for them and they were easy to install. Once you download the app, it walks you through the very easy set up. The clarity, and range is awesome. I am thinking seriously about adding another camera or two to my 3 camera system. The price is lower than a lot of comparable systems.
That was a lot easier than it should've been lol..
That was so easy to watch and learn, no extra and unnecessary steps, no stupids and distractive ads. simple and awesome iot exploit. Keep up the good work
Really fantastic video, well done. Your explanations and visuals are easy to follow, and we can all tell that you have a good understanding of what you're doing.
It's good to see this channel is still alive, I love your content! Thank you for sharing your knowledge, hope to see more updates in the future
Wow this was really interesting to see a demonstration by someone willing to explain the thinking process along the way. This is very inspiring!
Awesome video! Exactly the type of hands-on example I love to see/learn from.
A German Engineer. Nothing more to say :) Ah, wait. A German Reverse Engineer :)) Well done.
Great to see you back. Hope you'll post more videos.
Ghidra Ninja - It's been a while. I love your work and want to see more. Thanks of the video.
I really liked the style of this video, because it was "just right" for the knowledge I have. You explained it very well and with not too much or too less informations. thx!
Yeah-the level of knowledge we have is much lower then we think we have!.Try explaining this to someone or to replicate it..You will need to watch this video 100 times over :)
Really good video with good explanations! Love it dude! Keep up the good work!
Found your channel watching the new Game and Watch hacks and enjoying the content library, this video was awesome to watch and might try to do this myself on my own Wyze cam.
i just found your content yesterday, and I am HOOKED. Keep up the awesome work :)
Great job on this! I actually have one of these hacked cameras to use a security cam (but keep it off of the wyze network). Crazy how simple it is to hack the firmware and can't wait to see more. Might be time for me to start hacking some of my IoT devices. Makes me a bit nervous of how vulnerable my network might be though!
Amazing to see you back.Loved the video
I would back up your channel on another platform like Bitchute or library. CZcams has been deleting channels like yours.
I loved this video! i plan on picking up a camera to play around with myself! Im glad I'm not the only one who thought "what if it has been backdoored and returned to the wild" you're a legend man!
What an fantastic video!
Excellent content and perfect pace.
Great tutorial, lots of new utilities I have never heard of before
Awesome. I actually have one of these sitting around.
Can we quickly laugh at how stupid their way of stopping telnetd is? Instead of uninstalling it and or removing it from the rcS file, instead, they just kill it (And not even stop the service, just use killall.)
Based on where the killall is from, I'm guessing the telnetd was a backup access point for testing. If the camera starts up, but can't load the camera app for some reason, it won't kill the telnet daemon, and they can log in to figure out what broke.
@@Acorn_Anomaly Shouldn’t make it into prod FW though
@@ArnaudMEURET No, but taking advantage of it in this instance would still require either an already compromised or non-functioning device. There have been worse backdoor incidents.
Ideally, they'd have removed it or disabled it, but after they had an already working image, they may not have wanted to mess around too much with it, especially since, as I said above, taking advantage of that isn't generally achievable remotely.
maybe is used for support from the company
me thinks they be lazy
I was able to get into a Faleemi outdoor camera with this exact same method (except they have an option to only update the rootfs so I only needed to repack the squash file with no UBoot header). Works like a charm, and with telnet/wget I can update my camera remotely with my custom firmware. Thank you so much for my first IoT hack! I was also able to get a UART terminal to it on the hardware side.
Such a great video! Very informational
Welcome Back! Finally a new video! 🙌
You should make more such videos, you have the potential to grow your channel
very cool i have always been thinking about repacking modified firmwares
This is awesome, I can perfectly use tooling such as jefferson right now for firmware modification. To split up flash image partitions, I am simply using dd though and cat things together again.
Edit: Since it looks like jefferson is for extraction only, I'll stick with mounting the rootfs through the mtd + jffs2 kernel modules, which is a bit of work and annoyance, but solved. =) I will still keep jefferson in mind for extraction-only/analysis use-cases though, makes sense also to have something portable. Thank you!
Awesome Video! Keep up the good work!
Your videos are amazing, please never stop posting videos, I am now a student of yours.
Learned a lot thanks 👍🙏
This video is AMAZING. Thx
Awesome video!
From the UK 🇬🇧. Great stuff
Great content bro 👍😀
Awesome video 😍
Amazing video :) Please make more
Amazing vid!
Awesome video
Thanks for the tip! Gonna try and modify an init script, pack the squashfs and update the camera. Should be similar to your model
dude this channel teach a lot better youtube channel easy tips and learn everyday
Amazing video...
Great note about zero padding the modified filesystem image before you bundle it to keep it the same size as the original!
Whoever disliked this is either an idiot or they accidentally clicked the wrong button. Great video man and it would be good to see more videos like this that give us novices guidance in exploiting devices. It’s also good that you’ve shown it with a device we have access too, so yeh much appreciated 👍
Or they wanted to see disassembly and Ghidra.
Thank you that knowledge!
interesting to see the miio client on there, same thing is running on my vacuum. Thanks for the very informative video
This is so cool!
Welcome back-
I love your videos!
Might have to get a few of those cams now :D
Dude! Amazing!
No doubt, you've already had countless people recommending the Wyze Cam V3. The low light image capability seems very good.
What it doesn't have is RTSP, and Wyze doesn't seem very anxious to provide that capability.
But it's a swell cam.
Amazing video. I love the "hack" where you get it into ram where there was more space. I was just wondering though: The need to store the extra binary was to get the reverse shell, but if bash was there, could you then use that instead? I do really like you went the NC way, because I learned a lot about what to do if the situation arose. Amazing!
Awesome video very usefull =)
This could all be avoided if the customer had all cameras on their own network (vLAN) with no internet access and no access to the main network. But this was a very informative detailed video.
Once i backdoored my neighbour's security cam. He was backdooring his wife...
Now you are "backdooring" us? (lying)
@@cocosloan3748 boomer
I'm taking some courses in IOT, I still can't understand everything here but I'm enjoying it a lot
This was really interesting, do you have any plans on uploading more IOT videos?
cool video..👍👍👍
hey i love you. this was a fun video to watch
Very good Job. I liked reverse Shell using netcat , i'm using reverse ssh , bit this is more easy
Nice video
Great job :)
Wow...Just wow!
Nice video, keep up the good work! But are you planning on uploading more regularly? And do you have any plans in doing more Ghidra related videos?
I'm going to start checking the firmware on every device I buy from now on. On the plus side it will keep me from buying too many things :D.
finally !YAY
That's the best CZcams sponsorship I've ever seen.... "this video is sponsored by ME" ;)
Heck ya new vid
The oh s*** moment at the end... love it
T.Hanks
We need more videos xD
Would this work on the newer v3's? Awesome video and explanation. I'm looking to set one up as a weather webcam for weather underground.
Yay! :)
15:50 Thanks for the advice :)
12:50 *
"shameless plug", not sure why but I laughed my ass off at that haha
Could you extract the firmware for Vstarcam cameras? They're not available online and the updater inside the camera only downloads a diff of what needs to be updated. I tried extracting from the flash using a raspberry pi but it didn't work. These cameras are one of the most sold on aliexpress and I can't find a way to telnet to them. Their RTSP server keeps crashing and I wanted to write a custom script to restart this server. Would be nice if you managed to crack these cameras. Thanks!
man, you are a genius. i can only wish to know a half of a half of what you know. can you do some alexa hacking? my brother in law have one and i would love to do some pranks to him
Doom on a wyze camera can't wait to see that
It's been a few years, but I believe I used to use squashfs as the system image on the good ol' T-Mobile G1 (HTC Dream), the first Android device. But I thought it wasn't read-only once mounted as I used to manipulate the system partition all the time... I may be mistaken tho, that was 2009
a good video after another and another and another ... good job! Open a patreon if you need a little motivation to upload more frequently. I would sign up just like I'm on the LiveOverflow patreon...
Great video! Is there a way to repack the JFS2 directory like you did with the squashfs folders? I took a look at jefferson but the docs only mention the ability to extract.
You can re-pack the JFFS2 filesystem by using mkfs.jffs2. The problem I'm running into is that the repacked filesystem (no modification) is larger than the original so my offsets are wrong when I go to re-pack the bin file. I'm not terribly skilled in Python so I'm trying to figure out how to mod the wyze_extractor script to build the image properly using a modified JFFS2 filesystem. Hopefully I'll be able to post my fixes here, as I'm working on a mod for my own purposes.
great.
Thank you for this video. Tell me, please, is it possible to edit files within a SBN (signed binary) file and then repack with this method? I can open the archive and see the files inside but I'm not sure how to repack it.
nice
Can you do one similar reverse engineering on a Huawei 4G dongle , that could be a nice tutorial
This is seriously impressive. How long did this take?
Where does the reverse shell point to initially? If you were to run PWD for example. Is it just the home dir of the user? (In the case of the video the user would be root)
Most devices have some sort of checksum of the firmware binary, how do you usually bypass that?
Subbed ;)
Thanks I believe my nosey neighbors watch me through my LED lights also .
bin mir absolut sicher, dass du aus dem deutschsprachigem raum bist. dieser akzent ist so einzigartig hahah :D
Ich nix verstehen😇
@@stacksmashing
i thought your mother language is german. you sound like a german person is speaking english haha
War ein Witz, ich bin Deutsch :)
@@stacksmashing (x
I am dumb i couldn't understand the packing part a bit. Do you have any course online? Or any resources that would help. I come from web and Network exploitation background am getting into firmware reversing and stuffs i couldn't understand a bit while packing the firmware. :(
I had a friend whose mom purchased a cheap Walmart IoT camera.
This camera has two-way communication features and makes an alert when the owner rings in. One time it made the alert sound but no audio on the other end. They literally believed it was caused by ghosts as the camera ". . . doesn't connect to the internet, it goes through my mom's phone."