@hap-server/hap-server
v0.11.4
Published
Home automation system based on Homebridge.
Downloads
47
Maintainers
Readme
Home Automation Server
Home automation system based on Homebridge.
It includes a web interface for controlling accessories, activating and configuring scenes, automations and custom controls. Configuring accessories in the web interface and storing historical data is not supported yet.
It includes a plugin system to add accessories, accessory configuration, authentication and options for automations. All Homebridge plugins are supported.
TODO
- Web interface
- [x] Layouts
- Customisable by dragging sections and accessories in the web interface.
- [x] Scenes
- [x] Cameras
- [x] Custom sections with plugins
- [ ] Service groups (one tile controls multiple accessories)
- Group services into a single service with merged values
- [x] Basic accessory control (on/off)
- [x] Switch
- [x] Lightbulb
- [x] Programmable Switch (shows last action for five seconds)
- [x] Outlet
- [x] Television
- [x] Lock Mechanism
- [x] Garage Door Opener
- [ ] All other services supported by hap-nodejs
- [x] Other services with plugins
- [x] Accessory control
- [x] Switch
- [x] Lightbulb
- [x] Programmable Switch
- [x] Outlet
- [ ] Television
- [x] Input selection
- [ ] Remote
- [ ] Lock Mechanism
- [ ] Garage Door Opener
- [ ] All other services supported by hap-nodejs
- [x] Other services with plugins
- [x] Dark theme (system wide)
- [ ] Notifications
- Configuration
- [x] Add + configure accessories in the web interface
- [x] Set home/accessory/service names
- [x] Server status and output
- [x] Custom layouts
- [x] Manage users/permissions
- [x] Manage HomeKit bridges + choose accessories to expose
- Per-user HomeKit bridges (see above)
- [x] Expose accessories via multiple bridges
- [x] Manage + name HomeKit pairings
- [x] Add + configure accessories in the web interface
- [x] Layouts
- [x] Desktop app
- Electron app that wraps the web interface and provides notifications in the background.
- Supports all operating systems supported by Electron (though for macOS you probably want to use the built in Home app).
- Uses a local copy of the web interface instead of using the server's.
- [ ] Historical data
- [ ] Store changes to an accessory's state
- Enable with the
--experimental-history
flag. Currently only stores changes already visible to hap-server (when plugins (usually incorrectly) update without any subscribed clients, when controlled in hap-server or when a controller is subscribed to changes) and from all accessories.
- Enable with the
- [ ] Elgato Eve???
- [ ] Store changes to an accessory's state
- Security
- [x] Web interface authentication
- Completely handled by plugins.
- [x] Permissions
- [ ] Web interface permission checks
- [ ] Per-user HomeKit bridges
- This would allow you to configure all accessories in hap-server and then allow multiple people to create their own homes with read-only access (or no access) to other people's accessories instead of sharing a single home where everyone has permission to control all accessories. Also allows users to choose their own favourite accessories/scenes/colours and using multiple devices without an Apple ID.
- [ ] Multiple pairings with a single bridge?
- [ ] Process isolation (e.g. using a separate process for each plugin)
- [x] Web interface authentication
- [x] Scenes
- Works with automations. (Scenes just run automation conditions to check if they're enabled and automation actions to activate/deactivate them.)
- [ ] Simple scene editor. (Set accessories to create active conditions and activate/deactivate actions.)
- [ ] Restore state before scene was enabled (using existing historical data)
- [x] Automations
- [x] Create automations that can run on the server
- Useful if you don't have an Apple TV 4, HomePod or always home iPad.
- Also could easily allow for more flexible automations than HomeKit allows.
- [x] Manage automations in the web interface
- TODO:
- [ ] Better error handling
- [x] Handle triggers/conditions/actions that don't have an editor component
- [x] Set characteristic action editor
- TODO:
- [x] Triggers
- [x] Cron expressions
- [x] Sunrise/sunset
- [ ] Characteristic changes
- [ ] Any change
- [ ] Set to value
- [ ] Set below/above value
- [x] Conditions
- [x] All/any
- [x] JavaScript
- [ ] Check characteristic
- [x] Actions
- [x] Conditional
- [x] JavaScript
- [x] Set characteristic
- [x] Increment/decrement
- [ ] Transitions
- [ ] Automation history
- [x] Create automations that can run on the server
- [ ] Temporary scheduled actions
- "Turn the lights off in 10 minutes."
- [ ] Cameras
- [x] Basic support (use with HomeKit)
- [x] Snapshots in the web interface
- [ ] Live streaming in the web interface
- HomeKit Secure Video??
- Recording??
- [ ] Routers
- [ ] Basic support (use with HomeKit)
- For routers and HomeKit Accessory Security: no support as the TLV format isn't known yet.
- For Wi-Fi extenders (or satellites as they are called internally) - these are very basic (only provides a connected/not connected status): supported in hap-nodejs, but not yet in hap-server until Homebridge also updates hap-nodejs.
- [ ] Visible in the web interface
- [ ] Controllable in the web interface
- [ ] Basic support (use with HomeKit)
- [ ] Merged accessories
- Merge services from multiple accessories into a single accessory to add functionality with multiple plugins.
- [x] Add HomeKit accessories
- [x] HomeKit over IP
- [ ] HomeKit over BLE
- [x] Plugins
- [x] Accessories
- [x] Accessory platforms
- [x] All current Homebridge accessories + accessory platforms
- [x] Web interface plugins
- [x] Layout sections
- [x] Basic accessory control
- [x] Accessory control
- [x] Accessory + accessory platform discovery + setup
- [x] Accessory + accessory platform configuration
- [x] Authentication
- [x] User management
- [x] Automation trigger configuration
- [x] Automation condition configuration
- [x] Automation action configuration
- [x] Custom routes and menu items
- [ ] Custom modals
- [ ] Web interface themes?
- [x] Automation plugins
- Automation plugins can run other automation conditions/actions.
- [x] Automation triggers
- [x] Automation conditions
- [x] Automation actions
- [ ] Install + manage plugins in the web interface?
- Like server output???
- Performance and stability features
- [x] Cached accessories
- Accessory configuration can be cached so the server can run immediately and have accessories load in the background.
- This works differently to Homebridge - plugins can just create accessories as normal instead of restoring event handlers to a restored accessory object. Plugins can use the restored accessory object if they want to though.
- HAP time warnings
- hap-server will output a warning when an accessory takes more than 2 seconds to get a value, or 5 seconds to set a value.
- [x] Cached accessories
- [x] Configuration reloading
- Global plugin configuration cannot be reloaded.
- [x] Accessories + accessory platforms
- [x] HAP bridges
- [x] Server hostname
- [ ] Listening addresses and HTTPS configuration
- [ ] Automations
- Platform compatibility
- [x] macOS
- [x] Linux??
- [ ] Windows??
- [x] Full compatibility with Homebridge
- Run instead of Homebridge and use all Homebridge plugins with the web interface. Homebridge accessories appear and can be controlled in the web interface, by automations on the server and with hap-server's HAP bridges.
Installation
npm install -g @hap-server/hap-server
# Or if that doesn't work
sudo npm install -g @hap-server/hap-server
This will install hap-server and link the hap-server
executable.
You can now run hap-server with your configuration. Once you've tested your configuration you'll probably want to
set it up as a system service with systemd
(Debian), launchd
(macOS) or whatever service manager you have
installed.
hap-server requires a plugin to authenticate access to the web interface. You can use the authenticate-pam plugin to allow local users on the server to access the web interface. If you don't install an authentication handler you won't be able to access the web interface, but you'll still be able to configure hap-server using it's configuration file.
npm install -g @hap-server/authenticate-pam
By default users with the IDs root
and cli-token
(the user used when running CLI commands) are administrators.
When using the authenticate-pam plugin you'll need to assign your user an ID the first time you use it. (A proper
setup workflow will be added soon.) Once you have an account setup you can make your account an administrator.
hap-server make-admin {user-id}
# Or with the path to the configuration file
hap-server make-admin {user-id} --config data/config.yaml
GitHub Package Registry
By default npm
will install from https://npmjs.com. You can configure npm
to install hap-server from
GitHub Package Registry by adding this to your npmrc
:
@hap-server:registry=https://npm.pkg.github.com
Run this to configure npm
to use GitHub Package Registry for @hap-server
scoped packages globally:
echo "@hap-server:registry=https://npm.pkg.github.com" >> `npm --global prefix`/etc/npmrc
GitLab Package Registry (https://gitlab.com)
You can also configure npm
to install hap-server from GitLab Package Registry by adding this to your
npmrc
:
@hap-server:registry=https://gitlab.com/api/v4/packages/npm/
Run this to configure npm
to use GitLab Package Registry for @hap-server
scoped packages globally:
echo "@hap-server:registry=https://gitlab.com/api/v4/packages/npm/" >> `npm --global prefix`/etc/npmrc
GitLab Package Registry (https://gitlab.fancy.org.uk)
You can also configure npm
to install hap-server from GitLab Package Registry by adding this to your
npmrc
:
@hap-server:registry=https://gitlab.fancy.org.uk/api/v4/packages/npm/
Run this to configure npm
to use GitLab Package Registry for @hap-server
scoped packages globally:
echo "@hap-server:registry=https://gitlab.fancy.org.uk/api/v4/packages/npm/" >> `npm --global prefix`/etc/npmrc
Development builds
Every change to the main
branch is published to the next
tag on GitLab Package Registry
(on https://gitlab.com and https://gitlab.fancy.org.uk). After configuring npm
to install from one of
those registries, you can install from main
with this:
npm install -g @hap-server/hap-server@next
To switch back to the latest stable version specify the latest
tag:
npm install -g @hap-server/hap-server@latest
Alternatively you can install from the git repository (or a mirror). When installing from git npm
will build
hap-server locally.
npm install -g git+https://gitlab.fancy.org.uk/hap-server/hap-server.git
# Or from GitHub
npm install -g git+https://github.com/hap-server/hap-server.git
# Or from gitlab.com
npm install -g git+https://gitlab.com/hap-server/hap-server.git
Usage
To run hap-server, just run hap-server
.
Samuels-MacBook-Air:~ samuel$ hap-server
[28/02/2019, 01:56:01] Starting hap-server with configuration file /Users/samuel/.homebridge/config.json
...
hap-server will exit with an error if the configuration file doesn't exist. To use a custom configuration file path pass it as the first argument. hap-server allows you to write your configuration file in either JSON or YAML.
Samuels-MacBook-Air:~ samuel$ hap-server data/config.yaml
[28/02/2019, 01:56:01] Starting hap-server with configuration file /Users/samuel/Documents/Projects/hap-server/data/config.yaml
...
hap-server can automatically setup HTTPS with a self signed certificate and advertise the web interface with Bonjour.
To use this add the --advertise-web-interface
flag.
Samuels-MacBook-Air:~ samuel$ hap-server data/config.yaml --advertise-web-interface
...
[27/07/2019, 01:00:03] You can access the web interface on your local network at https://hap-server-12b083b6-dd04-49a7-abac-171388e99db2.local:51820/,
[27/07/2019, 01:00:03] (remember to install the TLS certificate at /Users/samuel/Documents/Projects/hap-server/data/certificates/12b083b6-dd04-49a7-abac-171388e99db2.pem,
[27/07/2019, 01:00:03] fingerprint: c9:01:0c:f7:54:80:3d:b4:57:fd:33:27:c0:2f:f2:d2:de:b8:22:de:9a:ef:9e:56:ec:7f:c9:05:c9:72:34:a4)
...
All Homebridge command line flags work with hap-server.
Samuels-MacBook-Air:~ samuel$ hap-server help
hap-server [config]
Run the HAP and web server
Commands:
hap-server [config] Run the HAP and web server [default]
hap-server make-admin <user> Promote a user to administrator
hap-server get-characteristics <config> Get characteristics
<characteristics>
hap-server set-characteristic <config> Set a characteristic
<characteristic> <value>
hap-server validate-configuration Validates a configuration file
<config>
hap-server version Show version number
Positionals:
config The configuration file to use [string] [default:
"/Users/samuel/Documents/Projects/hap-server/data/config.yaml"]
Options:
--debug, -D Enable debug level logging
[boolean] [default: false]
--timestamps, -T Add timestamps to logs
[boolean] [default: true]
--force-colour, -C Force colour in logs[boolean] [default: false]
--help Show help [boolean]
--advertise-web-interface Automatically setup a HTTP server with a self
signed TLS certificate for the web interface
and advertise it through Bonjour
[boolean] [default: false]
--advertise-web-interface-port Port to listen on for the automatically
advertised web interface
[number] [default: 51820]
--data-path, -U Path to store data [string]
--plugin-path, -P Additional paths to look for plugins at as
well as the default location ([path] can also
point to a single plugin) [array]
--print-setup, -Q Print setup information
[boolean] [default: false]
--allow-unauthenticated, -I Allow unauthenticated requests (for easier
hacking) [boolean] [default: false]
--user, -u User to run as after starting
--group, -g Group to run as after starting
To show the version number run hap-server version
.
Samuels-MacBook-Air:~ samuel$ hap-server version
hap-server version 0.11.0 release
homebridge version 0.4.50, API 2.4
hap-nodejs version 0.4.51
Node.js version 12.10.0, v8 7.6.303.29-node.16, native modules 72
npm version 6.11.3
Configuration
hap-server stores data in a platform-specific default location (falling back to the same location as Homebridge) and supports the same configuration format as Homebridge, as well as YAML. Using the same configuration as Homebridge, hap-server will behave exactly like Homebridge but will have a web interface for controlling accessories. Using Homebridge and hap-server plugins at the same time are supported, however you shouldn't run multiple instances of hap-server/Homebridge using the same data location.
Platform | Directory
------------|-----------
macOS | ~/Library/Application Support/hap-server
, ~/.homebridge
, /Library/Application Support/hap-server
Linux | ~/.config/hap-server
, ~/.homebridge
, /var/lib/hap-server
For other platforms ~/.homebridge
is used.
You can also use hap-server programmatically with Server.createServer
.
import {Server} from '@hap-server/hap-server';
const server = await Server.createServer({
config: ...,
data_path: ...,
});
// See src/cli/server.ts to see what you can do with the Server object
Development
# Clone the git repository
git clone https://gitlab.fancy.org.uk/hap-server/hap-server.git
cd hap-server
# Install dependencies
npm install
# Build/watch the backend and example plugins
npx gulp build-backend watch-backend build-example-plugins watch-example-plugins &
# Copy the example configuration
mkdir -p data
cp example-config/config.yaml data
# Run the server (this will build the frontend)
bin/hap-server data/config.yaml
To build the frontend in Gulp instead of the hap-server process (and disable webpack hot module replacement) add
watch-frontend
to the Gulp command and add the --no-webpack-hot
flag to the hap-server command.
To use the standalone Vue devtools
run npx vue-devtools
and pass the --vue-devtools-port
flag to hap-server
.
npx vue-devtools &
bin/hap-server data/config.yaml --vue-devtools-port 8098
# Also pass --vue-devtools-host if you want to use the Vue devtools to work on other devices
bin/hap-server data/config.yaml --vue-devtools-host samuels-macbook-air.local --vue-devtools-port 8098
Plugins
hap-server supports all Homebridge plugins, but also has it's own plugin API that allows plugins to use hap-server features.
Credits + License
hap-server is built on Apple HomeKit/HAP, HAP-NodeJS and Homebridge.
hap-server is released under the MIT license.
If you'd like to contribute to hap-server please create an account on my GitLab server and contact me (Tor).