node-unifiapi
UniFi API ported to Node.JS
This library is a rewrite of the PHP based UniFi-API-Browser written in JavaScript for Node-JS.
It is mimicking the UniFi-API-Browser API calls (the same commands the same effects) for Ubiquiti Unifi Controller versions 4 and 5 with addition of few more generic calls.
Major features
- Implements the major (if not all) calls to the REST API of the Ubiquiti for Unifi Controller
- Supports WebRTC (over the Ubiquiti Unifi Cloud) protocol. If you have your devices registerred in the Unifi Cloud you can access them and execute the same REST API calls over WebRTC
- Supports SSH access to the devices that support it (mostly UAP) over WebRTC
- Supports Plug-in replacement for the WebRTC module (tested with electron-webrtc) in case wrtc doesn't work for you for some reason
Warning
Quite unstable mostly due to the instability of the WebRTC implementation in Node.JS. Also highly incompleted and untested. Any help appreciated!
Installation
To install run:
npm install node-unifiapi --save
The installation DOES NOT depend on the Node's wrtc module anymore. If you want to use the WebRTC functionality (Unifi cloudapi and SSH tunnels to device) you have to install webrtc module, and if this module is not node-webrtc you have to explicitly specify it according to the documentation.
To install node-webrtc do:
npm install node-webrtc --save
The install requirements for node-webrtc are visible here node-webrtc. Please consult with the installation requirements of this module in order to be able to install it.
XOpenDisplay Error
A frequent error caused by node-webrtc module is the one defined in issue #281
node: symbol lookup error: [local-path]/build/wrtc/v0.0.61/Release/node-v47-linux-x64/wrtc.node: undefined symbol: XOpenDisplay
It happens mostly on Linux, almost exquisively if the Linux have X11 subsystem, although it is not caused directly by it (but a bad linking). The easiest method to avoid it is to use non desktop (non X11 based) Linux distribution, like Ubuntu Server. We all hope that in version 0.0.62 of the node-webrtc module this issue will be fixed.
Segmentation errors
Again, the node-wrtc module is quite unstable sometimes. I find it best working on OSX or Linux (Linux Server, without X11 libraries) with the prebuilt binary images (which for the moment requires node version 6.9 maximum for Linux). The problem with this instability seems to be well known to the wrtc community but I cannot predict when it will be fixed.
However, the unifiapi module uses the standart webrtc api, so it could work with any webrtc module with the standard api.
Following is an example with electron-webrtc module:
npm install electron-webrtc
And then a test (example) code:
let cloud = require('node-unifiapi/cloudapi');
let wrtc = require('electron-webrtc')({ headless: true });
let r = cloud({ device-id: 'xxx-xxx-xx-xx-xx-xx', username: 'myuser', password: 'mypass', webrtc: wrtc, waiter: 1000 }).api;
r.stat_sessions().then(data => console.log('Success', data).catch(err => console.log('Error', err);
The waiter property sets delay between every command sent to the webrtc in ms. I found electron-webrtc working better, if there is at least 500ms delay between the calls.
Test from CLI
There is a sister project available here https://github.com/delian/unificli which provides CLI tool where all (or most) of the calls of this API are exposed as REPL CLI commands one could use to test.
Usage
All the API are Promises
Direct access to Ubiquiti Unifi Controller
If you have a direct access to Ubiquiti Unifi Controller, you could use the following API:
let unifi = require('node-unifiapi');
let r = unifi({
baseUrl: 'https://127.0.0.1:8443', // The URL of the Unifi Controller
username: 'ubnt',
password: 'ubnt',
// debug: true, // More debug of the API (uses the debug module)
// debugNet: true // Debug of the network requests (uses request module)
});
r.stat_sessions()
.then((data) => {
console.log('Stat sessions', data);
return r.stat_allusers();
})
.then((data) => {
console.log('AP data', data);
})
.catch((err) => {
console.log('Error', err);
})
Access via Unifi Cloud and WebRTC
If you have to access the Unifi Controller if it is behind NAT and you need to use WebRTC to access it or known only via Unifi Cloud:
let cloud = require('node-unifiapi/cloudapi');
let r = cloud({
deviceId: '801bb78e12c80000000001a22aea000000000203c905000000066660aaaa', // The cloud id of the device
username: 'clouduser',
password: 'cloudpass',
// debug: true, // More debug of the API (uses the debug module)
// debugNet: true // Debug of the network requests
});
r.api.stat_sessions()
.then((data) => {
console.log('Stat sessions', data);
return r.api.stat_allusers();
})
.then((data) => {
console.log('AP data', data);
})
.catch((err) => {
console.log('Error', err);
})
Be careful - when we use the cloud access all the Unifi calls are available under the .api property, to not confuse with the API calls that are related to the cloud management itself.
Rebuild Readme.md
If you want to modify the README.md file for any reason (added jsdoc comment somewhere or have done change to README.hbs) please run
npm run readme
API
Functions
- UnifiAPI(options) ⇒
The main class and the initialization of the Unifi Access
- list_settings(site) ⇒
Promise
Alias to list_settings. Retrieve array with settings defined by setting key.
- SSH(mac, uuid, stun, turn, username, password, site, autoclose, webrtc, waiter) ⇒
SSHSession
Open SSH tunnel to a device managed by the controller (currently only Unifi AP) using WebRTC
- CloudAPI(options) ⇒
Cloud API interface. Under the .api method there will be all of the UnifiAPI calls (over WebRTC)
UnifiAPI(options) ⇒
The main class and the initialization of the Unifi Access
Kind: global function
Returns: this
Param | Type | Description |
---|---|---|
options | object |
the options during initialization |
options.baseUrl | string |
the URL where the Unifi controller is. Default https://127.0.0.1:8443 |
options.username | string |
default username |
options.password | string |
default password |
options.site | string |
default site. Default is "default" |
options.debug | boolean |
if the debug log is enabled |
options.debugNet | boolean |
if the debug of the request module is enabled |
Example
let UnifiAPI = ;let unifi = ;
- UnifiAPI(options) ⇒
- .debugging(enable) ⇒
undefined
- .netsite(url, jsonParams, headers, method, site) ⇒
Promise
- .login(username, password) ⇒
Promise
- .logout()
- .authorize_guest(mac, minutes, up, down, mbytes, apmac, site) ⇒
Promise
- .unauthorize_guest(mac, site) ⇒
Promise
- .kick_sta(mac, site) ⇒
Promise
- .terminate_guest(id, site) ⇒
Promise
- .block_sta(mac, site) ⇒
Promise
- .unblock_sta(mac, site) ⇒
Promise
- .set_sta_note(user, note, site) ⇒
Promise
- .set_sta_name(user, name, site) ⇒
Promise
- .stat_sessions(start, end, type, site) ⇒
Promise
- .stat_daily_site(start, end, attrs, site) ⇒
Promise
- .stat_hourly_site(start, end, attrs, site) ⇒
Promise
- .stat_hourly_ap(start, end, attrs, site) ⇒
Promise
- .stat_sta_sessions_latest(mac, limit, sort, site) ⇒
Promise
- .stat_auths(start, end, site) ⇒
Promise
- .stat_allusers(historyhours, site) ⇒
Promise
- .list_guests(historyhours, site) ⇒
Promise
- .list_guests2(historyhours, site) ⇒
Promise
- .list_clients(mac, site) ⇒
Promise
- .list_some_clients(macs, ap, site) ⇒
Promise
- .stat_client(mac, site) ⇒
Promise
- .list_usergroup(site) ⇒
Promise
- .set_usergroup(userid, groupid, site) ⇒
Promise
- .list_health(site) ⇒
Promise
- .list_dashboard(site) ⇒
Promise
- .list_users(site) ⇒
Promise
- .list_aps(mac, site) ⇒
Promise
- .list_rogueaps(within, site) ⇒
Promise
- .list_sites() ⇒
Promise
- .stat_sites() ⇒
Promise
- .add_site(name, description, site) ⇒
Promise
- .remove_site(name, site) ⇒
Promise
- .list_wlan_groups(site) ⇒
Promise
- .stat_sysinfo(site) ⇒
Promise
- .list_self(site) ⇒
Promise
- .list_networkconf(site) ⇒
Promise
- .stat_voucher(createtime, site) ⇒
Promise
- .stat_payment(within, site) ⇒
Promise
- .create_hotspot(name, password, note, site) ⇒
Promise
- .list_hotspot(site) ⇒
Promise
- .create_voucher(count, minutes, quota, note, up, down, mbytes, site) ⇒
Promise
- .revoke_voucher(voucher_id, site) ⇒
Promise
- .list_portforwarding(site) ⇒
Promise
- .list_dynamicdns(site) ⇒
Promise
- .list_portconf(site) ⇒
Promise
- .list_extension(site) ⇒
Promise
- .list_settings(site) ⇒
Promise
- .restart_ap(mac, site) ⇒
Promise
- .disable_ap(ap_id, disable, site) ⇒
Promise
- .enable_ap(ap_id, disable, site) ⇒
Promise
- .set_locate_ap(mac, site) ⇒
Promise
- .unset_locate_ap(mac, site) ⇒
Promise
- .site_ledson(site) ⇒
Promise
- .site_ledsoff(site) ⇒
Promise
- .set_ap_radiosettings(ap_id, radio, channel, ht, tx_power_mode, tx_power, site) ⇒
Promise
- .get_settings_by_key(key, site) ⇒
Promise
- .set_settings(key, obj, site) ⇒
Promise
- .set_guest_access(obj, guest_id, site_id, site) ⇒
Promise
- .set_guestlogin_settings(portal_enabled, portal_customized, redirect_enabled, redirect_url, x_password, site) ⇒
Promise
- .rename_ap(ap_id, ap_name, site) ⇒
Promise
- .set_wlansettings(wlan_id, x_password, name, site) ⇒
Promise
- .list_events(site) ⇒
Promise
- .list_wlanconf(site) ⇒
Promise
- .get_wlanconf(site) ⇒
Promise
- .list_alarms(site) ⇒
Promise
- .set_ap_led(ap_id, led_override, site) ⇒
Promise
- .set_ap_name(ap_id, name, site) ⇒
Promise
- .set_ap_wireless(ap_id, radio, channel, ht, min_rssi, min_rssi_enabled, antenna_gain, tx_power_mode, site) ⇒
Promise
- .status(site) ⇒
Promise
- .set_ap_network(ap_id, type, ip, netmask, gateway, dns1, dns2, site) ⇒
Promise
- .request_spectrumscan(mac, site) ⇒
Promise
- .set_site_descr(description, site) ⇒
Promise
- .set_site_settings(gen_id, site_id, advanced, alerts, auto_upgrade, key, led_enabled, x_ssh_username, x_ssh_password, site) ⇒
Promise
- .add_hotspot2(name, network_access_internet, network_type, venue_group, venue_type, site) ⇒
Promise
- .list_hotspot2(site) ⇒
Promise
- .delete_hotspot2(site) ⇒
Promise
- .set_hotspot2(hs_id, name, network_access_internet, network_type, venue_group, venue_type, site) ⇒
Promise
- .remove_wlanconf(id, site) ⇒
Promise
- .sdn_register(username, password, site) ⇒
Promise
- .sdn_unregister(site) ⇒
Promise
- .sdn_stat(site) ⇒
Promise
- .sdn_onoff(enabled, site_id, site) ⇒
Promise
- .extend_voucher(voucher_id, site) ⇒
Promise
- .debugging(enable) ⇒
undefined
unifiAPI.debugging(enable) ⇒ Enable or disable the debug of the module
Kind: instance method of UnifiAPI
Param | Type | Description |
---|---|---|
enable | boolean |
Enable or disable the debugging |
Promise
unifiAPI.netsite(url, jsonParams, headers, method, site) ⇒ Generic network operation, executing Ubiquiti command under /api/s/{site}/... rest api
Kind: instance method of UnifiAPI
Param | Type | Description |
---|---|---|
url | string |
The right part of the URL (/api/s/{site}/ is automatically added) |
jsonParams | object |
optional. Default undefined. If it is defined and it is object, those will be the JSON POST attributes sent to the URL and the the default method is changed from GET to POST |
headers | object |
optional. Default {}. HTTP headers that we require to be sent in the request |
method | object |
optional. Default undefined. The HTTP request method. If undefined, then it is automatic. If no jsonParams specified, it will be GET. If jsonParams are specified it will be POST |
site | string |
optional. The {site} atribute of the request. If not specified, it is taken from the UnifiAPI init options, where if it is not specified, it is "default" |
Example
unifi ;
Promise
unifiAPI.login(username, password) ⇒ Explicit login to the controller. It is not necessary, as every other method calls implicid login (with the default username and password) before execution
Kind: instance method of UnifiAPI
Returns: Promise
- success or failure
Param | Type | Description |
---|---|---|
username | string |
The username |
password | string |
The password |
Example
unifi
unifiAPI.logout()
Logout of the controller
Kind: instance method of UnifiAPI
Example
unifi
Promise
unifiAPI.authorize_guest(mac, minutes, up, down, mbytes, apmac, site) ⇒ Authorize guest by a MAC address
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
mac | string |
mac address of the guest - mandatory |
minutes | string |
minutes for the authorization - optional, default 60 min |
up | string |
upstream bandwidth in Kbps. Default no limit |
down | string |
downstream bandwidth in Kbps. Default no _limit |
mbytes | string |
download limit in Mbytes. Default no limit |
apmac | string |
to which mac address the authorization belongs. Default any |
site | string |
to which site (Ubiquiti) the command will be applied if it is different than the default |
Example
unifi
Promise
unifiAPI.unauthorize_guest(mac, site) ⇒ De-authorize guest by a MAC address
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
mac | string |
the mac address |
site | site |
Ubiquiti site, if different from default - optional |
Example
unifi
Promise
unifiAPI.kick_sta(mac, site) ⇒ Kick a client (station) of the network. This will disconnect a wireless user if it is connected
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
mac | string |
Mac address |
site | string |
Ubiquiti site, if different from default - optional |
Example
unifi
Promise
unifiAPI.terminate_guest(id, site) ⇒ Terminate access of a Guest (logged in via Guest Authorization). It kicks it out of the wireless and authroization
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
id | string |
the ID of the guest that have to be kicked out |
site | string |
Ubiquiti site, if different from default - optional |
Example
unifi
Promise
unifiAPI.block_sta(mac, site) ⇒ Block station of the network
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
mac | string |
Mac address |
site | string |
Ubiquiti site, if different from default - optional |
Example
unifi
Promise
unifiAPI.unblock_sta(mac, site) ⇒ Unblock station of the network
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
mac | string |
Mac address |
site | string |
Ubiquiti site, if different from default - optional |
Example
unifi
Promise
unifiAPI.set_sta_note(user, note, site) ⇒ Set or remove Note to a station
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
user | string |
User ID |
note | string |
Note |
site | string |
Ubiquiti site, if different from default - optional |
Example
unifi
Example
unifi // remove note
Promise
unifiAPI.set_sta_name(user, name, site) ⇒ Set or remove Name to a station
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
user | string |
User ID |
name | string |
Name |
site | string |
Ubiquiti site, if different from default - optional |
Example
unifi
Example
unifi // remove name
Promise
unifiAPI.stat_sessions(start, end, type, site) ⇒ List client sessions
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
start | number |
Start time in Unix Timestamp - Optional. Default 7 days ago |
end | number |
End time in Unix timestamp - Optional. Default - now |
type | string |
Sessions type. Optional. Default all |
site | string |
Ubiquiti site, if different from default - optional |
Example
unifi
Promise
unifiAPI.stat_daily_site(start, end, attrs, site) ⇒ List daily site statistics
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
start | number |
Start time in Unix Timestamp - Optional. Default 7 days ago |
end | number |
End time in Unix timestamp - Optional. Default - now |
attrs | array |
What attributes we are quering for. Optional. Default [ 'bytes', 'wan-tx_bytes', 'wan-rx_bytes', 'wlan_bytes', 'num_sta', 'lan-num_sta', 'wlan-num_sta', 'time' ] |
site | string |
Ubiquiti site, if different from default - optional |
Example
unifi
Promise
unifiAPI.stat_hourly_site(start, end, attrs, site) ⇒ List hourly site statistics
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
start | number |
Start time in Unix Timestamp - Optional. Default 7 days ago |
end | number |
End time in Unix timestamp - Optional. Default - now |
attrs | array |
What attributes we are quering for. Optional. Default [ 'bytes', 'wan-tx_bytes', 'wan-rx_bytes', 'wlan_bytes', 'num_sta', 'lan-num_sta', 'wlan-num_sta', 'time' ] |
site | string |
Ubiquiti site, if different from default - optional |
Example
unifi
Promise
unifiAPI.stat_hourly_ap(start, end, attrs, site) ⇒ List hourly site statistics for ap
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
start | number |
Start time in Unix Timestamp - Optional. Default 7 days ago |
end | number |
End time in Unix timestamp - Optional. Default - now |
attrs | array |
What attributes we are quering for. Optional. Default [ 'bytes', 'num_sta', 'time' ] |
site | string |
Ubiquiti site, if different from default - optional |
Example
unifi
Promise
unifiAPI.stat_sta_sessions_latest(mac, limit, sort, site) ⇒ Last station sessions
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
mac | string |
Mac address |
limit | number |
How many sessions. Optional. Default 5 |
sort | string |
Sorting. Optional. Default Ascending (asc) |
site | string |
Ubiquiti site, if different from default - optional |
Example
unifi
Promise
unifiAPI.stat_auths(start, end, site) ⇒ List authorizations
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
start | number |
Start time in Unix Timestamp - Optional. Default 7 days ago |
end | number |
End time in Unix timestamp - Optional. Default - now |
site | string |
Ubiquiti site, if different from default - optional |
Example
unifi
Promise
unifiAPI.stat_allusers(historyhours, site) ⇒ List all users
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
historyhours | number |
How many hours back to query. Optional. Default 8670 |
site | string |
Ubiquiti site, if different from default - optional |
Example
unifi
Promise
unifiAPI.list_guests(historyhours, site) ⇒ List of guests (authorized via the guest portal)
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
historyhours | number |
How many hours back to query. Optional. Default 8670 |
site | string |
Ubiquiti site, if different from default - optional |
Example
unifi
Promise
unifiAPI.list_guests2(historyhours, site) ⇒ List of guests (authorized via the guest portal) but with modern internal api
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
historyhours | number |
How many hours back to query. Optional. Default 8670 |
site | string |
Ubiquiti site, if different from default - optional |
Example
unifi
Promise
unifiAPI.list_clients(mac, site) ⇒ List of (all) clients per station
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
mac | string |
Mac address |
site | string |
Ubiquiti site, if different from default - optional |
Example
unifi
Promise
unifiAPI.list_some_clients(macs, ap, site) ⇒ List of group of clients per station
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
macs | string |
String mac or array of mac addresses as strings, to get information about them |
ap | string |
Station man address |
site | string |
Ubiquiti site, if different from default - optional |
Example
unifi
Promise
unifiAPI.stat_client(mac, site) ⇒ Statistics of (all) clients per station
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
mac | string |
Mac address |
site | string |
Ubiquiti site, if different from default - optional |
Example
unifi
Promise
unifiAPI.list_usergroup(site) ⇒ List of the usergroups
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
site | string |
Ubiquiti site, if different from default - optional |
Example
unifi
Promise
unifiAPI.set_usergroup(userid, groupid, site) ⇒ Add user to a group
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
userid | string |
ID of the user |
groupid | string |
ID of the group |
site | string |
Ubiquiti site, if different from default - optional |
Example
unifi
Promise
unifiAPI.list_health(site) ⇒ List health
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
site | string |
Ubiquiti site, if different from default - optional |
Example
unifi
Promise
unifiAPI.list_dashboard(site) ⇒ List dashboard
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
site | string |
Ubiquiti site, if different from default - optional |
Example
unifi
Promise
unifiAPI.list_users(site) ⇒ List users
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
site | string |
Ubiquiti site, if different from default - optional |
Example
unifi
Promise
unifiAPI.list_aps(mac, site) ⇒ List APs
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
mac | string |
AP mac/id, Optional |
site | string |
Ubiquiti site, if different from default - optional |
Example
unifi
Promise
unifiAPI.list_rogueaps(within, site) ⇒ List Rogue APs
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
within | number |
For how many hours back. Optional. Default 24h |
site | string |
Ubiquiti site, if different from default - optional |
Example
unifi
Promise
unifiAPI.list_sites() ⇒ List sites
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Example
unifi
Promise
unifiAPI.stat_sites() ⇒ Sites stats
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Example
unifi
Promise
unifiAPI.add_site(name, description, site) ⇒ Add new site
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
name | string |
name |
description | string |
description - optional |
site | string |
Ubiquiti site to query, if different from default - optional |
Example
unifi
Promise
unifiAPI.remove_site(name, site) ⇒ Remove site
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
name | string |
name |
site | string |
Ubiquiti site to query, if different from default - optional |
Example
unifi
Promise
unifiAPI.list_wlan_groups(site) ⇒ List WLANGroups
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
site | string |
Ubiquiti site to query, if different from default - optional |
Example
unifi
Promise
unifiAPI.stat_sysinfo(site) ⇒ Stat Sysinfo
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
site | string |
Ubiquiti site to query, if different from default - optional |
Example
unifi
Promise
unifiAPI.list_self(site) ⇒ Get information aboult self (username, etc)
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
site | string |
Ubiquiti site to query, if different from default - optional |
Example
unifi
Promise
unifiAPI.list_networkconf(site) ⇒ Get information aboult the network configuration
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
site | string |
Ubiquiti site to query, if different from default - optional |
Example
unifi
Promise
unifiAPI.stat_voucher(createtime, site) ⇒ Get accounting / status of the vouchers
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
createtime | number |
Unixtimestamp since when we return information about the vouchers. Optional. Default any |
site | string |
Ubiquiti site to query, if different from default - optional |
Example
unifi
Promise
unifiAPI.stat_payment(within, site) ⇒ Get accounting / status of the payments
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
within | number |
how many hours back we query. Optional. Default any |
site | string |
Ubiquiti site to query, if different from default - optional |
Example
unifi
Promise
unifiAPI.create_hotspot(name, password, note, site) ⇒ Create HotSpot (version 1)
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Todo
- Check if the URL of the rest service is correct
- Test that it is working
Param | Type | Description |
---|---|---|
name | string |
name |
password | string |
password |
note | string |
Note (optional) |
site | string |
Ubiquiti site to query, if different from default - optional |
Example
unifi
Promise
unifiAPI.list_hotspot(site) ⇒ List all of the hotspots (v1)
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
site | string |
Ubiquiti site to query, if different from default - optional |
Example
unifi
Promise
unifiAPI.create_voucher(count, minutes, quota, note, up, down, mbytes, site) ⇒ Create vouchers. Generate a set of vouchers
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
count | number |
how many vouchers to generate. Optional. default is 1 |
minutes | number |
how long the voucher may be active after activation in minutes. Optional. default is 60 minutes |
quota | number |
how many times a user may reuse (login with) this voucher. Default 0 = unlimited. 1 means only once. 2 means two times and so on |
note | string |
the note of the voucher. Optional |
up | number |
Upstream bandwidth rate limit in Kbits. Optional. Default - no limit |
down | number |
Downstream bandwidth rate limit in Kbits. Optional. Default - no limit |
mbytes | number |
Limit of the maximum download traffic in Mbytes. Optional. Default - no limit |
site | string |
Ubiquiti site to query, if different from default - optional |
Example
unifi
Promise
unifiAPI.revoke_voucher(voucher_id, site) ⇒ Revoke Voucher. Voucher revoking is the same as deleting the voucher. In most of the cases the authorized user is kicked out of the network too
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
voucher_id | string |
description |
site | string |
Ubiquiti site to query, if different from default - optional |
Example
unifi
Promise
unifiAPI.list_portforwarding(site) ⇒ List port forwarding configuration
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
site | string |
Ubiquiti site to query, if different from default - optional |
Example
unifi
Promise
unifiAPI.list_dynamicdns(site) ⇒ List dynamic dns configuration
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
site | string |
Ubiquiti site to query, if different from default - optional |
Example
unifi
Promise
unifiAPI.list_portconf(site) ⇒ List network port configuration
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Todo
- Test it
Param | Type | Description |
---|---|---|
site | string |
Ubiquiti site to query, if different from default - optional |
Example
unifi
Promise
unifiAPI.list_extension(site) ⇒ List extensions
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Todo
- Learn more what exactly is this
Param | Type | Description |
---|---|---|
site | string |
Ubiquiti site to query, if different from default - optional |
Example
unifi
Promise
unifiAPI.list_settings(site) ⇒ Get array with all the settings refered by settings key
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
site | string |
Ubiquiti site to query, if different from default - optional |
Example
unifi
Promise
unifiAPI.restart_ap(mac, site) ⇒ Restart Wireless Access Point
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
mac | string |
mac address of the AP |
site | string |
Ubiquiti site to query, if different from default - optional |
Example
unifi
Promise
unifiAPI.disable_ap(ap_id, disable, site) ⇒ Disable Wireless Access Point
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
ap_id | string |
The internal ID of the AP |
disable | boolean |
Shall we disable it. Optional. Default true. If false, the AP is enabled |
site | string |
Ubiquiti site to query, if different from default - optional |
Example
unifi
Promise
unifiAPI.enable_ap(ap_id, disable, site) ⇒ Enable Wireless Access Point
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
ap_id | string |
The internal ID of the AP |
disable | boolean |
Shall we disable it. Optional. Default true. If false, the AP is enabled |
site | string |
Ubiquiti site to query, if different from default - optional |
Example
unifi
Promise
unifiAPI.set_locate_ap(mac, site) ⇒ Locate Wireless Access Point. The Access Point will start blinking
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
mac | string |
mac of the AP |
site | string |
Ubiquiti site to query, if different from default - optional |
Example
unifi
Promise
unifiAPI.unset_locate_ap(mac, site) ⇒ Turn off Locate Wireless Access Point. The Access Point will stop blinking
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
mac | string |
mac of the AP |
site | string |
Ubiquiti site to query, if different from default - optional |
Example
unifi
Promise
unifiAPI.site_ledson(site) ⇒ All devices in the site group will start blinking
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
site | string |
Ubiquiti site to query, if different from default - optional |
Example
unifi
Promise
unifiAPI.site_ledsoff(site) ⇒ All devices in the site group will stop blinking
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
site | string |
Ubiquiti site to query, if different from default - optional |
Example
unifi
Promise
unifiAPI.set_ap_radiosettings(ap_id, radio, channel, ht, tx_power_mode, tx_power, site) ⇒ Change AP wireless settings
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
ap_id | string |
internal id of the AP |
radio | string |
The radio type. Supports ng or ac. Default ng. Optional |
channel | number |
Wireless channel. Optional. Default 1. Could be string 'auto' |
ht | number |
HT width in MHz. 20, 40, 80, 160. Optional. Default 20 |
tx_power_mode | number |
TX Power Mode. Optional. Default 0 |
tx_power | number |
TX Power. Optional. Default 0 |
site | string |
Ubiquiti site to query, if different from default - optional |
Example
unifi
Promise
unifiAPI.get_settings_by_key(key, site) ⇒ Retrieve settings by a specific settings key. Only elements with this settings key will be returned in the array. Usually 1 or 0 Typical keys are mgmt, snmp, porta, locale, rsyslogd, auto_speedtest, country, connectivity
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
key | string |
key |
site | string |
Ubiquiti site to query, if different from default - optional |
Example
unifi
Promise
unifiAPI.set_settings(key, obj, site) ⇒ Set settings by key modifies properties of the settings, defined by key
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
key | string |
key |
obj | object |
object of properties that overwrite the original values |
site | string |
Ubiquiti site to query, if different from default - optional |
Example
unifi
Promise
unifiAPI.set_guest_access(obj, guest_id, site_id, site) ⇒ Set Guest Settings and Guest Access Portal are created with this method
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
obj | object |
Object of properties that modify the original values |
obj.auth | string |
Optional. Type of authentication. hotspot, radius, none, .... Default hotspot |
obj.expire | string |
Optional. How long the authentication is valid in minutes. Default 480 (8h) |
obj.facebook_enabled | boolean |
Optional. Allow authentication with facebook. Default false |
obj.google_enabled | boolean |
Optional. Allow authentication with google+. Default false |
obj.payment | boolean |
Optional. Allow payments for authentication. Default false |
obj.portal_customized | boolean |
Optional. Customize the auth portal. Default false |
obj.portal_enabled | boolean |
Optional. Enable the portal. Default true |
obj.redirect_enabled | boolean |
Optional. Redirect after authentication. Default false |
obj.redirect_url | string |
Optional. Redirect URL after successful authentication. Default empty |
obj.voucher_enabled | boolean |
Optional. If voucher authentication is enabled. Default false |
guest_id | string |
From the get_settings, the ID of the guest settings |
site_id | string |
The ID of the current site |
site | string |
Ubiquiti site to query, if different from default - optonal |
Example
unifi
Promise
unifiAPI.set_guestlogin_settings(portal_enabled, portal_customized, redirect_enabled, redirect_url, x_password, site) ⇒ Set Guest Login Settings (simplified version)
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
portal_enabled | boolean |
If the portal is enabled. Optional. Default true |
portal_customized | boolean |
If the portal is customized. Optional. Default true |
redirect_enabled | boolean |
If the redirection is enabled. Optional. Default false |
redirect_url | string |
The url for redirection. Optional. Default '' |
x_password | string |
Password for the portal. Optional. Default '' |
site | string |
Ubiquiti site to query, if different from default - optonal |
Example
unifi
Promise
unifiAPI.rename_ap(ap_id, ap_name, site) ⇒ Rename Access Point
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
ap_id | string |
Id of the AP |
ap_name | string |
New name of the AP |
site | string |
Ubiquiti site to query, if different from default - optonal |
Example
unifi
Promise
unifiAPI.set_wlansettings(wlan_id, x_password, name, site) ⇒ Set WLAN Settings
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
wlan_id | strings |
ID of the Wlan |
x_password | string |
Password of the WLAN |
name | string |
Name of the WLAN |
site | string |
Ubiquiti site to query, if different from default - optonal |
Example
unifi
Promise
unifiAPI.list_events(site) ⇒ List the Events
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
site | string |
Ubiquiti site to query, if different from default - optonal |
Example
unifi
Promise
unifiAPI.list_wlanconf(site) ⇒ Get WLAN Config. Respond with Array of Wlan configurations
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
site | string |
Ubiquiti site to query, if different from default - optonal |
Example
unifi
Promise
unifiAPI.get_wlanconf(site) ⇒ Get WLAN Config. Second REST option. Respond with Array of Wlan configurations
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
site | string |
Ubiquiti site to query, if different from default - optonal |
Example
unifi
Promise
unifiAPI.list_alarms(site) ⇒ List the Alarms
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
site | string |
Ubiquiti site to query, if different from default - optonal |
Example
unifi
Promise
unifiAPI.set_ap_led(ap_id, led_override, site) ⇒ Set the access point LED
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
ap_id | string |
AP ID |
led_override | string |
Do we follow the standard LED config. Options default and overwrite |
site | string |
Ubiquiti site to query, if different from default - optonal |
Example
unifi
Promise
unifiAPI.set_ap_name(ap_id, name, site) ⇒ Change the name of an Access Point
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
ap_id | string |
the ID of the AP |
name | string |
the new name |
site | string |
Ubiquiti site to query, if different from default - optonal |
Example
unifi
Promise
unifiAPI.set_ap_wireless(ap_id, radio, channel, ht, min_rssi, min_rssi_enabled, antenna_gain, tx_power_mode, site) ⇒ Set wireless properties per AP
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
ap_id | string |
the ID of the AP |
radio | string |
radio type. ng/ac/bg. Optional. Default ng |
channel | number |
The channel number or auto. Optional. Default auto. |
ht | number |
channel width. 20/40/80/160. Optional. Default 20. |
min_rssi | number |
Minimal RSSI accepted in dbi. Optional. Default -94 |
min_rssi_enabled | boolean |
If enabled, drops users bellow that rssi valur. Optional. Default false |
antenna_gain | number |
The antenna gain. Optional. Default 6 dbi |
tx_power_mode | string |
TX Power Mode. Optional. Default auto |
site | string |
Ubiquiti site to query, if different from default - optonal |
Example
unifi
Promise
unifiAPI.status(site) ⇒ Check status
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
site | string |
Ubiquiti site to query, if different from default - optonal |
Example
unifistatus
Promise
unifiAPI.set_ap_network(ap_id, type, ip, netmask, gateway, dns1, dns2, site) ⇒ Configure the network settings of AP/device
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
ap_id | string |
ID of the AP |
type | string |
static or dhcp. Optional. Default dhcp |
ip | string |
IP address. Optional |
netmask | string |
netmask. Optional |
gateway | string |
gateway. Optional |
dns1 | string |
dns. Optional |
dns2 | string |
dns. Optional |
site | string |
Ubiquiti site to query, if different from default - optonal |
Example
unifi
Promise
unifiAPI.request_spectrumscan(mac, site) ⇒ Request a spectrum scan
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
mac | string |
Mac of the AP |
site | string |
Ubiquiti site to query, if different from default - optonal |
Example
unifi
Promise
unifiAPI.set_site_descr(description, site) ⇒ Set description to the site
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
description | string |
description |
site | string |
Ubiquiti site to query, if different from default - optonal |
Example
unifi
Promise
unifiAPI.set_site_settings(gen_id, site_id, advanced, alerts, auto_upgrade, key, led_enabled, x_ssh_username, x_ssh_password, site) ⇒ Set settings of the site (optional)
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Todo
- To be tested and completed
Param | Type | Description |
---|---|---|
gen_id | string |
The id of the settings |
site_id | string |
The id of the site |
advanced | boolean |
advanced options enabled. Optional. default true |
alerts | boolean |
alerts enabled. Optional. default true |
auto_upgrade | boolean |
auto upgrade of the AP enabled. Optional. default true |
key | string |
always mgmt. Optional. default mgmt |
led_enabled | boolean |
Led enabled. Optional. default true |
x_ssh_username | string |
SSH username. Optional. Default ubnt |
x_ssh_password | string |
SSH password. Optional. Default ubnt |
site | string |
Ubiquiti site to query, if different from default - optonal |
Example
unifi
Promise
unifiAPI.add_hotspot2(name, network_access_internet, network_type, venue_group, venue_type, site) ⇒ Add HotSpot 2.0 configuration
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
name | string |
hotspot name. Default hotspot |
network_access_internet | string |
Network access |
network_type | number |
Network type. Optional. Default 2 |
venue_group | number |
Venue group. Optional. Default 2 |
venue_type | number |
Venue type. Optional. Default 0 |
site | string |
Ubiquiti site to query, if different from default - optonal |
Example
unifi
Promise
unifiAPI.list_hotspot2(site) ⇒ List hotspot 2.0 configurations
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
site | string |
Ubiquiti site to query, if different from default - optonal |
Example
unifi
Promise
unifiAPI.delete_hotspot2(site) ⇒ Delete hotspot 2.0 configuration
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
site | string |
Ubiquiti site to query, if different from default - optonal |
Example
unifi
Example
unifi
Promise
unifiAPI.set_hotspot2(hs_id, name, network_access_internet, network_type, venue_group, venue_type, site) ⇒ Modify Hotspot 2.0 configuration
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
hs_id | string |
Hotspot2.0 config id |
name | string |
name. Optional |
network_access_internet | string |
Network access. Optional |
network_type | number |
Network type. Optional |
venue_group | number |
Venue group. Optional |
venue_type | number |
Venue type. Optional |
site | string |
Ubiquiti site to query, if different from default - optonal |
Example
unifi
Promise
unifiAPI.remove_wlanconf(id, site) ⇒ Remove WLAN configuration
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
id | string |
wlan config id |
site | string |
Ubiquiti site to query, if different from default - optonal |
Example
unifi
Promise
unifiAPI.sdn_register(username, password, site) ⇒ Register to the SDN (Ubiquiti cloud)
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
username | string |
Cloud username |
password | string |
Cloud password |
site | string |
Ubiquiti site to query, if different from default - optonal |
Example
unifi
Promise
unifiAPI.sdn_unregister(site) ⇒ Deregister of the SDN (Ubiquiti cloud)
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
site | string |
Ubiquiti site to query, if different from default - optonal |
Example
unifi
Promise
unifiAPI.sdn_stat(site) ⇒ Get information about the Ubiquiti cloud registration
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
site | string |
Ubiquiti site to query, if different from default - optonal |
Example
unifi
Promise
unifiAPI.sdn_onoff(enabled, site_id, site) ⇒ SDN on, off, deregistration
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
enabled | boolean |
Enable SDN or disable it. Default true |
site_id | string |
Site id |
site | string |
Ubiquiti site to query, if different from default - optonal |
Example
unifi
Promise
unifiAPI.extend_voucher(voucher_id, site) ⇒ Extend voucher
Kind: instance method of UnifiAPI
Returns: Promise
- Promise
Todo
- Test it and verify that the REST url is correct
Param | Type | Description |
---|---|---|
voucher_id | string |
voucher id |
site | string |
Ubiquiti site to query, if different from default - optonal |
Example
unifi
Promise
list_settings(site) ⇒ Alias to list_settings. Retrieve array with settings defined by setting key.
Kind: global function
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
site | string |
Ubiquiti site to query, if different from default - optional |
Example
unifi
SSHSession
SSH(mac, uuid, stun, turn, username, password, site, autoclose, webrtc, waiter) ⇒ Open SSH tunnel to a device managed by the controller (currently only Unifi AP) using WebRTC
Kind: global function
Returns: SSHSession
- Return SSHSession object with connect, send, recv, expect, close methods
Param | Type | Description |
---|---|---|
mac | string |
The mac address of the AP |
uuid | string |
Unique UUID of the session. Optional. Auto generated if undefined |
stun | string |
Stun server url. Optional. If undefined, automatically populated |
turn | string |
Turn server url. Optional. If undefined, automatically populated |
username | string |
Turn username. Optional |
password | string |
Turn password. Optional |
site | string |
Ubiquiti site to query, if different from default - optonal |
autoclose | number |
Timeout (milisec) of inactivity before the session is automatically closed. Optional. Default 30000 |
webrtc | object |
Object containing initialized WebRTC module. Optional. If not specified wrtc module is used or the one set in the UnifiAPI initialization. Tested with electron-webrtc |
waiter | number |
How many ms to wait before the next webrtc API call. Optionl. With wrtc is 100ms. However with electron-webrtc must be more than 1500 to avoid crashing on MAC and sometimes on Linux |
Example
let ssh = unifi;ssh
CloudAPI(options) ⇒
Cloud API interface. Under the .api method there will be all of the UnifiAPI calls (over WebRTC)
Kind: global function
Returns: CloudAPI
Param | Type | Description |
---|---|---|
options | object |
default parameters to access Unifi Cloud |
options.username | string |
Cloud username |
options.password | string |
Cloud password |
options.debug | boolean |
Debug the module. Optional. Default false |
options.deviceId | string |
Default Device Id |
options.gzip | boolean |
If gzip is enabled for the cloud messages. Optional. default true |
options.webrtc | object |
Reference to WebRTC module for NodeJS. If non specified, wrtc is used. Tested with electron-webrtc |
options.waiter | object |
How many ms to wait before WebRTC API call. Necessary for electron-webrtc as too fast calls crash the communication (values > 1000ms must be set for electron-webrtc) |
Example
let CloudAPI = ;let cloud = ;cloudself
- CloudAPI(options) ⇒
- .debugging(enabled) ⇒
undefined
- .login(username, password) ⇒
Promise
- .logout() ⇒
Promise
- .self() ⇒
Promise
- .devices() ⇒
Promise
- .delete_device(device_id) ⇒
Promise
- .debugging(enabled) ⇒
undefined
cloudAPI.debugging(enabled) ⇒ Enable or disable debugging
Kind: instance method of CloudAPI
Param | Type | Description |
---|---|---|
enabled | boolean |
Enable or Disable debugging |
Promise
cloudAPI.login(username, password) ⇒ Explicit login. Optional call as implicit login is always in place
Kind: instance method of CloudAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
username | string |
username if different from default. |
password | string |
password if different from default. |
Example
cloud
Promise
cloudAPI.logout() ⇒ Explicit logout
Kind: instance method of CloudAPI
Returns: Promise
- Promise
Example
cloud
Promise
cloudAPI.self() ⇒ Check information about self
Kind: instance method of CloudAPI
Returns: Promise
- Promise
Example
cloudself
Promise
cloudAPI.devices() ⇒ List registered devices / controllers
Kind: instance method of CloudAPI
Returns: Promise
- Promise
Example
cloud
Promise
cloudAPI.delete_device(device_id) ⇒ Forget device/controller
Kind: instance method of CloudAPI
Returns: Promise
- Promise
Param | Type | Description |
---|---|---|
device_id | string |
ID of the device |
Example
cloud