Skip to content

PeterBrain/homebridge-http

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

77 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Seeking New Maintainers

As I have commitments that don't allow me to progress this module I'm actively seeking contributors to this repo to maintain it.

Please let me know if you're interested.

homebridge-http

Supports https devices on the HomeBridge Platform and provides a readable callback for getting the "On", brightness level and color characteristics to Homekit.

Installation

  1. Install homebridge using: npm install -g homebridge
  2. Install homebridge-http using: npm install -g homebridge-http
  3. Update your configuration file. See sample-config.json in this repository for a sample.

Configuration

This module has recently been updated to support an additional method to read the power state of the device and the brightness level. Specify the status_url in your config.json that returns the status of the device as an integer (0 = off, 1 = on).

In the latest version you can use custom status responses beyond 0 and 1

For example include these in config.json, these work with motion, exchange for what you get from your status url. "status_on": "ACTIVE", "status_off": "PAUSE",

On and off statuses also support JSON responses. If you need a more complex way to tell if your accessory is in an on state have it send a JSON object back that matches what you specify in the config file. Example:

"status_on": {
    "speaker": "ON",
    "playlist": "Top Hits",
    "playmode": "PLAY"
}

Note that the response can contain more properties than what is specified, if all of the properties in the config object have matching properties in the response than it will be considered a match.

Specify the brightnesslvl_url to return the current brightness level as an integer.

hueset_url and saturationset_url are for setting hue and saturation levels respectively. Both take an integer as a parameter, with the first one being in range 0-360 and the second in 0-100. hue_url and saturation_url return current values of those settings.

Switch Handling and brightness Handling support 3 methods, yes for polling on app load, realtime for constant polling or no polling

Configuration sample:

"accessories": [
   {
       "accessory": "Http",
       "http_method": "GET",
       "service": "Light",
       "name": "Bedroom Lamp",

       "switchHandling": "realtime",
       "on_url": "http://localhost/controller/1700/ON",
       "off_url": "http://localhost/controller/1700/OFF",
       "status_url": "http://localhost/status/100059",
       "status_on": "ON",
       "status_off": "OFF",

       "brightnessHandling": "yes",
       "brightness_url": "http://localhost/controller/1707/%b",
       "brightnesslvl_url": "http://localhost/status/100054",

       "sendimmediately": "",
       "username": "",
       "password": ""
   },
   {
       "accessory": "Http",
       "http_method": "GET",
       "service": "Light",
       "name": "Color Changing Lamp",

       "switchHandling": "realtime",
       "on_url": "http://localhost/controller/1700/ON",
       "off_url": "http://localhost/controller/1700/OFF",
       "status_url": "http://localhost/status/100059",
       "status_on": {
           "power": "ON",
           "color": "Blue"
       },
       "status_off": {
           "power": "OFF"
       },

       "brightnessHandling": "yes",
       "brightness_url": "http://localhost/controller/1707/%b",
       "brightnesslvl_url": "http://localhost/status/100054",

       "colorHandling": "yes",
       "hueset_url": "http://localhost/hue/set/1707/%b",
       "hue_url": "http://localhost/hue/status/100054",
       "saturationset_url": "http://localhost/saturation/set/1707/%b",
       "saturation_url": "http://localhost/saturation/status/100054",

       "sendimmediately": "",
       "username": "",
       "password": ""
   },
   {
       "accessory": "Http",
       "http_method": "GET",
       "service": "Switch",
       "name": "Power Outlet",

       "on_url": "http://localhost/controller/1800/ON",
       "off_url": "http://localhost/controller/1800/OFF",
       "status_url": "http://localhost/status/100060",

       "sendimmediately": "",
       "username": "",
       "password": ""
   }
]

ToDo

Complete documentation and review a number of forks

About

HTTP Plugin for Homebridge

Resources

License

Code of conduct

Stars

Watchers

Forks

Packages

No packages published

Languages

  • JavaScript 100.0%