Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/oznu/homebridge-unifi-occupancy-sensor
An occupancy sensor for Homebridge and UniFi
https://github.com/oznu/homebridge-unifi-occupancy-sensor
homebridge homebridge-plugin homekit occupancy-sensor unifi unifi-controller
Last synced: 3 months ago
JSON representation
An occupancy sensor for Homebridge and UniFi
- Host: GitHub
- URL: https://github.com/oznu/homebridge-unifi-occupancy-sensor
- Owner: oznu
- License: gpl-3.0
- Archived: true
- Created: 2017-07-18T10:44:04.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2021-05-07T03:38:25.000Z (over 3 years ago)
- Last Synced: 2024-09-19T04:18:08.809Z (4 months ago)
- Topics: homebridge, homebridge-plugin, homekit, occupancy-sensor, unifi, unifi-controller
- Language: JavaScript
- Size: 97.7 KB
- Stars: 71
- Watchers: 10
- Forks: 12
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
- Security: .github/SECURITY.md
Awesome Lists containing this project
README
# Homebridge UniFi Occupancy Sensor
[![npm](https://img.shields.io/npm/v/homebridge-unifi-occupancy-sensor.svg)](https://www.npmjs.com/package/homebridge-unifi-occupancy-sensor)
[![npm](https://img.shields.io/npm/dt/homebridge-unifi-occupancy-sensor.svg)](https://www.npmjs.com/package/homebridge-unifi-occupancy-sensor)
[![Donate](https://img.shields.io/badge/donate-paypal-yellowgreen.svg)](https://paypal.me/oznu)This Homebridge plugin will provide an occupancy sensor accessory to HomeKit based on the devices connected to WiFi access points managed by a [UniFi Controller](https://www.ubnt.com/download/unifi).
The plugin connects to the UniFi Controller event web socket to get instant notifications of connecting devices - which can then be used to trigger HomeKit actions like turning on the lights.
## Requirements
* Node.js v10 or later
* [UniFi Controller](https://www.ubnt.com/download/unifi) v5## Homebridge Config
The easiest way to configure this plugin is via [Homebridge Config UI X](https://github.com/oznu/homebridge-config-ui-x).
```javascript
"accessories": [
{
"accessory": "UniFi Occupancy Sensor",
"name": "Occupancy Sensor", // Required. The name of the sensor.
"unifi": {
"controller": "https://demo.ubnt.com:8443", // Required. The url of the UniFi Controller. Use port 443 for UnifiOS
"username": "superadmin", // Required. A read-only user is fine.
"password": "password", // Required.
"site": "default", // Optional. The UniFi site to connect to.
"secure": false, // Optional. Set true to validate the SSL certificate.
"unifios": false // Optional. Set true if your controller runs on UnifiOS. Use port 443 as well.
},
"watch": [ // Optional - use either watch or monitor.
"44:00:10:f0:3e:66"
], // An array of device MAC addresses to watch for.
"monitor": [
{ // Optional - use either watch or monitor.
"device": "44:00:10:f0:3e:67", // An array of device MAC/AP combinations to watch for.
"ap": "44:00:10:f0:3e:44"
}
],
"watchGuests": true, // Optional. Set false to not monitor guest networks.
"interval": 1800, // Optional. Polling interval used to query Unifi in seconds
"mode": "any" // Optional. Set to "any", "all" or "none".
}
]
```### Site Name
If you're using a non-default site you will need to specify the name of the site in the plugin config. The internal site name might not match the name you have allocated to the site exactly, you can get the required site name by navigating to the site in the unifi controller then looking at the url bar:
```
https://unifi.com:8443/manage/site/mofkpypu/dashboard
```In this case the site name is `mofkpypu` and this is the value that should be entered in your Homebridge config.
## License
Copyright (C) 2017-2021 oznu
This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the [GNU General Public License](./LICENSE) for more details.