Homebridge plugin that integrates with Ankuoo Rec Switch
This package has been deprecated and the repository will be archived. I don't own a working Ankuoo Rec Switch anymore so I can't continue the development of this plugin. See the update below for more information and a possible path forward.
The correct decryption key has been found by ljalves (see this issue). If I can I will update the plugin to incorporate their work. In the meantime I advise you to take a look to the custom firmware that they developed for the switch that includes additional functionality like MQTT. That would make for a better integration with homebridge if you decide to use it.
- Install homebridge:
npm install -g homebridge
- Install homebridge-rcswitch-gpiomem:
npm install -g homebridge-ankuoo-rec-switch
- Update your homebridge configuration file.
See sample-config.json
All fields are required.To determine the onCode and offCode for your switch you have to sniff the packets transmitted from the mobile app to the switch (protocol UDP, port 18530) when you turn on and off the switch. The packet content (hex) will have the following structure:
0144
<- 2 bytes, constantaccf23xxxxxx
<- 6 bytes, mac address of your device10
<- 1 byte, 10, length in bytes of the decrypted payload that followsfd344f402a3f6299b530xxxxxxxxxxxx
<- encrypted payload, 16 bytes this is your on/off code.
accessory
: Must beAnkuooRecSwitch
(case sensitive)name
:: string :: What you want to call the switch. Keep in mind that Siri will prefer anything other than your homebridge switch if there's any confusion, so name it something uniquemac
:: string :: the mac address of your switchip
:: string :: the ip address of your switch (use a static ip)onCode
,offCode
:: string :: see instruction above on how to find your codes.
In theory it should work, however I haven't tested it because I only own one switch. If you find any issues please let me know I will try to fix them.
With the knowledge I have right now (see next question) there's is not a reliable way to determine the switch status. The plugin assumes that all your switches are off when you start homebridge, then uses broadcast packets sent by the switch to keep track of the on/off status. If one of this packets gets lost or if the switch was on when you started homebridge, then the status will be inconsistent. To fix this turn off your switch and then restart homebridge.
The packet structure is known (source), because it's basically the same for all the manufactures that use yunext.com as a platform. However, the AES 128bit key used to encrypt the payload it's not the same ("0123456789abcdef"). If you find the key used to encrypt the payload please let me know and I will gladly update my plugin to not require this codes anymore. I would even rewrite it as a platform so you have to only set username and password and it does the rest by itself.
There is a post on my blog explaining everything that I have tried to get this to work. If you see something that I've missed, please let me know.