I am considering to build a NFC reader for my smart lock. It consists of the actual reader (a “passive” element) and a NodeMCU that will do the heavy lifting (getting the readout of the badge ID, pushing it to HA).
My current plan is to have both in a 3D-printed case fixed on the outside of the entry door. This means that if someone grabs the box, they will be able to connect to the WiFi network (it will be a SSID and VLAN just for that reader).
The reader requires however to be able to contact HA in order to send the tag_scanned event and MQTT autodiscovery. I would like to pass these messages though a reverse proxy in order to whitelist the messages so that someone who controls the network cannot send anything sensitive to HA (there will be throttling for the ID management to mitigate brute force attacks).
Must be exciting living in an area with high tech thieves. The ones round here would just put a brick through a window or jimmy a sliding door if all sides of the house weren’t covered by security cameras.
I’m curious how you see this attack will be performed?
A reverse proxy (or even an mqtt broker ACL) isn’t going to help if the these genius thieves have your programmed NodeMCU.
I have a video of how thieves will break open the super-duper door with a hydraulic something I do not know the name in English that will push the door with great force and here we are.
I am mentally formatted because of my job in information security so here at least I would like to be clean and I do not expect anyone will poke around. But you never know!
If the nodemcu is retrieved by the high-tech thieves, they will find there the cleartext password for the WiFi network. They can then connect to that network and
attempt to guess the ID of the badge (bruteforce). Taken into account the key space an the throttling that risk is managed
they could also send MQTT messages such as “open the smart lock” which is highly annoying. This the reason to look for a way to reverse proxy these messages and whitelist the ones that are relevant.
If not then you will probably pull a power wire to the device, but then it would be just as easy to just leave the device inside and only pull the sensor wires to the outside.