hue-dash-switch
v1.0.0
Published
Node.js project turning your Amazon Dash button into a switch for your Philips Hue setup.
Downloads
8
Readme
hue-dash-switch
Amazon's Dash button is an amazing little device. Why not use the button's capabilities to its fullest and turn it into a remote for my Philips Hue setup rather than a simple tool for quicker ordering?
Note that this tutorial will show you how to control your entire Hue lightbulb setup with a Dash button rather than single lightbulbs. If you are interested in controlling single lightbulbs, Daniel Gallo posted a great tutorial on just that.
Content
- Node.js
- About .env
- Installing Dependencies
- Connecting Button to WiFi
- Button's MAC address
- Bridge's IP address
- Creating new User in Bridge
- Running Script
- LaunchDaemon
Node.js
This project is powered by Node.js. You need to have it installed on your computer before advancing any further. To check whether Node.js is running on your computer, run
node -v
If it outputs a version number, you are good to go. If not, download and install the lastest version of Node.js from the project's website or with Homebrew;
brew install node
.env
I store the Dash button's MAC address, the Bridge's IP address and User name in a .env file. For those of you not familiar with these: .env files provide a very clean way of storing passwords, access information or any kind of data in a single file. Other files can access this data, so you do not need to hardcode it into your scripts.
It is indispensable for this tutorial's success that you enter any information you are asked to enter into the given .env file.
Dotenv, the required package for .env usage, will be installed in the next step.
Installing Dependencies
Install the dependencies using npm
in your Terminal.
npm install
Finally, download the Amazon app to your smartphone (iOS, Android).
Connecting Button to WiFi
Connect the Dash button to the Internet by following the button's default setup process using Amazon's app up until the product selection page. Make sure that you do not select any products in this very step! Simply exit the setup by closing the app, otherwise you would be buying something from Amazon every time you press the button.
Button's MAC address
To make our final script work, we need to know the button's MAC address. The node-dash-button library's findButton-script listens for ARP requests on your local network, just like the ones being sent out with every click of the button.
To run the network listener by running
sudo npm run findButton
then press on your Dash button. Its MAC address will now appear in the console.
Enter the MAC address after "DASHMACADDRESS" in the given .env file.
Button's IP address
You need to find out its IP address so the script can talk to your Bridge. Open Philip's Hue companion app and navigate to Settings → Hue bridges → i. The IP address is located between your bridge's ID and MAC address.
Enter this IP address after "HUEIP" in the given .env file.
Creating new User in Bridge
To access your Hue lightbulbs, you will need to register a new user in your Bridge by pressing the link button on the Bridge and running the given registerUser.js file with Node.js;
sudo npm run registerUser
Running Script
And that's it. Run the app.js script by entering
sudo npm start
into your console and you are good to go! Your Amazon Dash button is now a switch for your Philips Hue setup.
LaunchDaemon
If you do not want to manually run the script with the node app.js
command every time your computer boots up or you simply dislike having an open console window running the script 24/7, I highly recommend using a LaunchDaemon for the script so macOS will run it in the background every time you start your computer.
In the given huedash.plist file, edit $YOURNAME to your name and $SCRIPTPATH to app.js' path. For me, that's com.maxrugen.huedash and ~/Developer/dash.
Now, copy the huedash.plist into the LaunchDaemon folder, set the file's owner to root and edit the file's rights using the following command. Again, you need to replace $YOURNAME with the name you just provided in the .plist.
sudo cp huedash.plist /Library/LaunchDaemons/huedash.plist && sudo chown root /Library/LaunchDaemons/huedash.plist && sudo chmod 644 /Library/LaunchDaemons/huedash.plist && sudo launchctl load /Library/LaunchDaemons/huedash.plist && sudo launchctl start com.$YOURNAME.huedash
Round Up
You now have a script running which
- starts running every time you boot your computer,
- imports the provided information from the .env file,
- prints "Button press detected" in the console whenever you press your Dash button,
- checks whether all of your lightbulbs are turned on or off and
- changes their status the opposite of the last known status! Congrats! 🎉