Skip to content
forked from ledge74/HelloHue

Sync your Philips Hue lights with Plex!

Notifications You must be signed in to change notification settings

bam2000/HelloHue

 
 

Repository files navigation

HelloHue

Sync Philips Hue lights with Plex!

Requirements

  • A Plex Pass subscription
  • A computer with Git / Node 8 / NPM 5 (alternatively, a Docker image is available)

Warning

This app is the standalone equivalent of the HelloHue.bundle Plex Plugin. This is not a Plex Plugin, as Plugins will be deprecated soon.

Behavior

This application detects when a media is playing, paused or stopped on your Plex Clients. Then it checks the client name, and the user who owns the stream. If it matches your criteria, it triggers your lights with the actions you have set up.

Installation with Node

  1. git clone https://github.com/bam2000/HelloHue.git
  2. cd HelloHue
  3. npm i
  4. npm start

Configure Plex Webhook

Plex needs to send webhooks to HelloHue in order for the channel to work. For example, if HelloHue uses the default port and is on the same machine as your Plex Media Server, the webhook url will be : http://127.0.0.1:4568/

Read this support article in order to learn how to create a Plex webhook

Configure HelloHue

  • In a browser, go the HelloHue app url, for example http://127.0.0.1:4568/ if you are on the machine that runs HelloHue.
  1. Configure everything : Hue bridge, Plex server, Location.
  2. Then configure your Rooms. One room is composed of one Player, one or multiple User(s) and one or multiple Hue Lights/Groups. Below is some additional details about the most important settings :
    • Plex Player name you can find your Plex Players in your Plex Media Server -> settings -> Authorized devices. Only put ONE client per room. If your have two clients in the same room, activate an other room and fill the settings with the other clients name and the same lights names.
    • Plex Users names you can find the list of users in Plex Media Server -> settings -> home users. You can put multiple users (comma separated values, case sensitive).
    • You need to tick Activate this room in order for light actions to get triggered.

HelloHue api

Three endpoints are available. You may use them to integrate with homebridge or home-assistant for example :

  • GET /api/start
  • GET /api/stop
  • GET /api/status
    • Returns 1 if HelloHue is started
    • Returns 0 if HelloHue is stopped

Example docker-compose file

HelloHue is also available as a Docker image

version: "3"

services:
  hellohue:
    container_name: hellohue
    volumes:
      - ./hellohue:/app/db
    ports:
      - "4568:4568"
    environment:
      - TZ=Europe/Paris
    network_mode: host
    restart: unless-stopped

Example homebridge-http integration

Integrate with homebridge and homebridge-http

{
    	"accessory": "Http",
    	"name": "HelloHue",
    	"switchHandling": "yes",
    	"http_method": "GET",
    	"on_url":      "http://127.0.0.1:4568/api/start",
    	"off_url":     "http://127.0.0.1:4568/api/stop",
    	"status_url":  "http://127.0.0.1:4568/api/status",
    	"service": "Switch",
    	"brightnessHandling": "no",
    	"brightness_url":     "http://localhost/controller/1707/%b",
    	"brightnesslvl_url":  "http://localhost/status/100054",
    	"sendimmediately": "",
    	"username" : "",
    	"password" : ""                     
},

Example Home-Assistant integration

- platform: command_line
  switches:
    hellohue:
      command_on: "/usr/bin/curl -X GET http://127.0.0.1:4568/api/start"
      command_off: "/usr/bin/curl -X GET http://127.0.0.1:4568/api/stop"
      command_state: "/usr/bin/curl -X GET http://127.0.0.1:4568/api/status"
      value_template: '{{ value == "1" }}'
      friendly_name: HelloHue

Example of Systemd Autostart

	sudo nano /etc/systemd/system/hellohue.service 

with the following Content

	[Unit]
	Description=HelloHue
	After=network.target

	[Service]
	Environment=NODE_PORT=4568
	Type=simple
	User=pi
	WorkingDirectory=/home/pi/HelloHueMod/
	ExecStart=/usr/local/bin/node index.js
	Restart=on-failure

	[Install]
	WantedBy=multi-user.target

Enable Systemctl

	systemctl enable hellohue.service

Check Status of Systemctl

	systemctl status hellohue.service

Support the project

I've modified HelloHue if you want to donate please go to the original page https://github.com/ledge74/HelloHue

About

Sync your Philips Hue lights with Plex!

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 50.6%
  • Liquid 49.1%
  • Dockerfile 0.3%