Skip to content
This repository has been archived by the owner on Dec 7, 2022. It is now read-only.

Latest commit

 

History

History
100 lines (72 loc) · 5.38 KB

README.md

File metadata and controls

100 lines (72 loc) · 5.38 KB

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

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! 🎉