Completely rebuilt my network. Wireless is the fantastic  @ubnt hardware. (these are nano-HDs) IP cameras are all UniFi G3’s. In short, I’d seriously consider any hardware Ubiquiti produces.
                        
                        
                        
                        
                                                
                        
                                                
                    
                    
                                    
                    
                        
                        
                        The wired network is all centered around a set of 5 Cisco switches, (mostly because I have 20 years of Cisco ios) trunked together by fiber runs between basement and attic and a few Ethernets. (connecting switches on other floors)
                        
                        
                        
                        
                                                
                        
                                                
                    
                    
                                    
                    
                        
                        
                        There are 4 VLANs, all independently routed. All the  @ubnt hardware supporting VLAN trunking is using it. User and guest wireless networks, for example, are just separate VLANs on the same physical Ethernet.
                        
                        
                        
                        
                                                
                    
                    
                                    
                    
                        
                        
                        At the heart is Linux iproute2 which routes / NATs everything. Connections again are all VLAN trunk ports although the divide between public internet and private networks are physically separate Ethernets.
                        
                        
                        
                        
                                                
                    
                    
                                    
                    
                        
                        
                        IoT devices, all HomeKit in my case, are on their own VLAN with heavily restricted access to anything else internal. The AppleTVs and HomePods “hub” the IoT devices which are mostly  @Leviton Decora Smaet dimmers and switches.
                        
                        
                        
                        
                                                
                        
                                                
                    
                    
                                    
                    
                        
                        
                        This brings up an interesting quandary - if the AppleTVs are on a network without access to other internal networks (namely the user network!) how does one screencast to an AppleTV? I do this with a one-way punch between the networks.
                        
                        
                        
                        
                                                
                    
                    
                                    
                    
                        
                        
                        User devices can initiate TCP and UDP traffic to the IoT network but not the other way around. Once a session is started, however, IoT devices can respond. But, you say, how are the AppleTVs discovered if their mDNS packets aren’t on the user network?
                        
                        
                        
                        
                                                
                    
                    
                                    
                    
                        
                        
                        The answer is mdns-repeater working across the VLANs. When an mDNS packet appears on one network, it is copied onto the other. This allows all devices to be mutually discoverable but connections only initiated in one direction. (The app with my minor fix:  https://github.com/anders94/mdns-repeater)">https://github.com/anders94/...
                        
                                                
                        
                        
                        
                                                
                    
                    
                                    
                    
                        
                        
                        Other HomeKit hardware includes the iHome plugs and the Unifi cameras. “Wait!”, you say, “Unifi cameras don’t support HomeKit!”. Not natively (yet?) but  https://homebridge.io"> https://homebridge.io  fixes that. (thanks node.js!)
                        
                        
                        
                        
                                                
                        
                                                
                    
                    
                                    
                    
                        
                        
                        All in, you have complete control using no third party apps regardless of what internal or external network you are on.
                        
                        
                        
                        
                                                
                        
                                                
                    
                    
                                    
                    
                        
                        
                        Just about all  @ubnt hardware is standard PoE so the switches, APs, cameras, etc. all have UPS (CyberPower in my case, don’t love it but there we are) through a rack PoE injector. This is the attic “stack” - an almost identical setup exists on most floors.
                        
                        
                        
                        
                                                
                        
                                                
                    
                    
                                    
                    
                        
                        
                        All servers are Intel NUC or Mac Minis (running Linux) to keep the power costs down. Admittedly this might use some upgrading but I tend to run hardware much longer than most. “Good enough” and all...
                        
                        
                        
                        
                                                
                        
                                                
                    
                    
                                    
                    
                        
                        
                        I’m going to write up a Medium on the configuration but I thought this way would be a fun overview. The most interesting parts are the iptables setup and the VLAN trunking / routing.
                        
                        
                        
                        
                                                
                    
                    
                                    
                    
                        
                        
                        Other fun things are the basement to attic and office fibers that are link aggregated so if one is cut, there is no loss in connectivity. It’s fun to unplug one or the other at will.
                        
                        
                        
                        
                                                
                    
                    
                                    
                    
                        
                        
                        Also, all DHCP and DNS for all networks is done via Linux as is NAT and any cross network routing.
                        
                        
                        
                        
                                                
                    
                    
                                    
                    
                        
                        
                        But I digress. I’ll write it up at some point. Hope you all enjoyed!
                        
                        
                        
                        
                                                
                    
                    
                
                 
                         Read on Twitter
Read on Twitter 
                             
                             
                             
                             
                             
                             
                             
                                     
                                    