Security Phase 2 – Doors and Windows (Planning)
I just wanted to start off by saying, this isn’t a how to at all, it’s more some general ideas I’ve been looking over for how to add door and window security to my recently set up video monitoring system. Basically, I want a log of when and if the doors and windows are opened and closed. I’d prefer not to run a bunch of wires, so wireless sensors are in order.
What I ultimately want is for an indicator light on a webpage to change based on the status of the door or window, a timestamp log to be created and possibly for some sort of email or text alert to occur. ULTIMATELY I may even use this whole project as an excuse to finally develop my Phone app skills and build an app that I can view it all on, but that’s farther down the road. A basic web page is fine for now, and it’s something I can manage.
My worry with wireless sensors was that I’d have to constantly change the batteries. Until I realized that it would be trivial to design the sensor so that it only transmits when the window is open, and while I am not building my own sensors (I probably could) I imagine the makers of such sensors realize that you could save a ton of battery life by designing the sensors to only work when open. I did a bit of searching on Amazon and found a6 pack of sensors for less than ten dollars. It appears that each sensor has it’s own receiver/indicator which emits an audible tone.
This is actually probably alright for my needs.
While I am not an Electrical Engineer, I am familiar with basic circuit flow and basic electronics. I don’t have any of these sensors yet but I can make some basic assumptions based on what I know. When the window/door is opened, some trigger is closed and the sensor starts transmitting some sort of radio signal. The fob thing which is always listening will receive the signal and activate some sort of internal speaker.
There are a couple of issues that need to be solved here. One, while the sensors hopefully are designed to conserve battery power, the FOBs are probably not. I also want the signal to go to a computer and not sound a mostly useless audible alarm. The power issue isn’t a huge issue. With the right transformer brick providing the proper voltage, it wouldn’t be hard to rewire the contacts to allow for the units to be plugged into the wall, all at once, off of one power supply. They look to be small enough that they could be mounted inside an electrical box in a small array and wired for power.
A similar method can be used to transform the speaker signal into a trigger for some sort of simple IO board. To activate the speaker, some sort of voltage is applied to the speaker, the speaker can easily be removed and the contact points that would previously have fed the speaker could be wired to am IO board. When the voltage is supplied to the "speaker" it will instead be read by the IO board, triggering a signal that "the Window/Door is open."
The main puzzle I have right now is, what would work best for the IO board. I see two options here, and both would function differently, and I may even require both. I could go with an Arduino board or a Raspberry Pi. Both of these options seem to have advantages and disadvantages, and there may even be a third option which corrects the disadvantages.
Let’s look at the Arduino. The Arduino is ideal for dealing with the IO board. It is, by design, meant to work with this sort of "hands on" electronics systems. It even has build in contacts for working with two wire IO interfaces. I don’t know anything about Process, the programming language of the Arduino, but I’ve been meaning to learn and I am capable of learning it. The problem is on the output. Arduino is not designed to work with PCs in any simple way. From some quick research online, the Arduino would require a serial interface and likely special software running on the server to poll the Arduino at set intervals. Which brings up another issue. As near as I can tell, the Arduino is a "pull" interface, meaning the server would have to pull the status from the Arduino, as opposed to "push" where the Arduino would push the data to the server as it changes.
So there is also the Raspberry Pi. The Raspberry Pi is a computer itself, which makes interfacing with the server simple and easy. It runs a simplified OS but connecting the Pi to the network is simple and telling it to push even a text file status update to the server via FTP or some similar network protocol is trivial. the issue comes in the need to read the sensors. I’m not entirely sure the Raspberry Pi is even capable of reading an analogue IO interface right out of the box. Some searching suggests it is possible through an additional interface board of some sort but not right out of the box. Looks like there are a handful of GPIO points build into the PI. The PI also feels like much more than is really needed for this simple application.
Its kind of a tricky decision, I’ve been wanting to play around with both the Pi and the Arduino so I may just pick up one of each and see what works. Both are around the same price and the whole system in the end will end up costing around $50-$75, which is almost nothing. The final step once the sensor data lands on the server is updating the web page but I already am familiar enough with building webpages and simple polling scripts that this step is the easy part. Whatever I end up going with I’ll certainly document the results in the future.