Skip to content

node.js based simulator of a Philips Hue bridge implementing the API. Modified to interface with a Blink1 and GPIO button pin.

License

Notifications You must be signed in to change notification settings

jamesbulpin/hueSimulator

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

60 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

A node.js based simulator for the Philips Hue API

As I started development of hueJS before getting my Hue starter kit, i needed to test my code with a simulated bridge.

This version of the simulator has been extended to control a locally-connected Blink1 as Hue light 1, and simulate a Hue Tap's main button push using an active-low, pulled-up input in GPIO pin 18. This therefore assumes the simulatro runs on a Raspberry Pi.

Install

Using npm:

sudo npm install -g hue-simulator

It should be installed globally by default, so you can start the simulator via command line, but to be sure we are adding the -g flag.

Run

Start the simulator via command line (if installed globally):

# start the simulator on localhost:80
sudo hue-simulator

# start the simulator on localhost:8080 #
hue-simulator --port=8080

# start the simulator on 127.0.3.1:80 #
sudo ifconfig lo0 alias 127.0.3.1
sudo hue-simulator --hostname=127.0.3.1

Sudo is necessary when we want to listen on port 80, a so called low-port that are restricted to the unix root user.

Debugger

There is a webinterface where you can enter commands similar to the debugger of the real bridge. After starting the simulator, simply navigate your browser to the IP of the simulator. screenshot of webinterface In the list on the left there are predefined commands, so you don't always have to look up the correct URL and write the whole JSON-body of the message. Click on a button, and the command-form is filled with dummy data for this kind of command.

Routes

GET /linkbutton will enable user registration for 30 seconds. By default, a user named "newdeveloper" is whitelisted. Registered users and state of the simulator will be lost when restarting. So you always have a "fresh" system.

At the moment, all routes from the hue API are available, except schedules.

Contributors

Rodney Rehm galactoise James Bulpin

Dependencies

node-cron request minimist expressjs rpi-gpio tinycolor2 node-blink1

Additionally the raspi-gpio tool must be available.

About

node.js based simulator of a Philips Hue bridge implementing the API. Modified to interface with a Blink1 and GPIO button pin.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 78.6%
  • HTML 20.0%
  • CSS 1.4%