Compare commits
121 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
acc783520f | ||
|
|
e95961834b | ||
|
|
6f8d90b4f0 | ||
|
|
1a9de7cb47 | ||
|
|
c1e398118d | ||
|
|
766eac5944 | ||
|
|
d0df4db012 | ||
|
|
0981857a39 | ||
|
|
f2050c1e00 | ||
|
|
02c0953294 | ||
|
|
e9bdb783c9 | ||
|
|
d240294cee | ||
|
|
ba7e10f1c0 | ||
|
|
465c223c15 | ||
|
|
6995d10419 | ||
|
|
fe4c18c53e | ||
|
|
05cb58b9f1 | ||
|
|
cf354b1d66 | ||
|
|
aca184263d | ||
|
|
a9ddf16fc9 | ||
|
|
b1e99f8747 | ||
|
|
ec86db23e1 | ||
|
|
272e8f65b2 | ||
|
|
25a12021e2 | ||
|
|
aa11f99d9d | ||
|
|
f5950504e8 | ||
|
|
ed2ceec9c4 | ||
|
|
8b5992979c | ||
|
|
2cc60dbc3c | ||
|
|
3e99b7b9a0 | ||
|
|
23b931a663 | ||
|
|
ee0bfe430b | ||
|
|
73ae5a4630 | ||
|
|
13cb313cd9 | ||
|
|
1d363deb18 | ||
|
|
f343d3ccc4 | ||
|
|
f34cbd675b | ||
|
|
64dcf6e4ad | ||
|
|
5d48e57c06 | ||
|
|
f9ce6bf54f | ||
|
|
11c132b263 | ||
|
|
5a64a0c844 | ||
|
|
898703db5c | ||
|
|
551c1c3741 | ||
|
|
a2bfd29590 | ||
|
|
146495d4a1 | ||
|
|
1aa8956445 | ||
|
|
77c4b17003 | ||
|
|
a5ca53a5b8 | ||
|
|
089b0b77ae | ||
|
|
0263c47be9 | ||
|
|
d722d7b843 | ||
|
|
3cf7b4d173 | ||
|
|
6b230753a0 | ||
|
|
19dc76ddfb | ||
|
|
3a1d1ff0cd | ||
|
|
8eeeb447c9 | ||
|
|
8acaa694ca | ||
|
|
d81a371239 | ||
|
|
7a47bda1c0 | ||
|
|
fb493f4dc8 | ||
|
|
1f19891d90 | ||
|
|
9a2432f067 | ||
|
|
97510ec5ec | ||
|
|
9726378e3c | ||
|
|
494375f8b5 | ||
|
|
3dbc24daca | ||
|
|
93d1d8ec3f | ||
|
|
b8620f7672 | ||
|
|
1e2e709d4a | ||
|
|
472d2eaa68 | ||
|
|
1522992e49 | ||
|
|
70f6a374e2 | ||
|
|
ff9e6f0225 | ||
|
|
00a637dbc4 | ||
|
|
6498b0255b | ||
|
|
05e791bcf0 | ||
|
|
192a1262c3 | ||
|
|
30056f50fc | ||
|
|
d040c512a7 | ||
|
|
b633fa54c7 | ||
|
|
5327d0c534 | ||
|
|
f1fc80f34f | ||
|
|
f82d1a6b64 | ||
|
|
6f6e80e862 | ||
|
|
4fefc11761 | ||
|
|
0db5effe6f | ||
|
|
fd69d844a6 | ||
|
|
12b85ce9db | ||
|
|
54ec631d4b | ||
|
|
fdea77fce0 | ||
|
|
108ddd3995 | ||
|
|
63600f4da1 | ||
|
|
20aa3e1377 | ||
|
|
d36a088101 | ||
|
|
007117cbfc | ||
|
|
7e60ce3e87 | ||
|
|
83d4f121ed | ||
|
|
bd39c325d2 | ||
|
|
4b175ddf9b | ||
|
|
48482d661a | ||
|
|
563739345c | ||
|
|
fdc5f06765 | ||
|
|
35b2fb37f3 | ||
|
|
8c1b33ed09 | ||
|
|
b6a22abc01 | ||
|
|
3aa658eab0 | ||
|
|
a4258f1963 | ||
|
|
cf5ba015b0 | ||
|
|
2970f79290 | ||
|
|
7fe7a40873 | ||
|
|
df1f70547c | ||
|
|
e89daaf1a3 | ||
|
|
d66c3ddd75 | ||
|
|
9e092f8b85 | ||
|
|
e4dc2e273c | ||
|
|
67d318ca91 | ||
|
|
cbe89d913c | ||
|
|
4fe1780e1d | ||
|
|
61bd2eda0d | ||
|
|
746fb0933c |
6
.gitignore
vendored
6
.gitignore
vendored
@@ -14,3 +14,9 @@
|
|||||||
|
|
||||||
# ignore PHPStorm files
|
# ignore PHPStorm files
|
||||||
.idea/*
|
.idea/*
|
||||||
|
|
||||||
|
# ignore the TODO list
|
||||||
|
TODO.md
|
||||||
|
|
||||||
|
# ignore Claude Code files
|
||||||
|
CLAUDE*.md
|
||||||
2334
API_REFERENCE.md
Executable file
2334
API_REFERENCE.md
Executable file
File diff suppressed because it is too large
Load Diff
@@ -1,6 +1,6 @@
|
|||||||
MIT License
|
MIT License
|
||||||
|
|
||||||
Copyright (c) 2016, Art of WiFi
|
Copyright (c) 2024, Art of WiFi
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
of this software and associated documentation files (the "Software"), to deal
|
of this software and associated documentation files (the "Software"), to deal
|
||||||
|
|||||||
491
README.md
491
README.md
@@ -1,99 +1,133 @@
|
|||||||
## UniFi Controller API client class
|
## UniFi Controller API client class
|
||||||
|
|
||||||
A PHP class that provides access to Ubiquiti's [**UniFi Network Controller**](https://unifi-network.ui.com/) API.
|
[](https://github.com/Art-of-WiFi/UniFi-API-client/blob/main/LICENSE)
|
||||||
|
[](https://packagist.org/packages/art-of-wifi/unifi-api-client)
|
||||||
|
[](https://packagist.org/packages/art-of-wifi/unifi-api-client)
|
||||||
|
[](https://packagist.org/packages/art-of-wifi/unifi-api-client)
|
||||||
|
|
||||||
UniFi Network Controller software versions 4.X.X, 5.X.X and 6.X.X are supported as well as UniFi OS-based controllers (version 6.5.55 has been confirmed to work).
|
A PHP class that provides access to Ubiquiti's [**UniFi Network Application**](https://unifi-network.ui.com/) API.
|
||||||
This class is used by our API browser tool which can be found [here](https://github.com/Art-of-WiFi/UniFi-API-browser).
|
|
||||||
|
This class is used by our API Browser tool, which can be found
|
||||||
|
[here](https://github.com/Art-of-WiFi/UniFi-API-browser).
|
||||||
|
|
||||||
The package can be installed manually or by using
|
The package can be installed manually or by using
|
||||||
composer/[packagist](https://packagist.org/packages/art-of-wifi/unifi-api-client) for
|
composer/[packagist](https://packagist.org/packages/art-of-wifi/unifi-api-client) for
|
||||||
easy inclusion in your projects.
|
easy inclusion in your projects. See the [installation instructions](#Installation) below for more details.
|
||||||
|
|
||||||
|
|
||||||
|
## Why use this API client?
|
||||||
|
|
||||||
|
- Easy to use: clear docs, comprehensive method coverage, and helpful examples.
|
||||||
|
- Broad coverage: exposes many UniFi endpoints not (yet) available in the official APIs.
|
||||||
|
- Composer-friendly: installable via [Composer](https://getcomposer.org) and works with modern PHP projects.
|
||||||
|
- Lightweight and dependency-free: no external libraries required; uses cURL.
|
||||||
|
- Secure: communicates over TLS and supports optional SSL certificate validation.
|
||||||
|
- Flexible and extensible: includes `custom_api_request()` for calling any API endpoint.
|
||||||
|
- Robust error handling: throws named Exceptions for precise try/catch handling.
|
||||||
|
- Actively maintained: regular updates and compatibility with recent UniFi versions.
|
||||||
|
|
||||||
|
|
||||||
|
## Supported Versions
|
||||||
|
|
||||||
|
| Software | Versions |
|
||||||
|
|--------------------------------------|-----------------------------------------------------------|
|
||||||
|
| UniFi Network Application/controller | 5.x, 6.x, 7.x, 8.x, 9.x, 10.x (**10.0.154 is confirmed**) |
|
||||||
|
| UniFi OS | 3.x, 4.x, 5.x (**5.0.5 is confirmed**) |
|
||||||
|
|
||||||
|
|
||||||
## Requirements
|
## Requirements
|
||||||
|
|
||||||
- a server with:
|
- a server or desktop with:
|
||||||
- PHP 5.5.0 or higher
|
- PHP **7.4.0** or higher (use version [1.1.83](https://github.com/Art-of-WiFi/UniFi-API-client/releases/tag/v1.1.83)
|
||||||
- PHP json and PHP cURL modules
|
for PHP 7.3.x and lower)
|
||||||
- tested on Apache 2.4 with PHP 5.6.1 and cURL 7.42.1 and with PHP 7.4.9 and cURL 7.68.0
|
- PHP cURL (`php-curl`) module enabled
|
||||||
- direct network connectivity between this server and the host and port (normally TCP port 8443 or port 443 for
|
- direct network connectivity between this server/desktop and the host and port where the UniFi Network Application is
|
||||||
UniFi OS) where the UniFi Controller is running
|
running (usually TCP port 8443, port 11443 for UniFi OS Server, or port 443 for UniFi OS consoles)
|
||||||
- you must use **accounts with local access**, not pure UniFi Cloud accounts, to access the UniFi Controller API through
|
- you **must** use an admin **account with local access permissions** to access the API through this class as explained
|
||||||
this class
|
here:
|
||||||
|
https://artofwifi.net/blog/use-local-admin-account-unifi-api-captive-portal
|
||||||
|
- do **not** use UniFi Cloud accounts and do not enable MFA/2FA for the accounts that you use with this class
|
||||||
|
|
||||||
|
|
||||||
## UniFi OS Support
|
## UniFi OS Support
|
||||||
|
|
||||||
Support for UniFi OS-based controllers (UniFi Dream Router, UniFi Dream Machine, UniFi Dream Machine Pro
|
Starting from version **1.1.47**, this API client also supports UniFi OS-based controllers. These
|
||||||
or Cloud Key Gen2/Cloud Key Gen2 Plus with firmware version 2.0.24 or higher) has
|
applications/devices/services have been verified to work:
|
||||||
been added as of version 1.1.47. The class automatically detects UniFi OS devices and
|
- UniFi OS Server, announcement [here](https://blog.ui.com/article/introducing-unifi-os-server)
|
||||||
adjusts URLs and several functions/methods accordingly. If your own code implements strict
|
- UniFi Dream Router (UDR)
|
||||||
validation of the URL that is passed to the constructor, please adapt your logic to
|
- UniFi Dream Machine (UDM)
|
||||||
allow URLs without a port suffix or with port 443 when dealing with a UniFi OS-based
|
- UniFi Dream Machine Pro (UDM PRO)
|
||||||
controller.
|
- UniFi Cloud Key Gen2 (UCK G2), firmware version 2.0.24 or higher
|
||||||
|
- UniFi Cloud Key Gen2 Plus (UCK G2 Plus), firmware version 2.0.24 or higher
|
||||||
|
- UniFi Express (UX)
|
||||||
|
- UniFi Dream Wall (UDW)
|
||||||
|
- UniFi Cloud Gateway Ultra (UCG-Ultra)
|
||||||
|
- UniFi CloudKey Enterprise (CK-Enterprise)
|
||||||
|
- UniFi Enterprise Fortress Gateway (EFG)
|
||||||
|
- Official UniFi Hosting, details [here](https://help.ui.com/hc/en-us/articles/4415364143511)
|
||||||
|
- HostiFi UniFi Cloud Hosting, details [here](https://hostifi.com/unifi)
|
||||||
|
|
||||||
|
The class automatically detects UniFi OS consoles/servers and adjusts URLs and several functions/methods accordingly.
|
||||||
|
|
||||||
|
UniFi OS-based consoles require you to connect using port **443** while **8443** which is used for
|
||||||
|
the self-hosted/software-based controllers. When connecting to **UniFi OS Server**, you are required to use port
|
||||||
|
**11443**.
|
||||||
|
|
||||||
|
|
||||||
|
### Remote API access to UniFi OS-based gateways
|
||||||
|
When connecting to a UniFi OS-based gateway through the WAN interface, you need to create a specific firewall rule to
|
||||||
|
allow this. See this blog post on the Art of WiFi website for detailed instructions when using the **"Classic"**
|
||||||
|
firewall:
|
||||||
|
https://artofwifi.net/blog/how-to-access-the-unifi-controller-by-wan-ip-or-hostname-on-a-udm-pro
|
||||||
|
|
||||||
|
See this blog post when using the **Zone-Based firewall** (ZBF):
|
||||||
|
https://artofwifi.net/blog/how-to-access-the-unifi-controller-by-wan-ip-or-hostname-on-a-udm-pro-using-zbf
|
||||||
|
|
||||||
|
|
||||||
|
## Upgrading from previous versions
|
||||||
|
|
||||||
|
When upgrading from a version before **2.0.0**, please:
|
||||||
|
- change your code to use the new Exceptions that are thrown by the class
|
||||||
|
- test the client with your code for any breaking changes
|
||||||
|
- make sure you are using [Composer](#composer) to install the class because the code is no longer held within a single
|
||||||
|
file
|
||||||
|
- see the note [here](#looking-for-version-1xx) regarding the single file version (1.x.x) of the API client
|
||||||
|
|
||||||
Please test all methods you plan on using thoroughly before using the API Client with
|
|
||||||
UniFi OS devices in a production environment.
|
|
||||||
|
|
||||||
## Installation
|
## Installation
|
||||||
|
|
||||||
Use [Composer](#composer), [Git](#git) or simply [Download the Release](#download-the-release) to install the
|
The preferred installation method is through [Composer](https://getcomposer.org).
|
||||||
API client class.
|
Follow these [installation instructions](https://getcomposer.org/doc/00-intro.md) if you don't have Composer
|
||||||
|
|
||||||
### Composer
|
|
||||||
|
|
||||||
The preferred installation method is through [composer](https://getcomposer.org).
|
|
||||||
Follow these [installation instructions](https://getcomposer.org/doc/00-intro.md) if you don't have composer
|
|
||||||
installed already.
|
installed already.
|
||||||
|
|
||||||
Once composer is installed, simply execute this command from the shell in your project
|
Once Composer is installed, execute this command from the shell in your project directory:
|
||||||
directory:
|
|
||||||
|
|
||||||
```sh
|
```sh
|
||||||
composer require art-of-wifi/unifi-api-client
|
composer require art-of-wifi/unifi-api-client
|
||||||
```
|
```
|
||||||
|
|
||||||
Or manually add the package to your composer.json file:
|
Or manually add the package to your `composer.json` file:
|
||||||
|
|
||||||
```javascript
|
```javascript
|
||||||
{
|
{
|
||||||
"require": {
|
"require": {
|
||||||
"art-of-wifi/unifi-api-client": "^1.1"
|
"art-of-wifi/unifi-api-client": "^2.0"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
Finally, be sure to include the autoloader in your code:
|
Finally, be sure to include the composer autoloader in your code if your framework doesn't already do this for you:
|
||||||
|
|
||||||
```php
|
```php
|
||||||
|
/**
|
||||||
|
* load the class using the composer autoloader
|
||||||
|
*/
|
||||||
require_once 'vendor/autoload.php';
|
require_once 'vendor/autoload.php';
|
||||||
```
|
```
|
||||||
|
|
||||||
### Git
|
|
||||||
|
|
||||||
Execute the following `git` command from the shell in your project directory:
|
|
||||||
|
|
||||||
```sh
|
|
||||||
git clone https://github.com/Art-of-WiFi/UniFi-API-client.git
|
|
||||||
```
|
|
||||||
|
|
||||||
When git is done cloning, include the file containing the class like so in your code:
|
|
||||||
|
|
||||||
```php
|
|
||||||
require_once 'path/to/src/Client.php';
|
|
||||||
```
|
|
||||||
|
|
||||||
### Download the Release
|
|
||||||
|
|
||||||
If you prefer not to use composer or git,
|
|
||||||
simply [download the package](https://github.com/Art-of-WiFi/UniFi-API-client/archive/master.zip), unpack the zip
|
|
||||||
file, then include the file containing the class in your code like so:
|
|
||||||
|
|
||||||
```php
|
|
||||||
require_once 'path/to/src/Client.php';
|
|
||||||
```
|
|
||||||
|
|
||||||
## Example usage
|
## Example usage
|
||||||
|
|
||||||
A basic example how to use the class:
|
A quick and basic example of how to use the class:
|
||||||
|
|
||||||
```php
|
```php
|
||||||
/**
|
/**
|
||||||
@@ -110,233 +144,154 @@ $login = $unifi_connection->login();
|
|||||||
$results = $unifi_connection->list_alarms(); // returns a PHP array containing alarm objects
|
$results = $unifi_connection->list_alarms(); // returns a PHP array containing alarm objects
|
||||||
```
|
```
|
||||||
|
|
||||||
Please refer to the `examples/` directory for some more detailed examples which can be used as a starting point for your
|
|
||||||
own PHP code.
|
|
||||||
|
|
||||||
#### IMPORTANT NOTES:
|
#### IMPORTANT NOTES:
|
||||||
|
|
||||||
1. In the above example, `$site_id` is the short site "name" (usually 8 characters long) that is visible in the URL when
|
1. In the above example, `$site_id` is the short site "name" (usually 8 characters long) that is visible in the URL when
|
||||||
managing the site in the UniFi Network Controller. For example with this URL:
|
managing the site in the UniFi Network Controller. For example, with this URL:
|
||||||
|
|
||||||
`https://<controller IP address or FQDN>:8443/manage/site/jl3z2shm/dashboard`
|
`https://<controller IP address or FQDN>:8443/manage/site/jl3z2shm/dashboard`
|
||||||
|
|
||||||
`jl3z2shm` is the short site "name" and the value to assign to $site_id.
|
`jl3z2shm` is the short site "name" and the value to assign to $site_id.
|
||||||
|
|
||||||
2. The 6th optional parameter that is passed to the constructor in the above example (`true`), enables validation of
|
2. The 6th optional parameter that is passed to the constructor in the above example (`true`), enables validation of
|
||||||
the controller's SSL certificate which is otherwise **disabled** by default. It is **highly recommended** to enable
|
the controller's SSL certificate, which is otherwise **disabled** by default. It is **highly recommended** to enable
|
||||||
this feature in production environments where you have a valid SSL cert installed on the UniFi Controller that is
|
this feature in production environments where you have a valid SSL cert installed on the UniFi Controller that is
|
||||||
associated with the FQDN in the `controller_url` parameter. This option was added with API client version 1.1.16.
|
associated with the FQDN in the `controller_url` parameter. This option was added with API client version 1.1.16.
|
||||||
|
|
||||||
3. Using an administrator account (`$controller_user` in the above example) with **read-only** permissions can limit
|
3. Using an administrator account (`$controller_user` in the above example) with **read-only** permissions can limit
|
||||||
visibility on certain collection/object properties. See this [issue](https://github.com/Art-of-WiFi/UniFi-API-client/issues/129)
|
visibility on certain collection/object properties. See this
|
||||||
and this [issue](https://github.com/Art-of-WiFi/UniFi-API-browser/issues/94) for an example where the WPA2 password
|
[issue](https://github.com/Art-of-WiFi/UniFi-API-client/issues/129) and this
|
||||||
isn't accessible for **read-only** administrator accounts.
|
[issue](https://github.com/Art-of-WiFi/UniFi-API-browser/issues/94) for an example where the WPA2 password isn't
|
||||||
|
visible for **read-only** administrator accounts.
|
||||||
|
|
||||||
|
### Code Examples:
|
||||||
|
|
||||||
|
More code examples are available in the [`examples/`](examples/) directory.
|
||||||
|
|
||||||
|
## Exception handling
|
||||||
|
|
||||||
|
The class now throws **Exceptions** for various error conditions instead of using PHP's `trigger_error()` function. This
|
||||||
|
allows for more granular error handling in your application code.
|
||||||
|
|
||||||
|
You can also choose to catch the `UniFi_API\Exceptions\UnifiApiException` Exception to catch all Exceptions that
|
||||||
|
might be thrown by the API Client class.
|
||||||
|
|
||||||
|
Here is an example of how to catch each of the Exceptions individually:
|
||||||
|
```php
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* PHP API usage example with Exception handling
|
||||||
|
*/
|
||||||
|
use UniFi_API\Exceptions\CurlExtensionNotLoadedException;
|
||||||
|
use UniFi_API\Exceptions\CurlGeneralErrorException;
|
||||||
|
use UniFi_API\Exceptions\CurlTimeoutException;
|
||||||
|
use UniFi_API\Exceptions\InvalidBaseUrlException;
|
||||||
|
use UniFi_API\Exceptions\InvalidSiteNameException;
|
||||||
|
use UniFi_API\Exceptions\JsonDecodeException;
|
||||||
|
use UniFi_API\Exceptions\LoginFailedException;
|
||||||
|
use UniFi_API\Exceptions\LoginRequiredException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* load the class using the composer autoloader
|
||||||
|
*/
|
||||||
|
require_once 'vendor/autoload.php';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* include the config file (place your credentials etc. there if not already present)
|
||||||
|
*/
|
||||||
|
require_once 'config.php';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* initialize the UniFi API connection class, log in to the controller and request the alarms collection
|
||||||
|
* (this example assumes you have already assigned the correct values to the variables in config.php)
|
||||||
|
*/
|
||||||
|
try {
|
||||||
|
$unifi_connection = new UniFi_API\Client($controller_user, $controller_password, $controller_url, $site_id, $controller_version, true);
|
||||||
|
$login = $unifi_connection->login();
|
||||||
|
$results = $unifi_connection->list_alarms(); // returns a PHP array containing alarm objects
|
||||||
|
} catch (CurlExtensionNotLoadedException $e) {
|
||||||
|
echo 'CurlExtensionNotLoadedException: ' . $e->getMessage(). PHP_EOL;
|
||||||
|
} catch (InvalidBaseUrlException $e) {
|
||||||
|
echo 'InvalidBaseUrlException: ' . $e->getMessage(). PHP_EOL;
|
||||||
|
} catch (InvalidSiteNameException $e) {
|
||||||
|
echo 'InvalidSiteNameException: ' . $e->getMessage(). PHP_EOL;
|
||||||
|
} catch (JsonDecodeException $e) {
|
||||||
|
echo 'JsonDecodeException: ' . $e->getMessage(). PHP_EOL;
|
||||||
|
} catch (LoginRequiredException $e) {
|
||||||
|
echo 'LoginRequiredException: ' . $e->getMessage(). PHP_EOL;
|
||||||
|
} catch (CurlGeneralErrorException $e) {
|
||||||
|
echo 'CurlGeneralErrorException: ' . $e->getMessage(). PHP_EOL;
|
||||||
|
} catch (CurlTimeoutException $e) {
|
||||||
|
echo 'CurlTimeoutException: ' . $e->getMessage(). PHP_EOL;
|
||||||
|
} catch (LoginFailedException $e) {
|
||||||
|
echo 'LoginFailedException: ' . $e->getMessage(). PHP_EOL;
|
||||||
|
} catch (Exception $e) {
|
||||||
|
/** catch any other Exceptions that might be thrown */
|
||||||
|
echo 'General Exception: ' . $e->getMessage(). PHP_EOL;
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
Although the PHP DocBlocks for most public methods/functions contain `@throws Exception`, it is recommended to catch
|
||||||
|
specific Exceptions that can be thrown by the API Client class to provide more detailed error messages to your
|
||||||
|
application code.
|
||||||
|
|
||||||
|
In most cases, the class will let Exceptions bubble up to the calling code, but in some cases it will catch them and
|
||||||
|
throw a new Exception with a more specific message.
|
||||||
|
|
||||||
|
The `list_alarms.php` example in the `examples/` directory is a good starting point to see how you can implement
|
||||||
|
Exception handling.
|
||||||
|
|
||||||
|
|
||||||
## Functions/methods supported
|
## Functions/methods supported
|
||||||
|
|
||||||
The class currently supports the following functions/methods to GET/POST/PUT/DELETE data
|
The class currently supports a large and growing number of functions/methods to access the UniFi Controller API.
|
||||||
through the UniFi Controller API. Please refer to the comments in the source code for
|
Please refer to the comments/PHP DocBlocks in the source code for more details on each of the functions/methods,
|
||||||
more details on each of the functions/methods and their respective parameters.
|
their purpose, and their respective parameters.
|
||||||
|
|
||||||
- login()
|
If you are using an advanced IDE such as PHPStorm or VS Code, you can use its code completion and other
|
||||||
- logout()
|
features to explore the available functions/methods thanks to the extensive PHP DocBlocks throughout the code.
|
||||||
- adopt_device()
|
|
||||||
- archive_alarm()
|
|
||||||
- assign_existing_admin()
|
|
||||||
- authorize_guest()
|
|
||||||
- block_sta()
|
|
||||||
- cancel_rolling_upgrade()
|
|
||||||
- check_controller_update()
|
|
||||||
- check_firmware_update()
|
|
||||||
- cmd_stat()
|
|
||||||
- count_alarms()
|
|
||||||
- create_apgroup() (supported with controller versions 6.0.X and higher)
|
|
||||||
- create_dynamicdns()
|
|
||||||
- create_firewallgroup()
|
|
||||||
- create_hotspotop()
|
|
||||||
- create_network()
|
|
||||||
- create_radius_account()
|
|
||||||
- create_site()
|
|
||||||
- create_user()
|
|
||||||
- create_usergroup()
|
|
||||||
- create_voucher()
|
|
||||||
- create_wlan()
|
|
||||||
- custom_api_request()
|
|
||||||
- delete_apgroup() (supported with controller versions 6.0.X and higher)
|
|
||||||
- delete_device()
|
|
||||||
- delete_firewallgroup()
|
|
||||||
- delete_network()
|
|
||||||
- delete_radius_account()
|
|
||||||
- delete_site()
|
|
||||||
- delete_usergroup()
|
|
||||||
- delete_wlan()
|
|
||||||
- disable_ap()
|
|
||||||
- edit_apgroup() (supported with controller versions 6.0.X and higher)
|
|
||||||
- edit_client_fixedip()
|
|
||||||
- edit_client_name()
|
|
||||||
- edit_firewallgroup()
|
|
||||||
- edit_usergroup()
|
|
||||||
- extend_guest_validity()
|
|
||||||
- forget_sta() (supported on controller version 5.9.X and higher)
|
|
||||||
- invite_admin()
|
|
||||||
- led_override()
|
|
||||||
- list_admins()
|
|
||||||
- list_alarms()
|
|
||||||
- list_all_admins()
|
|
||||||
- list_apgroups() (supported with controller versions 6.0.X and higher)
|
|
||||||
- list_aps() (deprecated but still available as alias)
|
|
||||||
- list_backups()
|
|
||||||
- list_clients()
|
|
||||||
- list_country_codes()
|
|
||||||
- list_current_channels()
|
|
||||||
- list_dashboard()
|
|
||||||
- list_device_name_mappings()
|
|
||||||
- list_devices()
|
|
||||||
- list_dpi_stats()
|
|
||||||
- list_dynamicdns()
|
|
||||||
- list_events()
|
|
||||||
- list_extension()
|
|
||||||
- list_firewallgroups()
|
|
||||||
- list_firmware()
|
|
||||||
- list_guests()
|
|
||||||
- list_health()
|
|
||||||
- list_hotspotop()
|
|
||||||
- list_known_rogueaps()
|
|
||||||
- list_networkconf()
|
|
||||||
- list_portconf()
|
|
||||||
- list_portforward_stats()
|
|
||||||
- list_portforwarding()
|
|
||||||
- list_radius_accounts() (supported on controller version 5.5.19 and higher)
|
|
||||||
- list_radius_profiles()
|
|
||||||
- list_rogueaps()
|
|
||||||
- list_routing()
|
|
||||||
- list_self()
|
|
||||||
- list_settings()
|
|
||||||
- list_sites()
|
|
||||||
- list_tags() (supported on controller version 5.5.19 and higher)
|
|
||||||
- list_usergroups()
|
|
||||||
- list_users()
|
|
||||||
- list_wlan_groups()
|
|
||||||
- list_wlanconf()
|
|
||||||
- locate_ap()
|
|
||||||
- move_device()
|
|
||||||
- power_cycle_switch_port()
|
|
||||||
- reboot_cloudkey()
|
|
||||||
- reconnect_sta()
|
|
||||||
- rename_ap()
|
|
||||||
- restart_ap() (deprecated but still available as alias)
|
|
||||||
- restart_device()
|
|
||||||
- revoke_admin()
|
|
||||||
- revoke_voucher()
|
|
||||||
- set_ap_radiosettings()
|
|
||||||
- set_device_settings_base()
|
|
||||||
- set_dynamicdns()
|
|
||||||
- set_element_adoption() (supported on controller version 5.13.X and higher)
|
|
||||||
- set_guestlogin_settings()
|
|
||||||
- set_guestlogin_settings_base()
|
|
||||||
- set_ips_settings_base() (supported on controller version 5.9.10 and higher)
|
|
||||||
- set_locate_ap() (deprecated but still available as alias)
|
|
||||||
- set_networksettings_base()
|
|
||||||
- set_radius_account_base()
|
|
||||||
- set_site_connectivity()
|
|
||||||
- set_site_country()
|
|
||||||
- set_site_guest_access()
|
|
||||||
- set_site_locale()
|
|
||||||
- set_site_mgmt()
|
|
||||||
- set_site_name()
|
|
||||||
- set_site_ntp()
|
|
||||||
- set_site_snmp()
|
|
||||||
- set_sta_name()
|
|
||||||
- set_sta_note()
|
|
||||||
- set_super_identity_settings_base()
|
|
||||||
- set_super_mgmt_settings_base()
|
|
||||||
- set_super_smtp_settings_base()
|
|
||||||
- set_usergroup()
|
|
||||||
- set_wlan_mac_filter()
|
|
||||||
- set_wlansettings()
|
|
||||||
- set_wlansettings_base()
|
|
||||||
- site_leds()
|
|
||||||
- site_ledsoff() (deprecated but still available as alias)
|
|
||||||
- site_ledson() (deprecated but still available as alias)
|
|
||||||
- spectrum_scan()
|
|
||||||
- spectrum_scan_state()
|
|
||||||
- start_rolling_upgrade()
|
|
||||||
- stat_5minutes_aps() (supported on controller version 5.5.X and higher)
|
|
||||||
- stat_5minutes_gateway() (supported on controller version 5.7.X and higher)
|
|
||||||
- stat_5minutes_site() (supported on controller version 5.5.X and higher)
|
|
||||||
- stat_5minutes_user (supported on controller version 5.7.X and higher)
|
|
||||||
- stat_allusers()
|
|
||||||
- stat_auths()
|
|
||||||
- stat_client()
|
|
||||||
- stat_daily_aps()
|
|
||||||
- stat_daily_gateway() (supported on controller version 5.7.X and higher)
|
|
||||||
- stat_daily_site()
|
|
||||||
- stat_daily_user() (supported on controller version 5.7.X and higher)
|
|
||||||
- stat_full_status()
|
|
||||||
- stat_hourly_aps()
|
|
||||||
- stat_hourly_gateway() (supported on controller version 5.7.X and higher)
|
|
||||||
- stat_hourly_site()
|
|
||||||
- stat_hourly_user() (supported on controller version 5.7.X and higher)
|
|
||||||
- stat_ips_events() (supported on controller version 5.9.10 and higher)
|
|
||||||
- stat_monthly_aps()
|
|
||||||
- stat_monthly_gateway()
|
|
||||||
- stat_monthly_site()
|
|
||||||
- stat_monthly_user()
|
|
||||||
- stat_payment()
|
|
||||||
- stat_sessions()
|
|
||||||
- stat_sites()
|
|
||||||
- stat_speedtest_results()
|
|
||||||
- stat_sta_sessions_latest()
|
|
||||||
- stat_status()
|
|
||||||
- stat_sysinfo()
|
|
||||||
- stat_voucher()
|
|
||||||
- unauthorize_guest()
|
|
||||||
- unblock_sta()
|
|
||||||
- unset_locate_ap() (deprecated but still available as alias)
|
|
||||||
- upgrade_device()
|
|
||||||
- upgrade_device_external()
|
|
||||||
|
|
||||||
Other functions, getters/setters:
|
For a quick overview of the available functions/methods, you can also check the API Reference here:
|
||||||
|
[API Reference](API_REFERENCE.md)
|
||||||
|
|
||||||
- get_class_version()
|
|
||||||
- get_cookie() (renamed from getcookie(), deprecated but still available, use get_cookies() instead)
|
|
||||||
- get_cookies()
|
|
||||||
- get_curl_connection_timeout()
|
|
||||||
- get_curl_http_version()
|
|
||||||
- get_curl_method()
|
|
||||||
- get_curl_request_timeout()
|
|
||||||
- get_curl_request_timeout()
|
|
||||||
- get_curl_ssl_verify_host()
|
|
||||||
- get_curl_ssl_verify_peer()
|
|
||||||
- get_debug()
|
|
||||||
- get_is_unifi_os()
|
|
||||||
- get_last_error_message()
|
|
||||||
- get_last_results_raw()
|
|
||||||
- get_site()
|
|
||||||
- set_connection_timeout()
|
|
||||||
- set_cookies()
|
|
||||||
- set_curl_http_version()
|
|
||||||
- set_curl_request_timeout()
|
|
||||||
- set_curl_ssl_verify_host()
|
|
||||||
- set_curl_ssl_verify_peer()
|
|
||||||
- set_debug()
|
|
||||||
- set_is_unifi_os()
|
|
||||||
- set_request_method()
|
|
||||||
- set_request_timeout()
|
|
||||||
- set_site()
|
|
||||||
|
|
||||||
## Need help or have suggestions?
|
## Need help or have suggestions?
|
||||||
|
|
||||||
There is still work to be done to add functionality and further improve the usability of
|
There is still work to be done to add functionality and further improve the usability of
|
||||||
this class, so all suggestions/comments are welcome. Please use the GitHub
|
this class, so all suggestions/comments are welcome. Please use the GitHub
|
||||||
[issue list](https://github.com/Art-of-WiFi/UniFi-API-client/issues) or the Ubiquiti
|
[Issues section](https://github.com/Art-of-WiFi/UniFi-API-client/issues) or the Ubiquiti
|
||||||
Community forums (https://community.ubnt.com/t5/UniFi-Wireless/PHP-class-to-access-the-UniFi-controller-API-updates-and/td-p/1512870)
|
Community forums (https://community.ui.com/questions/PHP-client-class-to-access-the-UniFi-controller-API-updates-and-discussion-part-2/a793904e-6023-4a7f-bcae-340db2a03fc1)
|
||||||
to share your suggestions and questions.
|
to share your suggestions and questions.
|
||||||
|
|
||||||
## Contribute
|
|
||||||
|
|
||||||
If you would like to contribute code (improvements), please open an issue and include
|
#### IMPORTANT NOTE:
|
||||||
your code there or else create a pull request.
|
When encountering issues with the UniFi API using other libraries, cURL or Postman, please do **not** open an Issue.
|
||||||
|
Such issues will be closed immediately. Please use the [Discussions](https://github.com/Art-of-WiFi/UniFi-API-client/discussions) section instead.
|
||||||
|
|
||||||
|
|
||||||
|
## Looking for version 1.x.x?
|
||||||
|
|
||||||
|
With versions 1.x.x of the API client, the entire client was contained within a single file which can be useful in
|
||||||
|
specific cases.
|
||||||
|
This has changed with version 2.0.0 where the code is now split across multiple files and inclusion in your project is
|
||||||
|
managed using composer.
|
||||||
|
|
||||||
|
If you are looking for the version 1.x.x code, you can tell composer to install that version by using the following
|
||||||
|
syntax in your `composer.json` file:
|
||||||
|
|
||||||
|
```javascript
|
||||||
|
{
|
||||||
|
"require": {
|
||||||
|
"art-of-wifi/unifi-api-client": "^1.1"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
Alternatively, you can download the latest 1.x.x code from the [releases page](https://github.com/Art-of-WiFi/UniFi-API-client/releases).
|
||||||
|
|
||||||
|
Whenever necessary, we will make sure to update the **version_1** branch with the latest 1.x.x code.
|
||||||
|
|
||||||
|
|
||||||
## Credits
|
## Credits
|
||||||
|
|
||||||
@@ -347,7 +302,27 @@ This class is based on the initial work by the following developers:
|
|||||||
|
|
||||||
and the API as published by Ubiquiti:
|
and the API as published by Ubiquiti:
|
||||||
|
|
||||||
- https://dl.ui.com/unifi/6.5.55/unifi_sh_api
|
- https://dl.ui.com/unifi/8.6.9/unifi_sh_api
|
||||||
|
|
||||||
|
## Contributors
|
||||||
|
|
||||||
|
A big thanks to all the contributors who have helped with this project!
|
||||||
|
|
||||||
|
[](https://github.com/Art-of-WiFi/UniFi-API-client/graphs/contributors)
|
||||||
|
|
||||||
|
If you would like to contribute to this project, please open an issue and include
|
||||||
|
your suggestions or code there or else create a pull request.
|
||||||
|
|
||||||
|
|
||||||
|
## About Art of WiFi
|
||||||
|
|
||||||
|
Art of WiFi develops software and tools that enhance the capabilities of UniFi networks. From captive portals and
|
||||||
|
reporting solutions to device search utilities, our goal is to make UniFi deployments more powerful and easier to
|
||||||
|
manage.
|
||||||
|
|
||||||
|
If you're looking for a specific solution or just want to see what else we offer, feel free to explore our web site:
|
||||||
|
- https://www.artofwifi.net
|
||||||
|
|
||||||
|
|
||||||
## Important Disclaimer
|
## Important Disclaimer
|
||||||
|
|
||||||
|
|||||||
@@ -8,7 +8,8 @@
|
|||||||
"unifi",
|
"unifi",
|
||||||
"controller",
|
"controller",
|
||||||
"api",
|
"api",
|
||||||
"client"
|
"client",
|
||||||
|
"unifi os"
|
||||||
],
|
],
|
||||||
"homepage": "https://github.com/Art-of-WiFi/UniFi-API-client",
|
"homepage": "https://github.com/Art-of-WiFi/UniFi-API-client",
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
@@ -20,7 +21,7 @@
|
|||||||
}
|
}
|
||||||
],
|
],
|
||||||
"require": {
|
"require": {
|
||||||
"php": ">=5.5.0",
|
"php": ">=7.4.0",
|
||||||
"ext-curl": "*",
|
"ext-curl": "*",
|
||||||
"ext-json": "*"
|
"ext-json": "*"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -28,7 +28,14 @@ $ap_mac = '<enter MAC address of Access Point to check>';
|
|||||||
* initialize the UniFi API connection class and log in to the controller and do our thing
|
* initialize the UniFi API connection class and log in to the controller and do our thing
|
||||||
* spectrum_scan_state()
|
* spectrum_scan_state()
|
||||||
*/
|
*/
|
||||||
$unifi_connection = new UniFi_API\Client($controlleruser, $controllerpassword, $controllerurl, $site_id, $controllerversion);
|
$unifi_connection = new UniFi_API\Client(
|
||||||
|
$controlleruser,
|
||||||
|
$controllerpassword,
|
||||||
|
$controllerurl,
|
||||||
|
$site_id,
|
||||||
|
$controllerversion
|
||||||
|
);
|
||||||
|
|
||||||
$set_debug_mode = $unifi_connection->set_debug($debug);
|
$set_debug_mode = $unifi_connection->set_debug($debug);
|
||||||
$loginresults = $unifi_connection->login();
|
$loginresults = $unifi_connection->login();
|
||||||
$data = $unifi_connection->spectrum_scan_state($ap_mac);
|
$data = $unifi_connection->spectrum_scan_state($ap_mac);
|
||||||
|
|||||||
@@ -24,7 +24,14 @@ $device_mac = '<enter MAC address of device to update>';
|
|||||||
* initialize the UniFi API connection class, log in to the controller
|
* initialize the UniFi API connection class, log in to the controller
|
||||||
* (this example assumes you have already assigned the correct values in config.php to the variables used)
|
* (this example assumes you have already assigned the correct values in config.php to the variables used)
|
||||||
*/
|
*/
|
||||||
$unifi_connection = new UniFi_API\Client($controlleruser, $controllerpassword, $controllerurl, $site_id, $controllerversion, false);
|
$unifi_connection = new UniFi_API\Client(
|
||||||
|
$controlleruser,
|
||||||
|
$controllerpassword,
|
||||||
|
$controllerurl,
|
||||||
|
$site_id,
|
||||||
|
$controllerversion
|
||||||
|
);
|
||||||
|
|
||||||
$login = $unifi_connection->login();
|
$login = $unifi_connection->login();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
@@ -45,7 +45,14 @@ $site_id = '<enter your site id here>';
|
|||||||
/**
|
/**
|
||||||
* initialize the UniFi API connection class and log in to the controller
|
* initialize the UniFi API connection class and log in to the controller
|
||||||
*/
|
*/
|
||||||
$unifi_connection = new UniFi_API\Client($controlleruser, $controllerpassword, $controllerurl, $site_id, $controllerversion);
|
$unifi_connection = new UniFi_API\Client(
|
||||||
|
$controlleruser,
|
||||||
|
$controllerpassword,
|
||||||
|
$controllerurl,
|
||||||
|
$site_id,
|
||||||
|
$controllerversion
|
||||||
|
);
|
||||||
|
|
||||||
$set_debug_mode = $unifi_connection->set_debug($debug);
|
$set_debug_mode = $unifi_connection->set_debug($debug);
|
||||||
$loginresults = $unifi_connection->login();
|
$loginresults = $unifi_connection->login();
|
||||||
|
|
||||||
|
|||||||
@@ -42,7 +42,14 @@ $note = 'Note to attach to newly authorized device';
|
|||||||
/**
|
/**
|
||||||
* initialize the UniFi API connection class and log in to the controller
|
* initialize the UniFi API connection class and log in to the controller
|
||||||
*/
|
*/
|
||||||
$unifi_connection = new UniFi_API\Client($controlleruser, $controllerpassword, $controllerurl, $site_id, $controllerversion);
|
$unifi_connection = new UniFi_API\Client(
|
||||||
|
$controlleruser,
|
||||||
|
$controllerpassword,
|
||||||
|
$controllerurl,
|
||||||
|
$site_id,
|
||||||
|
$controllerversion
|
||||||
|
);
|
||||||
|
|
||||||
$set_debug_mode = $unifi_connection->set_debug($debug);
|
$set_debug_mode = $unifi_connection->set_debug($debug);
|
||||||
$loginresults = $unifi_connection->login();
|
$loginresults = $unifi_connection->login();
|
||||||
|
|
||||||
|
|||||||
@@ -42,7 +42,14 @@ if ($site_id == "MUST_DEFINE_THIS") {
|
|||||||
/**
|
/**
|
||||||
* initialize the UniFi API connection class and log in to the controller
|
* initialize the UniFi API connection class and log in to the controller
|
||||||
*/
|
*/
|
||||||
$unifi_connection = new UniFi_API\Client($controlleruser, $controllerpassword, $controllerurl, $site_id, $controllerversion);
|
$unifi_connection = new UniFi_API\Client(
|
||||||
|
$controlleruser,
|
||||||
|
$controllerpassword,
|
||||||
|
$controllerurl,
|
||||||
|
$site_id,
|
||||||
|
$controllerversion
|
||||||
|
);
|
||||||
|
|
||||||
$set_debug_mode = $unifi_connection->set_debug($debug);
|
$set_debug_mode = $unifi_connection->set_debug($debug);
|
||||||
$loginresults = $unifi_connection->login(); // always true regardless of site id
|
$loginresults = $unifi_connection->login(); // always true regardless of site id
|
||||||
|
|
||||||
|
|||||||
@@ -25,7 +25,14 @@ $debug = false;
|
|||||||
/**
|
/**
|
||||||
* initialize the UniFi API connection class and log in to the controller and do our thing
|
* initialize the UniFi API connection class and log in to the controller and do our thing
|
||||||
*/
|
*/
|
||||||
$unifi_connection = new UniFi_API\Client($controlleruser, $controllerpassword, $controllerurl, $site_id, $controllerversion, true);
|
$unifi_connection = new UniFi_API\Client(
|
||||||
|
$controlleruser,
|
||||||
|
$controllerpassword,
|
||||||
|
$controllerurl,
|
||||||
|
$site_id,
|
||||||
|
$controllerversion
|
||||||
|
);
|
||||||
|
|
||||||
$set_debug_mode = $unifi_connection->set_debug($debug);
|
$set_debug_mode = $unifi_connection->set_debug($debug);
|
||||||
$loginresults = $unifi_connection->login();
|
$loginresults = $unifi_connection->login();
|
||||||
$site_settings = $unifi_connection->list_settings();
|
$site_settings = $unifi_connection->list_settings();
|
||||||
@@ -34,7 +41,7 @@ $super_mgmt_settings = [];
|
|||||||
$super_mgmt_settings_id = '';
|
$super_mgmt_settings_id = '';
|
||||||
|
|
||||||
if (!empty($site_settings)) {
|
if (!empty($site_settings)) {
|
||||||
foreach($site_settings as $section) {
|
foreach ($site_settings as $section) {
|
||||||
echo 'section key: ' . $section->key . PHP_EOL;
|
echo 'section key: ' . $section->key . PHP_EOL;
|
||||||
if ($section->key === 'super_mgmt') {
|
if ($section->key === 'super_mgmt') {
|
||||||
$super_mgmt_settings = $section;
|
$super_mgmt_settings = $section;
|
||||||
|
|||||||
@@ -35,7 +35,14 @@ $new_password = '<new password goes here>';
|
|||||||
/**
|
/**
|
||||||
* initialize the UniFi API connection class and log in to the controller
|
* initialize the UniFi API connection class and log in to the controller
|
||||||
*/
|
*/
|
||||||
$unifi_connection = new UniFi_API\Client($controlleruser, $controllerpassword, $controllerurl, $site_id, $controllerversion);
|
$unifi_connection = new UniFi_API\Client(
|
||||||
|
$controlleruser,
|
||||||
|
$controllerpassword,
|
||||||
|
$controllerurl,
|
||||||
|
$site_id,
|
||||||
|
$controllerversion
|
||||||
|
);
|
||||||
|
|
||||||
$set_debug_mode = $unifi_connection->set_debug($debug);
|
$set_debug_mode = $unifi_connection->set_debug($debug);
|
||||||
$loginresults = $unifi_connection->login();
|
$loginresults = $unifi_connection->login();
|
||||||
$results = $unifi_connection->set_wlansettings($wlan_id, $new_password);
|
$results = $unifi_connection->set_wlansettings($wlan_id, $new_password);
|
||||||
|
|||||||
@@ -30,7 +30,14 @@ $description = 'new site';
|
|||||||
/**
|
/**
|
||||||
* initialize the UniFi API connection class and log in to the controller and do our thing
|
* initialize the UniFi API connection class and log in to the controller and do our thing
|
||||||
*/
|
*/
|
||||||
$unifi_connection = new UniFi_API\Client($controlleruser, $controllerpassword, $controllerurl, $site_id, $controllerversion);
|
$unifi_connection = new UniFi_API\Client(
|
||||||
|
$controlleruser,
|
||||||
|
$controllerpassword,
|
||||||
|
$controllerurl,
|
||||||
|
$site_id,
|
||||||
|
$controllerversion
|
||||||
|
);
|
||||||
|
|
||||||
$loginresults = $unifi_connection->login();
|
$loginresults = $unifi_connection->login();
|
||||||
$results = $unifi_connection->create_site($description);
|
$results = $unifi_connection->create_site($description);
|
||||||
|
|
||||||
|
|||||||
@@ -35,7 +35,14 @@ $site_id = '<enter your site id here>';
|
|||||||
/**
|
/**
|
||||||
* initialize the UniFi API connection class and log in to the controller
|
* initialize the UniFi API connection class and log in to the controller
|
||||||
*/
|
*/
|
||||||
$unifi_connection = new UniFi_API\Client($controlleruser, $controllerpassword, $controllerurl, $site_id, $controllerversion);
|
$unifi_connection = new UniFi_API\Client(
|
||||||
|
$controlleruser,
|
||||||
|
$controllerpassword,
|
||||||
|
$controllerurl,
|
||||||
|
$site_id,
|
||||||
|
$controllerversion
|
||||||
|
);
|
||||||
|
|
||||||
$set_debug_mode = $unifi_connection->set_debug($debug);
|
$set_debug_mode = $unifi_connection->set_debug($debug);
|
||||||
$loginresults = $unifi_connection->login();
|
$loginresults = $unifi_connection->login();
|
||||||
|
|
||||||
|
|||||||
@@ -31,7 +31,14 @@ $site_to_delete = '<_id value of the site>';
|
|||||||
/**
|
/**
|
||||||
* initialize the UniFi API connection class and log in to the controller and do our thing
|
* initialize the UniFi API connection class and log in to the controller and do our thing
|
||||||
*/
|
*/
|
||||||
$unifi_connection = new UniFi_API\Client($controlleruser, $controllerpassword, $controllerurl, $site_id, $controllerversion);
|
$unifi_connection = new UniFi_API\Client(
|
||||||
|
$controlleruser,
|
||||||
|
$controllerpassword,
|
||||||
|
$controllerurl,
|
||||||
|
$site_id,
|
||||||
|
$controllerversion
|
||||||
|
);
|
||||||
|
|
||||||
$loginresults = $unifi_connection->login();
|
$loginresults = $unifi_connection->login();
|
||||||
$results = $unifi_connection->delete_site($site_to_delete);
|
$results = $unifi_connection->delete_site($site_to_delete);
|
||||||
|
|
||||||
|
|||||||
@@ -30,7 +30,14 @@ $site_id = '<enter your site id here>';
|
|||||||
/**
|
/**
|
||||||
* initialize the UniFi API connection class and log in to the controller
|
* initialize the UniFi API connection class and log in to the controller
|
||||||
*/
|
*/
|
||||||
$unifi_connection = new UniFi_API\Client($controlleruser, $controllerpassword, $controllerurl, $site_id, $controllerversion);
|
$unifi_connection = new UniFi_API\Client(
|
||||||
|
$controlleruser,
|
||||||
|
$controllerpassword,
|
||||||
|
$controllerurl,
|
||||||
|
$site_id,
|
||||||
|
$controllerversion
|
||||||
|
);
|
||||||
|
|
||||||
$set_debug_mode = $unifi_connection->set_debug($debug);
|
$set_debug_mode = $unifi_connection->set_debug($debug);
|
||||||
$loginresults = $unifi_connection->login();
|
$loginresults = $unifi_connection->login();
|
||||||
|
|
||||||
|
|||||||
@@ -46,7 +46,14 @@ $port_conf_id = '<enter _id value of desired port configuration>';
|
|||||||
/**
|
/**
|
||||||
* initialize the UniFi API connection class and log in to the controller and do our thing
|
* initialize the UniFi API connection class and log in to the controller and do our thing
|
||||||
*/
|
*/
|
||||||
$unifi_connection = new UniFi_API\Client($controlleruser, $controllerpassword, $controllerurl, $site_id, $controllerversion, false);
|
$unifi_connection = new UniFi_API\Client(
|
||||||
|
$controlleruser,
|
||||||
|
$controllerpassword,
|
||||||
|
$controllerurl,
|
||||||
|
$site_id,
|
||||||
|
$controllerversion
|
||||||
|
);
|
||||||
|
|
||||||
$set_debug_mode = $unifi_connection->set_debug($debug);
|
$set_debug_mode = $unifi_connection->set_debug($debug);
|
||||||
$loginresults = $unifi_connection->login();
|
$loginresults = $unifi_connection->login();
|
||||||
$data = $unifi_connection->list_devices($device_mac);
|
$data = $unifi_connection->list_devices($device_mac);
|
||||||
|
|||||||
@@ -35,7 +35,14 @@ $return = 'array';
|
|||||||
/**
|
/**
|
||||||
* initialize the UniFi API connection class and log in to the controller and do our thing
|
* initialize the UniFi API connection class and log in to the controller and do our thing
|
||||||
*/
|
*/
|
||||||
$unifi_connection = new UniFi_API\Client($controlleruser, $controllerpassword, $controllerurl, $site_id, $controllerversion);
|
$unifi_connection = new UniFi_API\Client(
|
||||||
|
$controlleruser,
|
||||||
|
$controllerpassword,
|
||||||
|
$controllerurl,
|
||||||
|
$site_id,
|
||||||
|
$controllerversion
|
||||||
|
);
|
||||||
|
|
||||||
$set_debug_mode = $unifi_connection->set_debug($debug);
|
$set_debug_mode = $unifi_connection->set_debug($debug);
|
||||||
$loginresults = $unifi_connection->login();
|
$loginresults = $unifi_connection->login();
|
||||||
$results = $unifi_connection->custom_api_request($url, $request_method, $payload, $return);
|
$results = $unifi_connection->custom_api_request($url, $request_method, $payload, $return);
|
||||||
|
|||||||
@@ -23,7 +23,14 @@ require_once 'config.php';
|
|||||||
$site_id = "default";
|
$site_id = "default";
|
||||||
$site_name = "*enter your site name*";
|
$site_name = "*enter your site name*";
|
||||||
|
|
||||||
$unifi_connection = new UniFi_API\Client($controlleruser, $controllerpassword, $controllerurl, $site_id, $controllerversion);
|
$unifi_connection = new UniFi_API\Client(
|
||||||
|
$controlleruser,
|
||||||
|
$controllerpassword,
|
||||||
|
$controllerurl,
|
||||||
|
$site_id,
|
||||||
|
$controllerversion
|
||||||
|
);
|
||||||
|
|
||||||
$set_debug_mode = $unifi_connection->set_debug($debug);
|
$set_debug_mode = $unifi_connection->set_debug($debug);
|
||||||
$loginresults = $unifi_connection->login();
|
$loginresults = $unifi_connection->login();
|
||||||
|
|
||||||
@@ -36,7 +43,8 @@ if ($loginresults === 400) {
|
|||||||
* loop thru all known guests
|
* loop thru all known guests
|
||||||
*/
|
*/
|
||||||
foreach ($guestlist as $guest) {
|
foreach ($guestlist as $guest) {
|
||||||
print "<pre>" . $guest->_id . " (" . $guest->mac . "), valid until " . date(DATE_ATOM, $guest->end) . " (" . $guest->end . ")</pre>";
|
print "<pre>" . $guest->_id . " (" . $guest->mac . "), valid until " .
|
||||||
|
date(DATE_ATOM, $guest->end) . " (" . $guest->end . ")</pre>";
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* just a sample: only extend validity of guests which have end date after 2017-04-02
|
* just a sample: only extend validity of guests which have end date after 2017-04-02
|
||||||
|
|||||||
@@ -3,8 +3,17 @@
|
|||||||
* PHP API usage example
|
* PHP API usage example
|
||||||
*
|
*
|
||||||
* contributed by: Art of WiFi
|
* contributed by: Art of WiFi
|
||||||
* description: example basic PHP script to pull current alarms from the UniFi controller and output in json format
|
* description: An example basic PHP script to pull current alarms from the UniFi controller and output in JSON format,
|
||||||
|
* also demonstrates how to catch exceptions.
|
||||||
*/
|
*/
|
||||||
|
use UniFi_API\Exceptions\CurlExtensionNotLoadedException;
|
||||||
|
use UniFi_API\Exceptions\CurlGeneralErrorException;
|
||||||
|
use UniFi_API\Exceptions\CurlTimeoutException;
|
||||||
|
use UniFi_API\Exceptions\InvalidBaseUrlException;
|
||||||
|
use UniFi_API\Exceptions\InvalidSiteNameException;
|
||||||
|
use UniFi_API\Exceptions\JsonDecodeException;
|
||||||
|
use UniFi_API\Exceptions\LoginFailedException;
|
||||||
|
use UniFi_API\Exceptions\LoginRequiredException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* using the composer autoloader
|
* using the composer autoloader
|
||||||
@@ -12,8 +21,14 @@
|
|||||||
require_once 'vendor/autoload.php';
|
require_once 'vendor/autoload.php';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* include the config file (place your credentials etc. there if not already present)
|
* Include the config file (place your credentials etc. there if not already present), see the config.template.php
|
||||||
* see the config.template.php file for an example
|
* file for an example.
|
||||||
|
*
|
||||||
|
* @var array $controlleruser
|
||||||
|
* @var array $controllerpassword
|
||||||
|
* @var array $controllerurl
|
||||||
|
* @var array $controllerversion
|
||||||
|
* @var array $debug
|
||||||
*/
|
*/
|
||||||
require_once 'config.php';
|
require_once 'config.php';
|
||||||
|
|
||||||
@@ -25,12 +40,40 @@ $site_id = '<enter your site id here>';
|
|||||||
/**
|
/**
|
||||||
* initialize the UniFi API connection class and log in to the controller and do our thing
|
* initialize the UniFi API connection class and log in to the controller and do our thing
|
||||||
*/
|
*/
|
||||||
$unifi_connection = new UniFi_API\Client($controlleruser, $controllerpassword, $controllerurl, $site_id, $controllerversion);
|
try {
|
||||||
$set_debug_mode = $unifi_connection->set_debug($debug);
|
$unifi_connection = new UniFi_API\Client(
|
||||||
$loginresults = $unifi_connection->login();
|
$controlleruser,
|
||||||
$data = $unifi_connection->list_alarms();
|
$controllerpassword,
|
||||||
|
$controllerurl,
|
||||||
|
$site_id,
|
||||||
|
$controllerversion
|
||||||
|
);
|
||||||
|
|
||||||
/**
|
$set_debug_mode = $unifi_connection->set_debug($debug);
|
||||||
* provide feedback in json format
|
$login_results = $unifi_connection->login();
|
||||||
|
$data = $unifi_connection->list_alarms();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* echo the results in JSON format
|
||||||
*/
|
*/
|
||||||
echo json_encode($data, JSON_PRETTY_PRINT);
|
echo json_encode($data, JSON_PRETTY_PRINT);
|
||||||
|
} catch (CurlExtensionNotLoadedException $e) {
|
||||||
|
echo 'CurlExtensionNotLoadedException: ' . $e->getMessage(). PHP_EOL;
|
||||||
|
} catch (InvalidBaseUrlException $e) {
|
||||||
|
echo 'InvalidBaseUrlException: ' . $e->getMessage(). PHP_EOL;
|
||||||
|
} catch (InvalidSiteNameException $e) {
|
||||||
|
echo 'InvalidSiteNameException: ' . $e->getMessage(). PHP_EOL;
|
||||||
|
} catch (JsonDecodeException $e) {
|
||||||
|
echo 'JsonDecodeException: ' . $e->getMessage(). PHP_EOL;
|
||||||
|
} catch (LoginRequiredException $e) {
|
||||||
|
echo 'LoginRequiredException: ' . $e->getMessage(). PHP_EOL;
|
||||||
|
} catch (CurlGeneralErrorException $e) {
|
||||||
|
echo 'CurlGeneralErrorException: ' . $e->getMessage(). PHP_EOL;
|
||||||
|
} catch (CurlTimeoutException $e) {
|
||||||
|
echo 'CurlTimeoutException: ' . $e->getMessage(). PHP_EOL;
|
||||||
|
} catch (LoginFailedException $e) {
|
||||||
|
echo 'LoginFailedException: ' . $e->getMessage(). PHP_EOL;
|
||||||
|
} catch (Exception $e) {
|
||||||
|
/** catch any other Exceptions that might be thrown */
|
||||||
|
echo 'General Exception: ' . $e->getMessage(). PHP_EOL;
|
||||||
|
}
|
||||||
@@ -26,7 +26,14 @@ $site_id = '<enter your site id here>';
|
|||||||
/**
|
/**
|
||||||
* initialize the UniFi API connection class and log in to the controller and pull the requested data
|
* initialize the UniFi API connection class and log in to the controller and pull the requested data
|
||||||
*/
|
*/
|
||||||
$unifi_connection = new UniFi_API\Client($controlleruser, $controllerpassword, $controllerurl, $site_id, $controllerversion);
|
$unifi_connection = new UniFi_API\Client(
|
||||||
|
$controlleruser,
|
||||||
|
$controllerpassword,
|
||||||
|
$controllerurl,
|
||||||
|
$site_id,
|
||||||
|
$controllerversion
|
||||||
|
);
|
||||||
|
|
||||||
$set_debug_mode = $unifi_connection->set_debug($debug);
|
$set_debug_mode = $unifi_connection->set_debug($debug);
|
||||||
$loginresults = $unifi_connection->login();
|
$loginresults = $unifi_connection->login();
|
||||||
$aps_array = $unifi_connection->list_aps();
|
$aps_array = $unifi_connection->list_aps();
|
||||||
|
|||||||
@@ -25,7 +25,14 @@ $site_id = '<enter your site id here>';
|
|||||||
/**
|
/**
|
||||||
* initialize the UniFi API connection class and log in to the controller and pull the requested data
|
* initialize the UniFi API connection class and log in to the controller and pull the requested data
|
||||||
*/
|
*/
|
||||||
$unifi_connection = new UniFi_API\Client($controlleruser, $controllerpassword, $controllerurl, $site_id, $controllerversion);
|
$unifi_connection = new UniFi_API\Client(
|
||||||
|
$controlleruser,
|
||||||
|
$controllerpassword,
|
||||||
|
$controllerurl,
|
||||||
|
$site_id,
|
||||||
|
$controllerversion
|
||||||
|
);
|
||||||
|
|
||||||
$set_debug_mode = $unifi_connection->set_debug($debug);
|
$set_debug_mode = $unifi_connection->set_debug($debug);
|
||||||
$loginresults = $unifi_connection->login();
|
$loginresults = $unifi_connection->login();
|
||||||
$clients_array = $unifi_connection->list_clients();
|
$clients_array = $unifi_connection->list_clients();
|
||||||
|
|||||||
@@ -26,8 +26,14 @@ $site_id = '<enter your site id here>';
|
|||||||
/**
|
/**
|
||||||
* initialize the UniFi API connection class and log in to the controller and pull the requested data
|
* initialize the UniFi API connection class and log in to the controller and pull the requested data
|
||||||
*/
|
*/
|
||||||
|
$unifi_connection = new UniFi_API\Client(
|
||||||
|
$controlleruser,
|
||||||
|
$controllerpassword,
|
||||||
|
$controllerurl,
|
||||||
|
$site_id,
|
||||||
|
$controllerversion
|
||||||
|
);
|
||||||
|
|
||||||
$unifi_connection = new UniFi_API\Client($controlleruser, $controllerpassword, $controllerurl, $site_id, $controllerversion);
|
|
||||||
$set_debug_mode = $unifi_connection->set_debug($debug);
|
$set_debug_mode = $unifi_connection->set_debug($debug);
|
||||||
$loginresults = $unifi_connection->login();
|
$loginresults = $unifi_connection->login();
|
||||||
$result = $unifi_connection->list_health();
|
$result = $unifi_connection->list_health();
|
||||||
@@ -36,4 +42,4 @@ $result = $unifi_connection->list_health();
|
|||||||
* output the results in correct json formatting
|
* output the results in correct json formatting
|
||||||
*/
|
*/
|
||||||
header('Content-Type: application/json');
|
header('Content-Type: application/json');
|
||||||
echo (json_encode($result, JSON_PRETTY_PRINT));
|
echo(json_encode($result, JSON_PRETTY_PRINT));
|
||||||
@@ -26,7 +26,14 @@ $site_id = 'default';
|
|||||||
/**
|
/**
|
||||||
* initialize the UniFi API connection class and log in to the controller and do our thing
|
* initialize the UniFi API connection class and log in to the controller and do our thing
|
||||||
*/
|
*/
|
||||||
$unifi_connection = new UniFi_API\Client($controlleruser, $controllerpassword, $controllerurl, $site_id, $controllerversion);
|
$unifi_connection = new UniFi_API\Client(
|
||||||
|
$controlleruser,
|
||||||
|
$controllerpassword,
|
||||||
|
$controllerurl,
|
||||||
|
$site_id,
|
||||||
|
$controllerversion
|
||||||
|
);
|
||||||
|
|
||||||
$set_debug_mode = $unifi_connection->set_debug($debug);
|
$set_debug_mode = $unifi_connection->set_debug($debug);
|
||||||
$loginresults = $unifi_connection->login();
|
$loginresults = $unifi_connection->login();
|
||||||
$data = $unifi_connection->list_sites();
|
$data = $unifi_connection->list_sites();
|
||||||
|
|||||||
@@ -26,7 +26,14 @@ $site_id = '<enter your site id here>';
|
|||||||
/**
|
/**
|
||||||
* initialize the UniFi API connection class and log in to the controller and do our thing
|
* initialize the UniFi API connection class and log in to the controller and do our thing
|
||||||
*/
|
*/
|
||||||
$unifi_connection = new UniFi_API\Client($controlleruser, $controllerpassword, $controllerurl, $site_id, $controllerversion);
|
$unifi_connection = new UniFi_API\Client(
|
||||||
|
$controlleruser,
|
||||||
|
$controllerpassword,
|
||||||
|
$controllerurl,
|
||||||
|
$site_id,
|
||||||
|
$controllerversion
|
||||||
|
);
|
||||||
|
|
||||||
$set_debug_mode = $unifi_connection->set_debug($debug);
|
$set_debug_mode = $unifi_connection->set_debug($debug);
|
||||||
$loginresults = $unifi_connection->login();
|
$loginresults = $unifi_connection->login();
|
||||||
$data = $unifi_connection->stat_payment();
|
$data = $unifi_connection->stat_payment();
|
||||||
|
|||||||
@@ -38,7 +38,14 @@ $attribs = ['rx_bytes', 'tx_bytes'];
|
|||||||
/**
|
/**
|
||||||
* initialize the UniFi API connection class and log in to the controller and do our thing
|
* initialize the UniFi API connection class and log in to the controller and do our thing
|
||||||
*/
|
*/
|
||||||
$unifi_connection = new UniFi_API\Client($controlleruser, $controllerpassword, $controllerurl, $site_id, $controllerversion, true);
|
$unifi_connection = new UniFi_API\Client(
|
||||||
|
$controlleruser,
|
||||||
|
$controllerpassword,
|
||||||
|
$controllerurl,
|
||||||
|
$site_id,
|
||||||
|
$controllerversion
|
||||||
|
);
|
||||||
|
|
||||||
$set_debug_mode = $unifi_connection->set_debug(false);
|
$set_debug_mode = $unifi_connection->set_debug(false);
|
||||||
$loginresults = $unifi_connection->login();
|
$loginresults = $unifi_connection->login();
|
||||||
//$data = $unifi_connection->stat_5minutes_user($mac, null, null, $attribs);
|
//$data = $unifi_connection->stat_5minutes_user($mac, null, null, $attribs);
|
||||||
|
|||||||
@@ -49,16 +49,33 @@ $new_cycle_enabled = false;
|
|||||||
/**
|
/**
|
||||||
* initialize the UniFi API connection class and log in to the controller and do our thing
|
* initialize the UniFi API connection class and log in to the controller and do our thing
|
||||||
*/
|
*/
|
||||||
$unifi_connection = new UniFi_API\Client($controlleruser, $controllerpassword, $controllerurl, $site_id, $controllerversion);
|
$unifi_connection = new UniFi_API\Client(
|
||||||
|
$controlleruser,
|
||||||
|
$controllerpassword,
|
||||||
|
$controllerurl,
|
||||||
|
$site_id,
|
||||||
|
$controllerversion
|
||||||
|
);
|
||||||
|
|
||||||
$set_debug_mode = $unifi_connection->set_debug($debug);
|
$set_debug_mode = $unifi_connection->set_debug($debug);
|
||||||
$loginresults = $unifi_connection->login();
|
$loginresults = $unifi_connection->login();
|
||||||
if ($loginresults) {
|
if (!$loginresults) {
|
||||||
$pdu_details = $unifi_connection->list_devices($pdu_mac);
|
echo 'we encountered a login error!';
|
||||||
|
echo PHP_EOL;
|
||||||
|
exit();
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
$pdu_details = $unifi_connection->list_devices($pdu_mac);
|
||||||
|
|
||||||
|
/**
|
||||||
* change the model below from USPPDUP to UP1 when using a USP-Plug (thanks to @thesohoguy for contributing this)
|
* change the model below from USPPDUP to UP1 when using a USP-Plug (thanks to @thesohoguy for contributing this)
|
||||||
*/
|
*/
|
||||||
if (!empty($pdu_details) && property_exists($pdu_details[0], 'model') && $pdu_details[0]->model === 'USPPDUP' && property_exists($pdu_details[0], 'outlet_overrides')) {
|
if (
|
||||||
|
!empty($pdu_details) &&
|
||||||
|
property_exists($pdu_details[0], 'model') &&
|
||||||
|
$pdu_details[0]->model === 'USPPDUP' &&
|
||||||
|
property_exists($pdu_details[0], 'outlet_overrides')
|
||||||
|
) {
|
||||||
$device_id = $pdu_details[0]->_id;
|
$device_id = $pdu_details[0]->_id;
|
||||||
$outlet_overrides = $pdu_details[0]->outlet_overrides;
|
$outlet_overrides = $pdu_details[0]->outlet_overrides;
|
||||||
|
|
||||||
@@ -69,19 +86,15 @@ if ($loginresults) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$pdu_update = $unifi_connection->set_device_settings_base($device_id, ['outlet_overrides' => $outlet_overrides]);
|
$pdu_update = $unifi_connection->set_device_settings_base($device_id,
|
||||||
|
['outlet_overrides' => $outlet_overrides]);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* provide feedback in json format
|
* provide feedback in json format
|
||||||
*/
|
*/
|
||||||
echo 'results:' . PHP_EOL . PHP_EOL;
|
echo 'results:' . PHP_EOL . PHP_EOL;
|
||||||
echo json_encode($pdu_update, JSON_PRETTY_PRINT);
|
echo json_encode($pdu_update, JSON_PRETTY_PRINT);
|
||||||
echo PHP_EOL;
|
|
||||||
} else {
|
|
||||||
echo 'not a PDU device?';
|
|
||||||
echo PHP_EOL;
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
echo 'we encountered a login error!';
|
echo 'not a PDU device?';
|
||||||
echo PHP_EOL;
|
|
||||||
}
|
}
|
||||||
|
echo PHP_EOL;
|
||||||
131
examples/ppsks_examples/create_ppsk.php
Executable file
131
examples/ppsks_examples/create_ppsk.php
Executable file
@@ -0,0 +1,131 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* PHP API usage example
|
||||||
|
*
|
||||||
|
* contributed by: Art of WiFi
|
||||||
|
* description: example basic PHP script to create a new PPSK for a WLAN on the UniFi controller
|
||||||
|
*/
|
||||||
|
use UniFi_API\Exceptions\CurlExtensionNotLoadedException;
|
||||||
|
use UniFi_API\Exceptions\CurlGeneralErrorException;
|
||||||
|
use UniFi_API\Exceptions\CurlTimeoutException;
|
||||||
|
use UniFi_API\Exceptions\InvalidBaseUrlException;
|
||||||
|
use UniFi_API\Exceptions\InvalidSiteNameException;
|
||||||
|
use UniFi_API\Exceptions\JsonDecodeException;
|
||||||
|
use UniFi_API\Exceptions\LoginFailedException;
|
||||||
|
use UniFi_API\Exceptions\LoginRequiredException;
|
||||||
|
|
||||||
|
require 'vendor/autoload.php';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Record start time.
|
||||||
|
*/
|
||||||
|
$start_time = microtime(true);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Include the config file (place your credentials etc. there if not already present),
|
||||||
|
* see the config.template.php file for an example.
|
||||||
|
*
|
||||||
|
* @var array $controller_user
|
||||||
|
* @var array $controller_password
|
||||||
|
* @var array $controller_url
|
||||||
|
* @var array $controller_version
|
||||||
|
* @var array $debug
|
||||||
|
*/
|
||||||
|
require_once 'config.php';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The id of the site to use.
|
||||||
|
*/
|
||||||
|
$site_id = 'default';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The new PPSK details.
|
||||||
|
*/
|
||||||
|
$new_ppsk_password = 'mysecretppsk'; // the password for the new PPSK, this password must be unique for the SSID, between 8-63 characters
|
||||||
|
$new_ppsk_network_id = 'zzzzzzzzzzzzzzzzzzzzz'; // id for the required VLAN, taken from the output of list_networkconf()
|
||||||
|
$new_ppsk_wlan_id = 'xxxxxxxxxxxxxxxxxxxxx'; // id for the required WLAN, taken from the output of list_wlanconf()
|
||||||
|
|
||||||
|
try {
|
||||||
|
/**
|
||||||
|
* initialize the UniFi API connection class and log in to the controller and do our thing
|
||||||
|
*/
|
||||||
|
$unifi_connection = new UniFi_API\Client(
|
||||||
|
$controller_user,
|
||||||
|
$controller_password,
|
||||||
|
$controller_url,
|
||||||
|
$site_id,
|
||||||
|
$controller_version
|
||||||
|
);
|
||||||
|
|
||||||
|
$request_start_time = microtime(true);
|
||||||
|
|
||||||
|
$set_debug_mode = $unifi_connection->set_debug($debug);
|
||||||
|
$login_results = $unifi_connection->login();
|
||||||
|
$wlan_conf = $unifi_connection->list_wlanconf();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the details for the WLAN the PPSK will be created for.
|
||||||
|
*/
|
||||||
|
$wlan_details = [];
|
||||||
|
|
||||||
|
foreach ($wlan_conf as $wlan) {
|
||||||
|
if ($wlan->_id === $new_ppsk_wlan_id) {
|
||||||
|
$wlan_details = $wlan;
|
||||||
|
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (empty($wlan_details)) {
|
||||||
|
echo 'WLAN not found, exiting... Please check the $new_ppsk_wlan_id value 🤨' . PHP_EOL;
|
||||||
|
|
||||||
|
exit;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create the new PPSK, then append it to the existing PPSKs array.
|
||||||
|
*/
|
||||||
|
$new_ppsk = [
|
||||||
|
'password' => $new_ppsk_password,
|
||||||
|
'networkconf_id' => $new_ppsk_network_id,
|
||||||
|
];
|
||||||
|
|
||||||
|
$wlan_details->private_preshared_keys[] = $new_ppsk;
|
||||||
|
|
||||||
|
$unifi_connection->set_wlansettings_base($new_ppsk_wlan_id, $wlan_details);
|
||||||
|
|
||||||
|
$request_end_time = microtime(true);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Record end time.
|
||||||
|
*/
|
||||||
|
$end_time = microtime(true);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Calculate and display the execution time.
|
||||||
|
*/
|
||||||
|
$execution_time = $end_time - $start_time;
|
||||||
|
|
||||||
|
echo 'The PPSK has been created successfully!👍' . PHP_EOL;
|
||||||
|
|
||||||
|
echo 'Full execution time: ' . $execution_time . ' seconds' . PHP_EOL;
|
||||||
|
echo 'Time to fetch, process and push data back: ' . ($request_end_time - $request_start_time) . ' seconds' . PHP_EOL;
|
||||||
|
} catch (CurlExtensionNotLoadedException $e) {
|
||||||
|
echo 'CurlExtensionNotLoadedException: ' . $e->getMessage(). PHP_EOL;
|
||||||
|
} catch (InvalidBaseUrlException $e) {
|
||||||
|
echo 'InvalidBaseUrlException: ' . $e->getMessage(). PHP_EOL;
|
||||||
|
} catch (InvalidSiteNameException $e) {
|
||||||
|
echo 'InvalidSiteNameException: ' . $e->getMessage(). PHP_EOL;
|
||||||
|
} catch (JsonDecodeException $e) {
|
||||||
|
echo 'JsonDecodeException: ' . $e->getMessage(). PHP_EOL;
|
||||||
|
} catch (LoginRequiredException $e) {
|
||||||
|
echo 'LoginRequiredException: ' . $e->getMessage(). PHP_EOL;
|
||||||
|
} catch (CurlGeneralErrorException $e) {
|
||||||
|
echo 'CurlGeneralErrorException: ' . $e->getMessage(). PHP_EOL;
|
||||||
|
} catch (CurlTimeoutException $e) {
|
||||||
|
echo 'CurlTimeoutException: ' . $e->getMessage(). PHP_EOL;
|
||||||
|
} catch (LoginFailedException $e) {
|
||||||
|
echo 'LoginFailedException: ' . $e->getMessage(). PHP_EOL;
|
||||||
|
} catch (Exception $e) {
|
||||||
|
echo 'General Exception: ' . $e->getMessage(). PHP_EOL;
|
||||||
|
}
|
||||||
108
examples/ppsks_examples/list_ppsks.php
Executable file
108
examples/ppsks_examples/list_ppsks.php
Executable file
@@ -0,0 +1,108 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* PHP API usage example
|
||||||
|
*
|
||||||
|
* contributed by: Art of WiFi
|
||||||
|
* description: example basic PHP script to list all PPSKs for all WLANs in a specific UniFi site
|
||||||
|
*/
|
||||||
|
|
||||||
|
use UniFi_API\Exceptions\CurlExtensionNotLoadedException;
|
||||||
|
use UniFi_API\Exceptions\CurlGeneralErrorException;
|
||||||
|
use UniFi_API\Exceptions\CurlTimeoutException;
|
||||||
|
use UniFi_API\Exceptions\InvalidBaseUrlException;
|
||||||
|
use UniFi_API\Exceptions\InvalidSiteNameException;
|
||||||
|
use UniFi_API\Exceptions\JsonDecodeException;
|
||||||
|
use UniFi_API\Exceptions\LoginFailedException;
|
||||||
|
use UniFi_API\Exceptions\LoginRequiredException;
|
||||||
|
|
||||||
|
require 'vendor/autoload.php';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Record start time.
|
||||||
|
*/
|
||||||
|
$start_time = microtime(true);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Include the config file (place your credentials etc. there if not already present),
|
||||||
|
* see the config.template.php file for an example.
|
||||||
|
*
|
||||||
|
* @var array $controller_user
|
||||||
|
* @var array $controller_password
|
||||||
|
* @var array $controller_url
|
||||||
|
* @var array $controller_version
|
||||||
|
* @var array $debug
|
||||||
|
*/
|
||||||
|
require_once 'config.php';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The id of the site to use.
|
||||||
|
*/
|
||||||
|
$site_id = 'default';
|
||||||
|
|
||||||
|
try {
|
||||||
|
/**
|
||||||
|
* initialize the UniFi API connection class and log in to the controller and do our thing
|
||||||
|
*/
|
||||||
|
$unifi_connection = new UniFi_API\Client(
|
||||||
|
$controller_user,
|
||||||
|
$controller_password,
|
||||||
|
$controller_url,
|
||||||
|
$site_id,
|
||||||
|
$controller_version
|
||||||
|
);
|
||||||
|
|
||||||
|
$request_start_time = microtime(true);
|
||||||
|
|
||||||
|
$set_debug_mode = $unifi_connection->set_debug($debug);
|
||||||
|
$login_results = $unifi_connection->login();
|
||||||
|
$wlan_conf = $unifi_connection->list_wlanconf();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the details for the WLAN the PPSK will be created for.
|
||||||
|
*/
|
||||||
|
$wlan_details = [];
|
||||||
|
|
||||||
|
foreach ($wlan_conf as $wlan) {
|
||||||
|
/**
|
||||||
|
* Skip this SSID if private_pre_shared_keys is not set or empty.
|
||||||
|
*/
|
||||||
|
if (empty($wlan->private_preshared_keys)) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
echo json_encode($wlan->private_preshared_keys, JSON_PRETTY_PRINT) . PHP_EOL;
|
||||||
|
}
|
||||||
|
|
||||||
|
$request_end_time = microtime(true);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Record end time.
|
||||||
|
*/
|
||||||
|
$end_time = microtime(true);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Calculate and display the execution time.
|
||||||
|
*/
|
||||||
|
$execution_time = $end_time - $start_time;
|
||||||
|
|
||||||
|
echo 'Full execution time: ' . $execution_time . ' seconds' . PHP_EOL;
|
||||||
|
echo 'Time to fetch, process and push data back: ' . ($request_end_time - $request_start_time) . ' seconds' . PHP_EOL;
|
||||||
|
} catch (CurlExtensionNotLoadedException $e) {
|
||||||
|
echo 'CurlExtensionNotLoadedException: ' . $e->getMessage(). PHP_EOL;
|
||||||
|
} catch (InvalidBaseUrlException $e) {
|
||||||
|
echo 'InvalidBaseUrlException: ' . $e->getMessage(). PHP_EOL;
|
||||||
|
} catch (InvalidSiteNameException $e) {
|
||||||
|
echo 'InvalidSiteNameException: ' . $e->getMessage(). PHP_EOL;
|
||||||
|
} catch (JsonDecodeException $e) {
|
||||||
|
echo 'JsonDecodeException: ' . $e->getMessage(). PHP_EOL;
|
||||||
|
} catch (LoginRequiredException $e) {
|
||||||
|
echo 'LoginRequiredException: ' . $e->getMessage(). PHP_EOL;
|
||||||
|
} catch (CurlGeneralErrorException $e) {
|
||||||
|
echo 'CurlGeneralErrorException: ' . $e->getMessage(). PHP_EOL;
|
||||||
|
} catch (CurlTimeoutException $e) {
|
||||||
|
echo 'CurlTimeoutException: ' . $e->getMessage(). PHP_EOL;
|
||||||
|
} catch (LoginFailedException $e) {
|
||||||
|
echo 'LoginFailedException: ' . $e->getMessage(). PHP_EOL;
|
||||||
|
} catch (Exception $e) {
|
||||||
|
echo 'General Exception: ' . $e->getMessage(). PHP_EOL;
|
||||||
|
}
|
||||||
141
examples/ppsks_examples/remove_ppsk.php
Executable file
141
examples/ppsks_examples/remove_ppsk.php
Executable file
@@ -0,0 +1,141 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* PHP API usage example
|
||||||
|
*
|
||||||
|
* contributed by: Art of WiFi
|
||||||
|
* description: example basic PHP script to remove a PPSK from a specific UniFi site
|
||||||
|
*/
|
||||||
|
use UniFi_API\Exceptions\CurlExtensionNotLoadedException;
|
||||||
|
use UniFi_API\Exceptions\CurlGeneralErrorException;
|
||||||
|
use UniFi_API\Exceptions\CurlTimeoutException;
|
||||||
|
use UniFi_API\Exceptions\InvalidBaseUrlException;
|
||||||
|
use UniFi_API\Exceptions\InvalidSiteNameException;
|
||||||
|
use UniFi_API\Exceptions\JsonDecodeException;
|
||||||
|
use UniFi_API\Exceptions\LoginFailedException;
|
||||||
|
use UniFi_API\Exceptions\LoginRequiredException;
|
||||||
|
|
||||||
|
require 'vendor/autoload.php';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Record start time.
|
||||||
|
*/
|
||||||
|
$start_time = microtime(true);
|
||||||
|
|
||||||
|
$total_removals = 0;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Include the config file (place your credentials etc. there if not already present),
|
||||||
|
* see the config.template.php file for an example.
|
||||||
|
*
|
||||||
|
* @var array $controller_user
|
||||||
|
* @var array $controller_password
|
||||||
|
* @var array $controller_url
|
||||||
|
* @var array $controller_version
|
||||||
|
* @var array $debug
|
||||||
|
*/
|
||||||
|
require_once 'config.php';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The id of the site to use.
|
||||||
|
*/
|
||||||
|
$site_id = 'default';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The password value of the PPSK to remove.
|
||||||
|
*/
|
||||||
|
$ppsk_to_remove = 'mysecretppsk';
|
||||||
|
|
||||||
|
try {
|
||||||
|
/**
|
||||||
|
* Initialize the UniFi API connection class and log in to the controller and do our thing.
|
||||||
|
*/
|
||||||
|
$unifi_connection = new UniFi_API\Client(
|
||||||
|
$controller_user,
|
||||||
|
$controller_password,
|
||||||
|
$controller_url,
|
||||||
|
$site_id,
|
||||||
|
$controller_version
|
||||||
|
);
|
||||||
|
|
||||||
|
$request_start_time = microtime(true);
|
||||||
|
|
||||||
|
$set_debug_mode = $unifi_connection->set_debug($debug);
|
||||||
|
$login_results = $unifi_connection->login();
|
||||||
|
$wlan_conf = $unifi_connection->list_wlanconf();
|
||||||
|
|
||||||
|
foreach ($wlan_conf as $wlan) {
|
||||||
|
/**
|
||||||
|
* Skip this SSID if the private_pre_shared_keys array is not set or empty.
|
||||||
|
*/
|
||||||
|
if (empty($wlan->private_preshared_keys)) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
$removals = 0;
|
||||||
|
|
||||||
|
foreach ($wlan->private_preshared_keys as $ppsk) {
|
||||||
|
if ($ppsk->password === $ppsk_to_remove) {
|
||||||
|
echo 'Removing PPSK with password: "' . $ppsk_to_remove . '"' . PHP_EOL;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Remove the PPSK from the private_preshared_keys array.
|
||||||
|
*/
|
||||||
|
$wlan->private_preshared_keys = array_values(array_filter($wlan->private_preshared_keys, function ($value) use ($ppsk_to_remove) {
|
||||||
|
return $value->password !== $ppsk_to_remove;
|
||||||
|
}));
|
||||||
|
|
||||||
|
$removals++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Push the updated WLAN configuration back to the controller if we removed one or more PPSKs.
|
||||||
|
*/
|
||||||
|
if ($removals > 0) {
|
||||||
|
echo 'Pushing updated WLAN configuration back to the controller...' . PHP_EOL;
|
||||||
|
$unifi_connection->set_wlansettings_base($wlan->_id, $wlan);
|
||||||
|
$total_removals += $removals;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$request_end_time = microtime(true);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Record end time.
|
||||||
|
*/
|
||||||
|
$end_time = microtime(true);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Calculate the execution time.
|
||||||
|
*/
|
||||||
|
$execution_time = $end_time - $start_time;
|
||||||
|
|
||||||
|
if ($total_removals === 0) {
|
||||||
|
echo 'No PPSKs were removed, exiting...' . PHP_EOL;
|
||||||
|
|
||||||
|
exit;
|
||||||
|
}
|
||||||
|
|
||||||
|
echo 'Total PPSKs removed: ' . $total_removals . PHP_EOL;
|
||||||
|
|
||||||
|
echo 'Full execution time: ' . $execution_time . ' seconds' . PHP_EOL;
|
||||||
|
echo 'Time to fetch, process and push data back: ' . ($request_end_time - $request_start_time) . ' seconds' . PHP_EOL;
|
||||||
|
} catch (CurlExtensionNotLoadedException $e) {
|
||||||
|
echo 'CurlExtensionNotLoadedException: ' . $e->getMessage(). PHP_EOL;
|
||||||
|
} catch (InvalidBaseUrlException $e) {
|
||||||
|
echo 'InvalidBaseUrlException: ' . $e->getMessage(). PHP_EOL;
|
||||||
|
} catch (InvalidSiteNameException $e) {
|
||||||
|
echo 'InvalidSiteNameException: ' . $e->getMessage(). PHP_EOL;
|
||||||
|
} catch (JsonDecodeException $e) {
|
||||||
|
echo 'JsonDecodeException: ' . $e->getMessage(). PHP_EOL;
|
||||||
|
} catch (LoginRequiredException $e) {
|
||||||
|
echo 'LoginRequiredException: ' . $e->getMessage(). PHP_EOL;
|
||||||
|
} catch (CurlGeneralErrorException $e) {
|
||||||
|
echo 'CurlGeneralErrorException: ' . $e->getMessage(). PHP_EOL;
|
||||||
|
} catch (CurlTimeoutException $e) {
|
||||||
|
echo 'CurlTimeoutException: ' . $e->getMessage(). PHP_EOL;
|
||||||
|
} catch (LoginFailedException $e) {
|
||||||
|
echo 'LoginFailedException: ' . $e->getMessage(). PHP_EOL;
|
||||||
|
} catch (Exception $e) {
|
||||||
|
echo 'General Exception: ' . $e->getMessage(). PHP_EOL;
|
||||||
|
}
|
||||||
@@ -30,7 +30,14 @@ $site_id = '<enter your site id here>';
|
|||||||
/**
|
/**
|
||||||
* initialize the UniFi API connection class and log in to the controller
|
* initialize the UniFi API connection class and log in to the controller
|
||||||
*/
|
*/
|
||||||
$unifi_connection = new UniFi_API\Client($controlleruser, $controllerpassword, $controllerurl, $site_id, $controllerversion);
|
$unifi_connection = new UniFi_API\Client(
|
||||||
|
$controlleruser,
|
||||||
|
$controllerpassword,
|
||||||
|
$controllerurl,
|
||||||
|
$site_id,
|
||||||
|
$controllerversion
|
||||||
|
);
|
||||||
|
|
||||||
$set_debug_mode = $unifi_connection->set_debug($debug);
|
$set_debug_mode = $unifi_connection->set_debug($debug);
|
||||||
$loginresults = $unifi_connection->login();
|
$loginresults = $unifi_connection->login();
|
||||||
|
|
||||||
|
|||||||
153
examples/set_vlan_to_port.php
Executable file
153
examples/set_vlan_to_port.php
Executable file
@@ -0,0 +1,153 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* PHP API usage example
|
||||||
|
*
|
||||||
|
* contributed by: Samuel Schnelly
|
||||||
|
* description: example basic PHP script to change VLAN on port
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* using the composer autoloader
|
||||||
|
*/
|
||||||
|
require_once 'vendor/autoload.php';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* include the config file (place your credentials etc. there if not already present)
|
||||||
|
* see the config.template.php file for an example
|
||||||
|
*/
|
||||||
|
require_once 'config.php';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* the site to use
|
||||||
|
*/
|
||||||
|
$site_id = '<enter your site id here>';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* initialize the UniFi API connection class and log in to the controller and do our thing
|
||||||
|
*/
|
||||||
|
$unifi_connection = new UniFi_API\Client(
|
||||||
|
$controlleruser,
|
||||||
|
$controllerpassword,
|
||||||
|
$controllerurl,
|
||||||
|
$site_id,
|
||||||
|
$controllerversion
|
||||||
|
);
|
||||||
|
|
||||||
|
$set_debug_mode = $unifi_connection->set_debug($debug);
|
||||||
|
$loginresults = $unifi_connection->login();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* change VLAN on port
|
||||||
|
*/
|
||||||
|
$port = 1;
|
||||||
|
$vlan = 200;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* MAC Address of the UniFi device
|
||||||
|
*/
|
||||||
|
$mac = '<enter your device mac address here>';
|
||||||
|
|
||||||
|
set_port_vlan($mac, $port, $vlan, $unifi_connection);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set specific VLAN on device port
|
||||||
|
*
|
||||||
|
* @param string $device_mac MAC Address of UNIFI device
|
||||||
|
* @param int $port_idx Port number of UNIFI device, note: started by 1
|
||||||
|
* @param int $vlan_id VLAN ID to set
|
||||||
|
* @param UniFi_API\Client $unifi_connection
|
||||||
|
*
|
||||||
|
* @return bool true if result is success, false upon failure
|
||||||
|
*/
|
||||||
|
function set_port_vlan($device_mac, $port_idx, $vlan_id, $unifi_connection)
|
||||||
|
{
|
||||||
|
$device = $unifi_connection->list_devices($device_mac);
|
||||||
|
|
||||||
|
// if no device found
|
||||||
|
if (count($device) == 0) {
|
||||||
|
trigger_error('set_port_vlan() device not found');
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
$port_table = $device[0]->port_table;
|
||||||
|
$def_port = null;
|
||||||
|
|
||||||
|
// check if port exists
|
||||||
|
$exist = false;
|
||||||
|
foreach ($port_table as $key => $port) {
|
||||||
|
if ($port->port_idx == $port_idx) {
|
||||||
|
$exist = true;
|
||||||
|
$def_port = $port;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!$exist) {
|
||||||
|
trigger_error('set_port_vlan() port_idx not found on device');
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
// check if vlan exists
|
||||||
|
$native_networkconf_id = null;
|
||||||
|
|
||||||
|
foreach ($unifi_connection->list_networkconf() as $key => $network) {
|
||||||
|
if ($network->purpose == 'vlan-only' && $network->vlan == $vlan_id) {
|
||||||
|
$native_networkconf_id = $network->_id;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($native_networkconf_id === null) {
|
||||||
|
trigger_error('set_port_vlan() vlan not exist');
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
$exist = false;
|
||||||
|
foreach ($device[0]->port_overrides as $key => $port) {
|
||||||
|
if ($port->port_idx == $port_idx) {
|
||||||
|
$exist = true;
|
||||||
|
$device[0]->port_overrides[$key]->native_networkconf_id = $native_networkconf_id;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!$exist) {
|
||||||
|
$device[0]->port_overrides[] = [
|
||||||
|
'port_idx' => isset($port_idx) ? $port_idx : 1,
|
||||||
|
'setting_preference' => isset($setting_preference) ? $setting_preference : 'auto',
|
||||||
|
'name' => isset($def_port->name) ? $def_port->name : 'Port 1',
|
||||||
|
'op_mode' => isset($def_port->op_mode) ? $def_port->op_mode : 'switch',
|
||||||
|
'port_security_enabled' => isset($def_port->port_security_enabled) ? $def_port->port_security_enabled : false,
|
||||||
|
'port_security_mac_address' => isset($def_port->port_security_mac_address) ? $def_port->port_security_mac_address : [],
|
||||||
|
'native_networkconf_id' => isset($native_networkconf_id) ? $native_networkconf_id : '',
|
||||||
|
'excluded_networkconf_ids' => isset($def_port->excluded_networkconf_ids) ? $def_port->excluded_networkconf_ids : [],
|
||||||
|
'show_traffic_restriction_as_allowlist' => isset($def_port->show_traffic_restriction_as_allowlist) ? $def_port->show_traffic_restriction_as_allowlist : false,
|
||||||
|
'forward' => isset($def_port->forward) ? $def_port->forward : 'customize',
|
||||||
|
'lldpmed_enabled' => isset($def_port->lldpmed_enabled) ? $def_port->lldpmed_enabled : true,
|
||||||
|
'voice_networkconf_id' => isset($def_port->voice_networkconf_id) ? $def_port->voice_networkconf_id : '',
|
||||||
|
'stormctrl_bcast_enabled' => isset($def_port->stormctrl_bcast_enabled) ? $def_port->stormctrl_bcast_enabled : false,
|
||||||
|
'stormctrl_bcast_rate' => isset($def_port->stormctrl_bcast_rate) ? $def_port->stormctrl_bcast_rate : 100,
|
||||||
|
'stormctrl_mcast_enabled' => isset($def_port->stormctrl_mcast_enabled) ? $def_port->stormctrl_mcast_enabled : false,
|
||||||
|
'stormctrl_mcast_rate' => isset($def_port->stormctrl_mcast_rate) ? $def_port->stormctrl_mcast_rate : 100,
|
||||||
|
'stormctrl_ucast_enabled' => isset($def_port->stormctrl_ucast_enabled) ? $def_port->stormctrl_ucast_enabled : false,
|
||||||
|
'stormctrl_ucast_rate' => isset($def_port->stormctrl_ucast_rate) ? $def_port->stormctrl_ucast_rate : 100,
|
||||||
|
'egress_rate_limit_kbps_enabled' => isset($def_port->egress_rate_limit_kbps_enabled) ? $def_port->egress_rate_limit_kbps_enabled : false,
|
||||||
|
'autoneg' => isset($def_port->autoneg) ? $def_port->autoneg : true,
|
||||||
|
'isolation' => isset($def_port->isolation) ? $def_port->isolation : false,
|
||||||
|
'stp_port_mode' => isset($def_port->stp_port_mode) ? $def_port->stp_port_mode : true,
|
||||||
|
'port_keepalive_enabled' => isset($def_port->port_keepalive_enabled) ? $def_port->port_keepalive_enabled : false
|
||||||
|
];
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
$payload = [
|
||||||
|
'port_overrides' => $device[0]->port_overrides
|
||||||
|
];
|
||||||
|
|
||||||
|
$result = $unifi_connection->set_device_settings_base($device[0]->device_id, $payload);
|
||||||
|
|
||||||
|
if ($result) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
69
examples/toggle_auto_update_settings.php
Executable file
69
examples/toggle_auto_update_settings.php
Executable file
@@ -0,0 +1,69 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* PHP API usage example
|
||||||
|
*
|
||||||
|
* contributed by: Art of WiFi
|
||||||
|
* description: example to toggle the site-wide auto upgrade setting on a UniFi controller
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* using the composer autoloader
|
||||||
|
*/
|
||||||
|
require_once('vendor/autoload.php');
|
||||||
|
|
||||||
|
/**
|
||||||
|
* include the config file (place your credentials etc. there if not already present)
|
||||||
|
* see the config.template.php file for an example
|
||||||
|
*
|
||||||
|
* @var string $controlleruser the user name for access to the UniFi Controller
|
||||||
|
* @var string $controllerpassword the password for access to the UniFi Controller
|
||||||
|
* @var string $controllerurl full url to the UniFi Controller, eg. 'https://
|
||||||
|
* @var string $controllerversion the version of the Controller software, eg. '4.6.6' (must be at least 4.0.0)
|
||||||
|
* @var bool $debug set to true (without quotes) to enable debug output to the browser and the PHP error log
|
||||||
|
*/
|
||||||
|
require_once('config.php');
|
||||||
|
|
||||||
|
/**
|
||||||
|
* site id for the site where settings are to be updated
|
||||||
|
*/
|
||||||
|
$site_id = 'zzzzz';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* initialize the UniFi API connection class and log in to the controller to do our thing
|
||||||
|
*/
|
||||||
|
$unifi_connection = new UniFi_API\Client(
|
||||||
|
$controlleruser,
|
||||||
|
$controllerpassword,
|
||||||
|
$controllerurl,
|
||||||
|
$site_id,
|
||||||
|
$controllerversion
|
||||||
|
);
|
||||||
|
|
||||||
|
$login_results = $unifi_connection->login();
|
||||||
|
|
||||||
|
if ($login_results) {
|
||||||
|
/**
|
||||||
|
* we get the current site mgmt settings
|
||||||
|
*/
|
||||||
|
$current_site_settings = $unifi_connection->list_settings();
|
||||||
|
|
||||||
|
$mgmt_settings = [];
|
||||||
|
foreach ($current_site_settings as $section) {
|
||||||
|
if ($section->key == 'mgmt') {
|
||||||
|
$mgmt_settings = $section;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* toggle the auto upgrade setting and set the auto upgrade hour to 3
|
||||||
|
*/
|
||||||
|
$mgmt_settings->auto_upgrade = !$mgmt_settings->auto_upgrade;
|
||||||
|
$mgmt_settings->auto_upgrade_hour = 3;
|
||||||
|
$mgmt_id = $mgmt_settings->_id;
|
||||||
|
$set_result = $unifi_connection->set_site_mgmt($mgmt_id, $mgmt_settings);
|
||||||
|
|
||||||
|
echo 'done' . PHP_EOL;
|
||||||
|
exit();
|
||||||
|
}
|
||||||
|
|
||||||
|
echo 'login failed' . PHP_EOL;
|
||||||
@@ -31,7 +31,14 @@ $mac = '<enter MAC address of your AP here>';
|
|||||||
/**
|
/**
|
||||||
* initialize the UniFi API connection class and log in to the controller to do our thing
|
* initialize the UniFi API connection class and log in to the controller to do our thing
|
||||||
*/
|
*/
|
||||||
$unifi_connection = new UniFi_API\Client($controlleruser, $controllerpassword, $controllerurl, $site_id, $controllerversion); // initialize the class instance
|
$unifi_connection = new UniFi_API\Client(
|
||||||
|
$controlleruser,
|
||||||
|
$controllerpassword,
|
||||||
|
$controllerurl,
|
||||||
|
$site_id,
|
||||||
|
$controllerversion
|
||||||
|
);
|
||||||
|
|
||||||
$set_debug_mode = $unifi_connection->set_debug($debug);
|
$set_debug_mode = $unifi_connection->set_debug($debug);
|
||||||
$loginresults = $unifi_connection->login();
|
$loginresults = $unifi_connection->login();
|
||||||
|
|
||||||
|
|||||||
@@ -43,7 +43,14 @@ if ($site_id == "MUST_DEFINE_THIS") {
|
|||||||
/**
|
/**
|
||||||
* initialize the UniFi API connection class and log in to the controller
|
* initialize the UniFi API connection class and log in to the controller
|
||||||
*/
|
*/
|
||||||
$unifi_connection = new UniFi_API\Client($controlleruser, $controllerpassword, $controllerurl, $site_id, $controllerversion);
|
$unifi_connection = new UniFi_API\Client(
|
||||||
|
$controlleruser,
|
||||||
|
$controllerpassword,
|
||||||
|
$controllerurl,
|
||||||
|
$site_id,
|
||||||
|
$controllerversion
|
||||||
|
);
|
||||||
|
|
||||||
$set_debug_mode = $unifi_connection->set_debug($debug);
|
$set_debug_mode = $unifi_connection->set_debug($debug);
|
||||||
$loginresults = $unifi_connection->login(); // always true regardless of site id
|
$loginresults = $unifi_connection->login(); // always true regardless of site id
|
||||||
|
|
||||||
|
|||||||
@@ -60,7 +60,14 @@ $new_ports_config = [
|
|||||||
/**
|
/**
|
||||||
* initialize the UniFi API connection class and log in to the controller and do our thing
|
* initialize the UniFi API connection class and log in to the controller and do our thing
|
||||||
*/
|
*/
|
||||||
$unifi_connection = new UniFi_API\Client($controlleruser, $controllerpassword, $controllerurl, $site_id, $controllerversion, false);
|
$unifi_connection = new UniFi_API\Client(
|
||||||
|
$controlleruser,
|
||||||
|
$controllerpassword,
|
||||||
|
$controllerurl,
|
||||||
|
$site_id,
|
||||||
|
$controllerversion
|
||||||
|
);
|
||||||
|
|
||||||
$set_debug_mode = $unifi_connection->set_debug(false);
|
$set_debug_mode = $unifi_connection->set_debug(false);
|
||||||
$loginresults = $unifi_connection->login();
|
$loginresults = $unifi_connection->login();
|
||||||
$data = $unifi_connection->list_devices($device_mac);
|
$data = $unifi_connection->list_devices($device_mac);
|
||||||
|
|||||||
@@ -51,7 +51,14 @@ $na_channel = 44;
|
|||||||
/**
|
/**
|
||||||
* initialize the UniFi API connection class and log in to the controller and do our thing
|
* initialize the UniFi API connection class and log in to the controller and do our thing
|
||||||
*/
|
*/
|
||||||
$unifi_connection = new UniFi_API\Client($controlleruser, $controllerpassword, $controllerurl, $site_id, $controllerversion, false);
|
$unifi_connection = new UniFi_API\Client(
|
||||||
|
$controlleruser,
|
||||||
|
$controllerpassword,
|
||||||
|
$controllerurl,
|
||||||
|
$site_id,
|
||||||
|
$controllerversion
|
||||||
|
);
|
||||||
|
|
||||||
$set_debug_mode = $unifi_connection->set_debug(false);
|
$set_debug_mode = $unifi_connection->set_debug(false);
|
||||||
$loginresults = $unifi_connection->login();
|
$loginresults = $unifi_connection->login();
|
||||||
$data = $unifi_connection->list_devices($ap_mac);
|
$data = $unifi_connection->list_devices($ap_mac);
|
||||||
|
|||||||
@@ -8,6 +8,9 @@
|
|||||||
* usage: If the file is called via a web URL, it should be called like: update_switch_poe-mode.php?poe_mode=off
|
* usage: If the file is called via a web URL, it should be called like: update_switch_poe-mode.php?poe_mode=off
|
||||||
* If the file is called via the command line, it should be called like: php update_switch_poe-mode.php off
|
* If the file is called via the command line, it should be called like: php update_switch_poe-mode.php off
|
||||||
* The values can be "off" or "auto"
|
* The values can be "off" or "auto"
|
||||||
|
*
|
||||||
|
* IMPORTANT INFORMATION:
|
||||||
|
* This example no longer works with controller versions 7.1.X and higher. You now need to work with port profiles to enable POE on a switch port.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -39,20 +42,21 @@ $lanports = [6];
|
|||||||
/**
|
/**
|
||||||
* This is the function that reads out the current port configuration and changes the value for the poe_mode for the ports defined in $lanports
|
* This is the function that reads out the current port configuration and changes the value for the poe_mode for the ports defined in $lanports
|
||||||
*/
|
*/
|
||||||
function update_ports($running_config, $ports, $poe_mode){
|
function update_ports($running_config, $ports, $poe_mode)
|
||||||
|
{
|
||||||
/**
|
/**
|
||||||
* Update already non-default ports
|
* Update already non-default ports
|
||||||
*/
|
*/
|
||||||
$running_config_count = count($running_config);
|
$running_config_count = count($running_config);
|
||||||
for($i = 0; $i < $running_config_count; $i++){
|
for ($i = 0; $i < $running_config_count; $i++) {
|
||||||
if(in_array($running_config[$i]->port_idx, $ports)){
|
if (in_array($running_config[$i]->port_idx, $ports)) {
|
||||||
$running_config[$i]->poe_mode = $poe_mode;
|
$running_config[$i]->poe_mode = $poe_mode;
|
||||||
unset($ports[array_search($running_config[$i]->port_idx, $ports)]);
|
unset($ports[array_search($running_config[$i]->port_idx, $ports)]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$add_conf = [];
|
$add_conf = [];
|
||||||
foreach($ports as $port){
|
foreach ($ports as $port) {
|
||||||
$add_conf[] = [
|
$add_conf[] = [
|
||||||
'port_idx' => $port,
|
'port_idx' => $port,
|
||||||
'poe_mode' => $poe_mode
|
'poe_mode' => $poe_mode
|
||||||
@@ -62,7 +66,14 @@ function update_ports($running_config, $ports, $poe_mode){
|
|||||||
return array_merge($running_config, $add_conf);
|
return array_merge($running_config, $add_conf);
|
||||||
}
|
}
|
||||||
|
|
||||||
$unifi_connection = new UniFi_API\Client($controlleruser, $controllerpassword, $controllerurl, $site_id, $controllerversion, false);
|
$unifi_connection = new UniFi_API\Client(
|
||||||
|
$controlleruser,
|
||||||
|
$controllerpassword,
|
||||||
|
$controllerurl,
|
||||||
|
$site_id,
|
||||||
|
$controllerversion
|
||||||
|
);
|
||||||
|
|
||||||
$set_debug_mode = $unifi_connection->set_debug(false);
|
$set_debug_mode = $unifi_connection->set_debug(false);
|
||||||
$loginresults = $unifi_connection->login();
|
$loginresults = $unifi_connection->login();
|
||||||
$data = $unifi_connection->list_devices($device_mac);
|
$data = $unifi_connection->list_devices($device_mac);
|
||||||
|
|||||||
3592
src/Client.php
3592
src/Client.php
File diff suppressed because it is too large
Load Diff
19
src/Exceptions/CurlExtensionNotLoadedException.php
Executable file
19
src/Exceptions/CurlExtensionNotLoadedException.php
Executable file
@@ -0,0 +1,19 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace UniFi_API\Exceptions;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Thrown when the required PHP cURL extension is not loaded in the runtime.
|
||||||
|
*
|
||||||
|
* @note Consumers can catch this to provide an installation hint or to disable any
|
||||||
|
* functionality that requires cURL.
|
||||||
|
*
|
||||||
|
* @package UniFi_Controller_API_Client_Class
|
||||||
|
*/
|
||||||
|
class CurlExtensionNotLoadedException extends UnifiApiException
|
||||||
|
{
|
||||||
|
public function __construct()
|
||||||
|
{
|
||||||
|
parent::__construct('The PHP curl extension is not loaded. Please correct this before proceeding!');
|
||||||
|
}
|
||||||
|
}
|
||||||
48
src/Exceptions/CurlGeneralErrorException.php
Executable file
48
src/Exceptions/CurlGeneralErrorException.php
Executable file
@@ -0,0 +1,48 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace UniFi_API\Exceptions;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Thrown when a general cURL error occurs while calling the UniFi API.
|
||||||
|
*
|
||||||
|
* @property-read mixed $httpResponseCode HTTP response code if available
|
||||||
|
* @property-read mixed $curlGetinfoResults Results from curl_getinfo() if available
|
||||||
|
*
|
||||||
|
* @package UniFi_Controller_API_Client_Class
|
||||||
|
*/
|
||||||
|
class CurlGeneralErrorException extends UnifiApiException
|
||||||
|
{
|
||||||
|
/** @var mixed $_http_response_code */
|
||||||
|
private $_http_response_code;
|
||||||
|
|
||||||
|
/** @var mixed $_curl_getinfo_results */
|
||||||
|
private $_curl_getinfo_results;
|
||||||
|
|
||||||
|
public function __construct(string $message, $http_response_code, $_curl_getinfo_results)
|
||||||
|
{
|
||||||
|
$this->_http_response_code = $http_response_code;
|
||||||
|
$this->_curl_getinfo_results = $_curl_getinfo_results;
|
||||||
|
|
||||||
|
parent::__construct($message, $http_response_code);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the HTTP response code.
|
||||||
|
*
|
||||||
|
* @return mixed
|
||||||
|
*/
|
||||||
|
public function getHttpResponseCode()
|
||||||
|
{
|
||||||
|
return $this->_http_response_code;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the cURL curl_getinfo results.
|
||||||
|
*
|
||||||
|
* @return mixed
|
||||||
|
*/
|
||||||
|
public function getCurlGetinfoResults()
|
||||||
|
{
|
||||||
|
return $this->_curl_getinfo_results;
|
||||||
|
}
|
||||||
|
}
|
||||||
48
src/Exceptions/CurlTimeoutException.php
Executable file
48
src/Exceptions/CurlTimeoutException.php
Executable file
@@ -0,0 +1,48 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace UniFi_API\Exceptions;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Thrown when a cURL request times out.
|
||||||
|
*
|
||||||
|
* @property-read mixed $httpResponseCode HTTP response code if available
|
||||||
|
* @property-read mixed $curlGetinfoResults Result of curl_getinfo() when available
|
||||||
|
*
|
||||||
|
* @package UniFi_Controller_API_Client_Class
|
||||||
|
*/
|
||||||
|
class CurlTimeoutException extends UnifiApiException
|
||||||
|
{
|
||||||
|
/** @var mixed $_http_response_code */
|
||||||
|
private $_http_response_code;
|
||||||
|
|
||||||
|
/** @var mixed $_curl_getinfo_results */
|
||||||
|
private $_curl_getinfo_results;
|
||||||
|
|
||||||
|
public function __construct(string $message, $http_response_code, $curl_getinfo_results)
|
||||||
|
{
|
||||||
|
$this->_http_response_code = $http_response_code;
|
||||||
|
$this->_curl_getinfo_results = $curl_getinfo_results;
|
||||||
|
|
||||||
|
parent::__construct($message, $http_response_code);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the HTTP response code.
|
||||||
|
*
|
||||||
|
* @return mixed
|
||||||
|
*/
|
||||||
|
public function getHttpResponseCode()
|
||||||
|
{
|
||||||
|
return $this->_http_response_code;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the cURL curl_getinfo results.
|
||||||
|
*
|
||||||
|
* @return mixed
|
||||||
|
*/
|
||||||
|
public function getCurlGetinfoResults()
|
||||||
|
{
|
||||||
|
return $this->_curl_getinfo_results;
|
||||||
|
}
|
||||||
|
}
|
||||||
18
src/Exceptions/EmailInvalidException.php
Executable file
18
src/Exceptions/EmailInvalidException.php
Executable file
@@ -0,0 +1,18 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace UniFi_API\Exceptions;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Thrown when an invalid email address is provided to the client.
|
||||||
|
*
|
||||||
|
* @note This Exception is used for input validation where a properly formatted email is required.
|
||||||
|
*
|
||||||
|
* @package UniFi_Controller_API_Client_Class
|
||||||
|
*/
|
||||||
|
class EmailInvalidException extends UnifiApiException
|
||||||
|
{
|
||||||
|
public function __construct()
|
||||||
|
{
|
||||||
|
parent::__construct('Invalid email address provided.');
|
||||||
|
}
|
||||||
|
}
|
||||||
16
src/Exceptions/InvalidBaseUrlException.php
Executable file
16
src/Exceptions/InvalidBaseUrlException.php
Executable file
@@ -0,0 +1,16 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace UniFi_API\Exceptions;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Thrown when the provided base URL for the UniFi controller is invalid.
|
||||||
|
*
|
||||||
|
* @package UniFi_Controller_API_Client_Class
|
||||||
|
*/
|
||||||
|
class InvalidBaseUrlException extends UnifiApiException
|
||||||
|
{
|
||||||
|
public function __construct()
|
||||||
|
{
|
||||||
|
parent::__construct('The base URL provided is invalid.');
|
||||||
|
}
|
||||||
|
}
|
||||||
16
src/Exceptions/InvalidCurlMethodException.php
Executable file
16
src/Exceptions/InvalidCurlMethodException.php
Executable file
@@ -0,0 +1,16 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace UniFi_API\Exceptions;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Thrown when an unsupported or invalid cURL method is requested by the client.
|
||||||
|
*
|
||||||
|
* @package UniFi_Controller_API_Client_Class
|
||||||
|
*/
|
||||||
|
class InvalidCurlMethodException extends UnifiApiException
|
||||||
|
{
|
||||||
|
public function __construct()
|
||||||
|
{
|
||||||
|
parent::__construct('Invalid cURL method provided.');
|
||||||
|
}
|
||||||
|
}
|
||||||
19
src/Exceptions/InvalidSiteNameException.php
Executable file
19
src/Exceptions/InvalidSiteNameException.php
Executable file
@@ -0,0 +1,19 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace UniFi_API\Exceptions;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Thrown when a provided short site name is invalid or cannot be used by the client.
|
||||||
|
*
|
||||||
|
* @note This Exception is thrown when the short site name contains illegal characters or when
|
||||||
|
* the name does not correspond to any known site on the controller.
|
||||||
|
*
|
||||||
|
* @package UniFi_Controller_API_Client_Class
|
||||||
|
*/
|
||||||
|
class InvalidSiteNameException extends UnifiApiException
|
||||||
|
{
|
||||||
|
public function __construct()
|
||||||
|
{
|
||||||
|
parent::__construct('Invalid site name provided.');
|
||||||
|
}
|
||||||
|
}
|
||||||
13
src/Exceptions/JsonDecodeException.php
Executable file
13
src/Exceptions/JsonDecodeException.php
Executable file
@@ -0,0 +1,13 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace UniFi_API\Exceptions;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Thrown when the library fails to decode JSON returned by the controller.
|
||||||
|
*
|
||||||
|
* @package UniFi_Controller_API_Client_Class
|
||||||
|
*/
|
||||||
|
class JsonDecodeException extends UnifiApiException
|
||||||
|
{
|
||||||
|
// Intentionally empty - represents JSON decoding failures.
|
||||||
|
}
|
||||||
36
src/Exceptions/LoginFailedException.php
Executable file
36
src/Exceptions/LoginFailedException.php
Executable file
@@ -0,0 +1,36 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace UniFi_API\Exceptions;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Thrown when the client fails to authenticate with the UniFi controller.
|
||||||
|
*
|
||||||
|
* @note This can indicate invalid credentials, connectivity problems, or a change
|
||||||
|
* in the controller's authentication mechanism (e.g., MFA).
|
||||||
|
*
|
||||||
|
* @property-read mixed $httpResponseCode HTTP response code if available
|
||||||
|
*
|
||||||
|
* @package UniFi_Controller_API_Client_Class
|
||||||
|
*/
|
||||||
|
class LoginFailedException extends UnifiApiException
|
||||||
|
{
|
||||||
|
/** @var mixed $_http_response_code */
|
||||||
|
private $_http_response_code;
|
||||||
|
|
||||||
|
public function __construct(string $message, $http_response_code)
|
||||||
|
{
|
||||||
|
$this->_http_response_code = $http_response_code;
|
||||||
|
|
||||||
|
parent::__construct($message, $http_response_code);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the HTTP response code.
|
||||||
|
*
|
||||||
|
* @return mixed
|
||||||
|
*/
|
||||||
|
public function getHttpResponseCode()
|
||||||
|
{
|
||||||
|
return $this->_http_response_code;
|
||||||
|
}
|
||||||
|
}
|
||||||
16
src/Exceptions/LoginRequiredException.php
Executable file
16
src/Exceptions/LoginRequiredException.php
Executable file
@@ -0,0 +1,16 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace UniFi_API\Exceptions;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Thrown when a method that requires authentication is called before logging in.
|
||||||
|
*
|
||||||
|
* @package UniFi_Controller_API_Client_Class
|
||||||
|
*/
|
||||||
|
class LoginRequiredException extends UnifiApiException
|
||||||
|
{
|
||||||
|
public function __construct()
|
||||||
|
{
|
||||||
|
parent::__construct('This method requires the API client to be logged in first.');
|
||||||
|
}
|
||||||
|
}
|
||||||
16
src/Exceptions/MacAddressEmptyException.php
Executable file
16
src/Exceptions/MacAddressEmptyException.php
Executable file
@@ -0,0 +1,16 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace UniFi_API\Exceptions;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Thrown when a MAC address was expected, but none was provided (empty/null).
|
||||||
|
*
|
||||||
|
* @package UniFi_Controller_API_Client_Class
|
||||||
|
*/
|
||||||
|
class MacAddressEmptyException extends UnifiApiException
|
||||||
|
{
|
||||||
|
public function __construct()
|
||||||
|
{
|
||||||
|
parent::__construct('MAC address is empty.');
|
||||||
|
}
|
||||||
|
}
|
||||||
17
src/Exceptions/MacAddressInvalidException.php
Executable file
17
src/Exceptions/MacAddressInvalidException.php
Executable file
@@ -0,0 +1,17 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace UniFi_API\Exceptions;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Thrown when a provided MAC address does not match expected formatting or
|
||||||
|
* validation rules.
|
||||||
|
*
|
||||||
|
* @package UniFi_Controller_API_Client_Class
|
||||||
|
*/
|
||||||
|
class MacAddressInvalidException extends UnifiApiException
|
||||||
|
{
|
||||||
|
public function __construct()
|
||||||
|
{
|
||||||
|
parent::__construct('MAC address is invalid.');
|
||||||
|
}
|
||||||
|
}
|
||||||
16
src/Exceptions/MethodDeprecatedException.php
Executable file
16
src/Exceptions/MethodDeprecatedException.php
Executable file
@@ -0,0 +1,16 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace UniFi_API\Exceptions;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Thrown when a library method or API endpoint has been deprecated and should
|
||||||
|
* no longer be used.
|
||||||
|
*
|
||||||
|
* @note Consumers can catch this to provide migration guidance or suppress warnings for legacy callers.
|
||||||
|
*
|
||||||
|
* @package UniFi_Controller_API_Client_Class
|
||||||
|
*/
|
||||||
|
class MethodDeprecatedException extends UnifiApiException
|
||||||
|
{
|
||||||
|
// Intentionally empty - serves as a distinct exception type.
|
||||||
|
}
|
||||||
16
src/Exceptions/NotAUnifiOsConsoleException.php
Executable file
16
src/Exceptions/NotAUnifiOsConsoleException.php
Executable file
@@ -0,0 +1,16 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace UniFi_API\Exceptions;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Thrown when the target host is not a UniFi OS console.
|
||||||
|
*
|
||||||
|
* @package UniFi_Controller_API_Client_Class
|
||||||
|
*/
|
||||||
|
class NotAUnifiOsConsoleException extends UnifiApiException
|
||||||
|
{
|
||||||
|
public function __construct()
|
||||||
|
{
|
||||||
|
parent::__construct('This is not a UniFi OS console.');
|
||||||
|
}
|
||||||
|
}
|
||||||
30
src/Exceptions/UnifiApiException.php
Executable file
30
src/Exceptions/UnifiApiException.php
Executable file
@@ -0,0 +1,30 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace UniFi_API\Exceptions;
|
||||||
|
|
||||||
|
use Exception;
|
||||||
|
use Throwable;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Base exception for the UniFi API client.
|
||||||
|
*
|
||||||
|
* @note All custom exceptions in this library extend this class so consumers can
|
||||||
|
* catch a single type (\UniFi_API\Exceptions\UnifiApiException) when they
|
||||||
|
* want to handle all client errors uniformly.
|
||||||
|
*
|
||||||
|
* @package UniFi_Controller_API_Client_Class
|
||||||
|
*/
|
||||||
|
class UnifiApiException extends Exception
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* UnifiApiException constructor.
|
||||||
|
*
|
||||||
|
* @param string $message Human-readable message describing the error.
|
||||||
|
* @param int $code Optional error code.
|
||||||
|
* @param Throwable|null $previous Optional previous exception for chaining.
|
||||||
|
*/
|
||||||
|
public function __construct(string $message = 'An error occurred in the UniFi API client.', int $code = 0, ?Throwable $previous = null)
|
||||||
|
{
|
||||||
|
parent::__construct($message, $code, $previous);
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user