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.
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.
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.
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. 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.
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.
Rodney Rehm galactoise James Bulpin
node-cron request minimist expressjs rpi-gpio tinycolor2 node-blink1
Additionally the raspi-gpio tool must be available.