npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

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

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