Compare commits

...

17 Commits

Author SHA1 Message Date
malle-pietje
021d01ba86 API client class v1.1.68
- fixed a bug that was introduced with 1.1.67 and would only occur in certain corner cases
2021-01-24 18:09:38 +01:00
malle-pietje
caf838abb9 API client class v1.1.67
- fixed a bug where the request headers for subsequent function calls within the same Client instance would not always be cleared
2021-01-24 17:58:23 +01:00
malle-pietje
aa778c9b7b API client class v1.1.66
- simplified code based on Scrutinizer reports
2021-01-24 14:21:26 +01:00
malle-pietje
0e9ee66cef updated README to include new functions/methods 2021-01-23 11:44:12 +01:00
malle-pietje
721ba7d084 API client class v1.1.65
- applied minor improvements based on Scrutinizer reports
- applied minor changes to `authorize_guest()` to further improve handling of 0/null/empty values passed
- restricted protocols to be used by cURL to only allow http and https for improved security
- added methods/functions `list_device_name_mappings()` and `stat_full_status()`
2021-01-23 11:41:52 +01:00
malle-pietje
bf3446bba0 API client class v1.1.64
- added information to several docblocks
- changed handling of request headers, added private property for this
- applied changes for improved use of require_once in the README and examples
- added `list_sites()` example
- *potential breaking changes:*
    renamed `get_request_type()` and `set_request_type()` functions/methods to `get_request_method()` and `set_request_method()` respectively
2021-01-21 10:59:27 +01:00
malle-pietje
a4998de3a9 API client class v1.1.63
- changed references to *UbiOS* back to *UniFi OS*
- removed capitalization from all header strings (per RFC, header fields are case-insensitive: https://tools.ietf.org/html/rfc7230#section-3.2)
- removed charset parameter from headers (not required per RFC)
- added x-csrf-token header to all requests except GET when talking to UniFi OS-based controllers, thanks go to @paciks for raising #86
2021-01-06 17:03:21 +01:00
malle-pietje
c82481a28a API client class v1.1.62
- added several monthly stats methods: `stat_monthly_gateway()`, `stat_monthly_site()`, `stat_monthly_aps()`, `stat_monthly_user()`, thanks go to @Roel Janssens for spotting these MongoDB collections
- test for `object` or `resource` in `get_curl_resource()`, closes PR #82 submitted by @banakito
- applied change to comments in `example/modify_smartpower_pdu_outlet.php` based on a suggestion by @thesohoguy
- removed unnecessary variable from `list_apgroups()`, thanks go to Stephen Davies for reporting
- added an optional parameter $ap_group_ids to the `create_wlan()` function/method for UniFi controller versions 6.0.X and higher, thanks go to Stephen Davies for contributing
2020-12-10 14:52:39 +01:00
malle-pietje
2c743563f8 API client class v1.1.61
- minor improvements of comments contents
- fixed naming error in comments for list_devices()
- updated supported controller versions in main README
- change variable names used from MBytes to megabytes for improved consistency
2020-11-26 13:19:53 +01:00
malle-pietje
32252e56d7 API client class v1.1.60
- minor syntax improvements based on Scrutinizer CI feedback
- added support for PATCH requests (for future use)
- completed updating method/function comments to PHPDoc format (PSR-5)
2020-11-12 11:09:37 +01:00
malle-pietje
120699d343 API client class v1.1.59
- added methods/functions to manage AP groups: list_apgroups(), create_apgroup(), edit_apgroup(), and delete_apgroup() (only supported with controller versions 6.0.X and higher)
- adapted code to handle the behavior of the new v2 API routes that were added with controller versions 6.0.X and higher
- merged PR #76 which adds methods/functions check_controller_update() and check_firmware_update(), contributed  by @brenard
- further work on updating method/function comments to PHPDoc format (PSR-5)
2020-10-26 09:51:41 +01:00
malle-pietje
d26cba1f66 API client class v1.1.58
- changed several references from UniFi SDN controller to UniFi Network controller
- added optional payload parameter to the list_alarms() method/function, contributed by @MikeSiekkinen through PR #68
- added example showing how to disable/enable a UniFi switch port
- updated restart_device() function/method, thanks go to @leonardogyn for reporting this
- added example to modify outlet settings on a UniFi SmartPower PDU Pro, thanks go to @panthergm for providing access
2020-10-22 14:23:29 +02:00
malle-pietje
69b43df148 API client class v1.1.57
- increased minimum required PHP version to 5.5.0
- minor syntax improvement based on Scrutinizer feedback
- added create_dynamicdns() and set_dynamicdns() methods, "borrowed" routes from @smos
- added set_element_adoption() method, contributed by @VWT-Dan
- made a start at changing the function/method comments to PHPDoc format (PSR-5) which will support auto-generated class documentation (https://github.com/php-fig/fig-standards/blob/master/proposed/phpdoc.md#5-the-phpdoc-format)
- added check to throw an error when the $baseurl ends with a / character, thanks to @infraweavers for submitting #66
- fixed issue with logout() on UDM PROs, thanks go to @Olivier6767 for providing access to a UDM PRO, addresses #63
- applied several code styling improvements
2020-08-22 17:47:50 +02:00
malle-pietje
2b34890a67 - minor syntax improvement based on Scrutinizer feedback
- added create_dynamicdns() and set_dynamicdns() methods, "borrowed" routes from @smos
- made a start at changing the function/method comments to PHPDoc format (PSR-5) which will support auto-generated class documentation
(https://github.com/php-fig/fig-standards/blob/master/proposed/phpdoc.md#5-the-phpdoc-format)
2020-06-20 16:12:13 +02:00
malle-pietje
0d99d4a776 API client class v1.1.56
- switched to use of curl_setopt_array instead of curl_setopt which should slightly reduce the overall PHP execution time (https://gist.github.com/masakielastic/3330620)
- several minor code improvements
2020-06-13 12:28:43 +02:00
malle-pietje
89ce2fd8dd - general code clean up
- removed repetitive code (checks using $this->is_loggedin())
- updated the main README to include the latest added functions/methods
2020-06-08 12:52:32 +02:00
malle-pietje
c77913fded API client class v1.1.54
- fixed list_alarms() method/function
2020-06-07 14:23:44 +02:00
34 changed files with 2064 additions and 1936 deletions

4
.gitignore vendored
View File

@@ -5,5 +5,9 @@
/vendor/ /vendor/
/composer.lock /composer.lock
# ignore phpdoc files
/build
.phpdoc-md
# ignore XML files # ignore XML files
*.xml *.xml

144
README.md
View File

@@ -1,29 +1,32 @@
## UniFi Controller API client class ## UniFi Controller API client class
A PHP class that provides access to Ubiquiti's [**UniFi SDN Controller**](https://unifi-sdn.ui.com/) API, versions 4.X.X and 5.X.X of the UniFi SDN Controller software are supported (version 5.12.66 has been confirmed to work) as well as UbiOS-based controllers (version 5.12.59 has been confirmed to work). This class is used in our API browser tool which can be found [here](https://github.com/Art-of-WiFi/UniFi-API-browser). A PHP class that provides access to Ubiquiti's [**UniFi Network Controller**](https://unifi-network.ui.com/) API, versions 4.X.X, 5.X.X and 6.0.X of the UniFi Network Controller software are supported (version 6.0.43 has been confirmed to work) as well as UniFi OS-based controllers (version 5.12.59 has been confirmed to work). 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 composer/[packagist](https://packagist.org/packages/art-of-wifi/unifi-api-client) for easy inclusion in your projects.
The package can be installed manually or using composer/[packagist](https://packagist.org/packages/art-of-wifi/unifi-api-client) for easy inclusion in your projects.
## Requirements ## Requirements
- a server with PHP and cURL modules installed (tested on Apache 2.4 with PHP Version 5.6.1 and cURL 7.42.1 and with PHP 7.2.24 and cURL 7.58.0) - a server with PHP, version 5.5.0 or higher, and the PHP cURL module installed (tested on Apache 2.4 with PHP Version 5.6.1 and cURL 7.42.1 and with PHP 7.2.24 and cURL 7.58.0)
- network connectivity between this server and the host and port (normally TCP port 8443) where the UniFi Controller is running - direct network connectivity between this server and the host and port (normally TCP port 8443) where the UniFi Controller is running
- you must use **local accounts**, not UniFi Cloud accounts, to access the UniFi Controller API through this class - you must use **local accounts**, not UniFi Cloud accounts, to access the UniFi Controller API through this class
## UbiOS Support ## UniFi OS Support
Support for UbiOS-based controllers (UniFi Dream Machine Pro) has been added as of version 1.1.47. The class automatically detects UbiOS devices and adjusts URLs and several functions/methods accordingly. If your own code applies strict validation of the URL that is passed to the constructor, please adapt your logic to allow URLs without a port suffix when dealing with a UbiOS-based controller. Support for UniFi OS-based controllers (UniFi Dream Machine Pro or Cloud Key Gen2/Cloud Key Gen2 Plus with firmware version 2.0.24 or higher) has been added as of version 1.1.47. The class automatically detects UniFi OS devices and adjusts URLs and several functions/methods accordingly. If your own code applies strict validation of the URL that is passed to the constructor, please adapt your logic to allow URLs without a port suffix when dealing with a UniFi OS-based controller.
Please test all methods you plan on using thoroughly before using the API Client with UniFi OS devices in a production environment.
Please test all methods you plan on using thoroughly before using the API Client with UbiOS devices in a production environment.
## Installation ## Installation
You can use [Composer](#composer), [Git](#git) or simply [Download the Release](#download-the-release) to install the API client class. Use [Composer](#composer), [Git](#git) or simply [Download the Release](#download-the-release) to install the API client class.
### Composer ### Composer
The preferred method is via [composer](https://getcomposer.org). Follow the [installation instructions](https://getcomposer.org/doc/00-intro.md) if you do not already have composer installed. The preferred installation method is through [composer](https://getcomposer.org). Follow these [installation instructions](https://getcomposer.org/doc/00-intro.md) if you do not already have composer installed.
Once composer is installed, simply execute this command from the shell in your project directory: Once composer is installed, simply execute this command from the shell in your project directory:
@@ -31,7 +34,7 @@ Once composer is installed, simply execute this command from the shell in your p
composer require art-of-wifi/unifi-api-client composer require art-of-wifi/unifi-api-client
``` ```
Or you can manually add the package to your composer.json file: Or manually add the package to your composer.json file:
```javascript ```javascript
{ {
@@ -44,9 +47,10 @@ composer require art-of-wifi/unifi-api-client
Finally, be sure to include the autoloader in your code: Finally, be sure to include the autoloader in your code:
```php ```php
require_once('vendor/autoload.php'); require_once 'vendor/autoload.php';
``` ```
### Git ### Git
Execute the following `git` command from the shell in your project directory: Execute the following `git` command from the shell in your project directory:
@@ -58,17 +62,19 @@ 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: When git is done cloning, include the file containing the class like so in your code:
```php ```php
require_once('path/to/src/Client.php'); require_once 'path/to/src/Client.php';
``` ```
### Download the Release ### Download the Release
If you prefer not to use composer or git, you can simply [download the package](https://github.com/Art-of-WiFi/UniFi-API-client/archive/master.zip), uncompress the zip file, then include the file containing the class in your code like so: 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), uncompress the zip file, then include the file containing the class in your code like so:
```php ```php
require_once('path/to/src/Client.php'); require_once 'path/to/src/Client.php';
``` ```
## Example usage ## Example usage
A basic example how to use the class: A basic example how to use the class:
@@ -77,7 +83,7 @@ A basic example how to use the class:
/** /**
* load the class using the composer autoloader * load the class using the composer autoloader
*/ */
require_once('vendor/autoload.php'); require_once 'vendor/autoload.php';
/** /**
* initialize the Unifi API connection class, log in to the controller and request the alarms collection * initialize the Unifi API connection class, log in to the controller and request the alarms collection
@@ -88,17 +94,19 @@ $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 you can use as a starting point for your own PHP code. 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 managing the site in the UniFi SDN Controller. For example with this URL: 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:
`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 last 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 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. 2. The last 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 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.
## Functions/methods supported ## Functions/methods supported
@@ -108,19 +116,27 @@ The class currently supports the following functions/methods to GET/POST/PUT/DEL
- logout() - logout()
- adopt_device() - adopt_device()
- archive_alarm() - archive_alarm()
- assign_existing_admin()
- authorize_guest() - authorize_guest()
- block_sta() - block_sta()
- cancel_rolling_upgrade()
- cmd_stat()
- count_alarms() - count_alarms()
- check_controller_update()
- check_firmware_update()
- create_apgroup() (supported with controller versions 6.0.X and higher)
- create_dynamicdns()
- create_firewallgroup() - create_firewallgroup()
- create_hotspotop() - create_hotspotop()
- create_network() - create_network()
- create_radius_account() - create_radius_account()
- create_site() - create_site()
- create_usergroup()
- create_user() - create_user()
- create_usergroup()
- create_voucher() - create_voucher()
- create_wlan() - create_wlan()
- custom_api_request() - custom_api_request()
- delete_apgroup() (supported with controller versions 6.0.X and higher)
- delete_device() - delete_device()
- delete_firewallgroup() - delete_firewallgroup()
- delete_network() - delete_network()
@@ -129,18 +145,18 @@ The class currently supports the following functions/methods to GET/POST/PUT/DEL
- delete_usergroup() - delete_usergroup()
- delete_wlan() - delete_wlan()
- disable_ap() - disable_ap()
- edit_apgroup() (supported with controller versions 6.0.X and higher)
- edit_client_fixedip() - edit_client_fixedip()
- edit_firewallgroup() - edit_firewallgroup()
- edit_usergroup() - edit_usergroup()
- extend_guest_validity() - extend_guest_validity()
- forget_sta() (supported on controller version 5.9.X and higher) - forget_sta() (supported on controller version 5.9.X and higher)
- invite_admin() - invite_admin()
- assign_existing_admin()
- revoke_admin()
- led_override() - led_override()
- list_admins() - list_admins()
- list_all_admins()
- list_alarms() - 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_aps() (deprecated but still available as alias)
- list_backups() - list_backups()
- list_clients() - list_clients()
@@ -148,11 +164,13 @@ The class currently supports the following functions/methods to GET/POST/PUT/DEL
- list_current_channels() - list_current_channels()
- list_dashboard() - list_dashboard()
- list_devices() - list_devices()
- list_device_name_mappings()
- list_dpi_stats() - list_dpi_stats()
- list_dynamicdns() - list_dynamicdns()
- list_events() - list_events()
- list_extension() - list_extension()
- list_firewallgroups() - list_firewallgroups()
- list_firmware()
- list_guests() - list_guests()
- list_health() - list_health()
- list_hotspotop() - list_hotspotop()
@@ -164,6 +182,7 @@ The class currently supports the following functions/methods to GET/POST/PUT/DEL
- list_radius_accounts() (supported on controller version 5.5.19 and higher) - list_radius_accounts() (supported on controller version 5.5.19 and higher)
- list_radius_profiles() - list_radius_profiles()
- list_rogueaps() - list_rogueaps()
- list_routing()
- list_self() - list_self()
- list_settings() - list_settings()
- list_sites() - list_sites()
@@ -175,14 +194,17 @@ The class currently supports the following functions/methods to GET/POST/PUT/DEL
- locate_ap() - locate_ap()
- move_device() - move_device()
- power_cycle_switch_port() - power_cycle_switch_port()
- reboot_cloudkey()
- reconnect_sta() - reconnect_sta()
- rename_ap() - rename_ap()
- restart_ap() (deprecated but still available as alias) - restart_ap() (deprecated but still available as alias)
- restart_device() - restart_device()
- reboot_cloudkey() - revoke_admin()
- revoke_voucher() - revoke_voucher()
- set_ap_radiosettings() - set_ap_radiosettings()
- set_device_settings_base() - set_device_settings_base()
- set_dynamicdns()
- set_element_adoption() (supported on controller version 5.13.X and higher)
- set_guestlogin_settings() - set_guestlogin_settings()
- set_guestlogin_settings_base() - set_guestlogin_settings_base()
- set_ips_settings_base() (supported on controller version 5.9.10 and higher) - set_ips_settings_base() (supported on controller version 5.9.10 and higher)
@@ -197,11 +219,11 @@ The class currently supports the following functions/methods to GET/POST/PUT/DEL
- set_site_name() - set_site_name()
- set_site_ntp() - set_site_ntp()
- set_site_snmp() - set_site_snmp()
- set_super_mgmt_settings_base()
- set_super_smtp_settings_base()
- set_super_identity_settings_base()
- set_sta_name() - set_sta_name()
- set_sta_note() - set_sta_note()
- set_super_identity_settings_base()
- set_super_mgmt_settings_base()
- set_super_smtp_settings_base()
- set_usergroup() - set_usergroup()
- set_wlan_mac_filter() - set_wlan_mac_filter()
- set_wlansettings() - set_wlansettings()
@@ -211,71 +233,76 @@ The class currently supports the following functions/methods to GET/POST/PUT/DEL
- site_ledson() (deprecated but still available as alias) - site_ledson() (deprecated but still available as alias)
- spectrum_scan() - spectrum_scan()
- spectrum_scan_state() - 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_allusers()
- stat_auths() - stat_auths()
- stat_client() - stat_client()
- stat_5minutes_aps() (supported on controller version 5.5.X and higher)
- stat_hourly_aps()
- stat_daily_aps() - stat_daily_aps()
- stat_5minutes_gateway() (supported on controller version 5.7.X and higher)
- stat_hourly_gateway() (supported on controller version 5.7.X and higher)
- stat_daily_gateway() (supported on controller version 5.7.X and higher) - stat_daily_gateway() (supported on controller version 5.7.X and higher)
- stat_5minutes_site() (supported on controller version 5.5.X and higher)
- stat_hourly_site()
- stat_daily_site() - stat_daily_site()
- stat_5minutes_user (supported on controller version 5.7.X and higher)
- stat_hourly_user() (supported on controller version 5.7.X and higher)
- stat_daily_user() (supported on controller version 5.7.X and higher) - stat_daily_user() (supported on controller version 5.7.X and higher)
- 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_payment() - stat_payment()
- stat_sessions() - stat_sessions()
- stat_sites() - stat_sites()
- stat_speedtest_results() - stat_speedtest_results()
- stat_ips_events() (supported on controller version 5.9.10 and higher)
- stat_sta_sessions_latest() - stat_sta_sessions_latest()
- stat_status() - stat_status()
- stat_full_status()
- stat_sysinfo() - stat_sysinfo()
- stat_voucher() - stat_voucher()
- stat_monthly_aps()
- stat_monthly_gateway()
- stat_monthly_site()
- stat_monthly_user()
- unauthorize_guest() - unauthorize_guest()
- unblock_sta() - unblock_sta()
- unset_locate_ap() (deprecated but still available as alias) - unset_locate_ap() (deprecated but still available as alias)
- upgrade_device() - upgrade_device()
- upgrade_device_external() - upgrade_device_external()
- start_rolling_upgrade()
- cancel_rolling_upgrade()
- cmd_stat()
Other functions, getters/setters: Other functions, getters/setters:
- set_debug()
- get_debug()
- set_site()
- get_site()
- set_cookies()
- get_cookies()
- get_cookie() (renamed from getcookie(), deprecated but still available, use get_cookies() instead)
- get_last_results_raw()
- get_last_error_message()
- set_request_type()
- get_request_type()
- set_ssl_verify_peer()
- get_ssl_verify_peer()
- set_ssl_verify_host()
- get_ssl_verify_host()
- set_connection_timeout()
- get_connection_timeout()
- set_is_unifi_os()
- get_is_unifi_os()
- get_class_version() - get_class_version()
- get_connection_timeout()
- get_cookie() (renamed from getcookie(), deprecated but still available, use get_cookies() instead)
- get_cookies()
- get_debug()
- get_is_unifi_os()
- get_last_error_message()
- get_last_results_raw()
- get_request_method()
- get_site()
- get_ssl_verify_host()
- get_ssl_verify_peer()
- set_connection_timeout()
- set_cookies()
- set_debug()
- set_is_unifi_os()
- set_request_method()
- set_site()
- set_ssl_verify_host()
- set_ssl_verify_peer()
## 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 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 Community forums (https://community.ubnt.com/t5/UniFi-Wireless/PHP-class-to-access-the-UniFi-controller-API-updates-and/td-p/1512870) to share your suggestions and questions. 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 [issue list](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) to share your suggestions and questions.
## Contribute ## Contribute
If you would like to contribute code (improvements), please open an issue and include your code there or else create a pull request. If you would like to contribute code (improvements), please open an issue and include your code there or else create a pull request.
## Credits ## Credits
This class is based on the initial work by the following developers: This class is based on the initial work by the following developers:
@@ -285,7 +312,8 @@ 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/5.12.35/unifi_sh_api - https://dl.ui.com/unifi/6.0.41/unifi_sh_api
## Important Disclaimer ## Important Disclaimer

View File

@@ -1,27 +1,28 @@
{ {
"name": "art-of-wifi/unifi-api-client", "name": "art-of-wifi/unifi-api-client",
"type": "library", "type": "library",
"description": "API client class for use with Ubiquiti's UniFi controller", "description": "API client class for use with Ubiquiti's UniFi controller",
"keywords": [ "keywords": [
"ubnt", "ubnt",
"ubiquiti", "ubiquiti",
"unifi", "unifi",
"controller", "controller",
"api", "api",
"client" "client"
], ],
"homepage": "https://github.com/Art-of-WiFi/UniFi-API-client", "homepage": "https://github.com/Art-of-WiFi/UniFi-API-client",
"license": "MIT", "license": "MIT",
"authors": [ "authors": [
{ {
"name": "Art of WiFi", "name": "Art of WiFi",
"email": "info@artofowifi.net", "email": "info@artofowifi.net",
"homepage": "http://artofwifi.net" "homepage": "http://artofwifi.net"
} }
], ],
"require": { "require": {
"php": ">=5.4.0", "php": ">=5.5.0",
"ext-curl": "*" "ext-curl": "*",
"ext-json": "*"
}, },
"autoload": { "autoload": {
"psr-4": { "psr-4": {

View File

@@ -3,19 +3,19 @@
* PHP API usage example * PHP API usage example
* *
* contributed by: Art of WiFi * contributed by: Art of WiFi
* description: example basic PHP script to fetch an Access Point's scanning state/results * description: example basic PHP script to fetch an Access Point's scanning state/results
*/ */
/** /**
* using the composer autoloader * using the composer autoloader
*/ */
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 file for an example * see the config.template.php file for an example
*/ */
require_once('config.php'); require_once 'config.php';
/** /**
* site id and MAC address of AP to query * site id and MAC address of AP to query

View File

@@ -3,11 +3,11 @@
* PHP API usage example * PHP API usage example
* *
* contributed by: @4oo4 * contributed by: @4oo4
* description: example script to upgrade device firmware (can be scheduled with systemd/cron) * description: example script to upgrade device firmware (can be scheduled with systemd/cron)
* to the most current version * to the most current version
*/ */
require_once('vendor/autoload.php'); require_once 'vendor/autoload.php';
require_once('config.php'); require_once 'config.php';
/** /**
* site id of the AP to update * site id of the AP to update

View File

@@ -3,19 +3,19 @@
* PHP API usage example * PHP API usage example
* *
* contributed by: Art of WiFi * contributed by: Art of WiFi
* description: example PHP script to perform a basic auth of a guest device * description: example PHP script to perform a basic auth of a guest device
*/ */
/** /**
* using the composer autoloader * using the composer autoloader
*/ */
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 file for an example * see the config.template.php file for an example
*/ */
require_once('config.php'); require_once 'config.php';
/** /**
* the MAC address of the device to authorize * the MAC address of the device to authorize

View File

@@ -3,21 +3,21 @@
* PHP API usage example * PHP API usage example
* *
* contributed by: Art of WiFi * contributed by: Art of WiFi
* description: example basic PHP script to auth a guest device and attach a note to it, * description: example basic PHP script to auth a guest device and attach a note to it,
* this requires the device to be connected to the WLAN/LAN at moment of * this requires the device to be connected to the WLAN/LAN at moment of
* authorization * authorization
*/ */
/** /**
* using the composer autoloader * using the composer autoloader
*/ */
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 file for an example * see the config.template.php file for an example
*/ */
require_once('config.php'); require_once 'config.php';
/** /**
* the MAC address of the device to authorize * the MAC address of the device to authorize

View File

@@ -3,27 +3,26 @@
* PHP API usage example * PHP API usage example
* *
* contributed by: @malcolmcif, based on another Art of WiFi example * contributed by: @malcolmcif, based on another Art of WiFi example
* description: basic PHP script to block a list of mac addresses passed in via command line, * description: basic PHP script to block a list of mac addresses passed in via command line,
* output is to console in non json format * output is to console in non json format
* *
* usage: * usage:
* php block_list.php <list of comma seperated mac addresses> * php block_list.php <list of comma seperated mac addresses>
* *
* example: * example:
* php block_list.php 09:09:09:09:09:09,10:10:10:10:10:10 * php block_list.php 09:09:09:09:09:09,10:10:10:10:10:10
*
*/ */
/** /**
* using the composer autoloader * using the composer autoloader
*/ */
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 file for an example * see the config.template.php file for an example
*/ */
require_once('config.php'); require_once 'config.php';
$debug = false; $debug = false;
/** /**

View File

@@ -3,14 +3,14 @@
* PHP API usage example * PHP API usage example
* *
* contributed by: Art of WiFi * contributed by: Art of WiFi
* description: example basic PHP script to modify the super_mgmt settings for UniFi controller and output results * description: example basic PHP script to modify the super_mgmt settings for UniFi controller and output results
* in json format * in json format
*/ */
/** /**
* using the composer autoloader * using the composer autoloader
*/ */
require_once('vendor/autoload.php'); require_once 'vendor/autoload.php';
/** /**
* UniFi controller credentials and the site to use, in this case since we are modifying global settings you can select * UniFi controller credentials and the site to use, in this case since we are modifying global settings you can select
@@ -18,7 +18,7 @@ require_once('vendor/autoload.php');
* *
* NOTE: in this case you need to enter Super Administrator account credentials in config.php * NOTE: in this case you need to enter Super Administrator account credentials in config.php
*/ */
require_once('config.php'); require_once 'config.php';
$site_id = 'default'; $site_id = 'default';
$debug = false; $debug = false;

View File

@@ -3,19 +3,19 @@
* PHP API usage example * PHP API usage example
* *
* contributed by: Art of WiFi * contributed by: Art of WiFi
* description: example basic PHP script to change the WPA2 password/PSK of a WLAN, returns true on success * description: example basic PHP script to change the WPA2 password/PSK of a WLAN, returns true on success
*/ */
/** /**
* using the composer autoloader * using the composer autoloader
*/ */
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 file for an example * see the config.template.php file for an example
*/ */
require_once('config.php'); require_once 'config.php';
/** /**
* The site to which the WLAN you want to modify belongs * The site to which the WLAN you want to modify belongs

View File

@@ -1,10 +1,8 @@
<?php <?php
/** /**
* Copyright (c) 2017, Art of WiFi * Copyright (c) 2021, Art of WiFi
*
* This file is subject to the MIT license that is bundled
* with this package in the file LICENSE.md
* *
* This file is subject to the MIT license that is bundled with this package in the file LICENSE.md
*/ */
/** /**

View File

@@ -3,19 +3,19 @@
* PHP API usage example * PHP API usage example
* *
* contributed by: Art of WiFi * contributed by: Art of WiFi
* description: example basic PHP script to create a new site, returns true upon success * description: example basic PHP script to create a new site, returns true upon success
*/ */
/** /**
* using the composer autoloader * using the composer autoloader
*/ */
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 file for an example * see the config.template.php file for an example
*/ */
require_once('config.php'); require_once 'config.php';
/** /**
* the site to use to log in to the controller * the site to use to log in to the controller

View File

@@ -3,19 +3,19 @@
* PHP API usage example * PHP API usage example
* *
* contributed by: Art of WiFi * contributed by: Art of WiFi
* description: example basic PHP script to create a set of vouchers, returns an array containing the newly created vouchers * description: example basic PHP script to create a set of vouchers, returns an array containing the newly created vouchers
*/ */
/** /**
* using the composer autoloader * using the composer autoloader
*/ */
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 file for an example * see the config.template.php file for an example
*/ */
require_once('config.php'); require_once 'config.php';
/** /**
* minutes the voucher is valid after activation (expiration time) * minutes the voucher is valid after activation (expiration time)

View File

@@ -3,19 +3,19 @@
* PHP API usage example * PHP API usage example
* *
* contributed by: Art of WiFi * contributed by: Art of WiFi
* description: example basic PHP script to delete a site, returns true upon success * description: example basic PHP script to delete a site, returns true upon success
*/ */
/** /**
* using the composer autoloader * using the composer autoloader
*/ */
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 file for an example * see the config.template.php file for an example
*/ */
require_once('config.php'); require_once 'config.php';
/** /**
* the site to use to log in to the controller * the site to use to log in to the controller

View File

@@ -3,19 +3,19 @@
* PHP API usage example * PHP API usage example
* *
* contributed by: Art of WiFi * contributed by: Art of WiFi
* description: example basic PHP script to disable/enable a device, returns true upon success * description: example basic PHP script to disable/enable a device, returns true upon success
*/ */
/** /**
* using the composer autoloader * using the composer autoloader
*/ */
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 file for an example * see the config.template.php file for an example
*/ */
require_once('config.php'); require_once 'config.php';
/** /**
* the 24 character id of the device to disable/enable * the 24 character id of the device to disable/enable

View File

@@ -0,0 +1,78 @@
<?php
/**
* PHP API usage example
*
* contributed by: Art of WiFi
* description: example PHP script to disable/enable the port of a UniFi switch
* note: Requires controller version 5.5.X or higher. This example assumes an override alreay exists for the desired port.
* To create a new port override simply append one (similar in structure to $updated_override) as needed to the
* $existing_overrides array
*/
/**
* 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 to log in to the controller
*/
$site_id = '<enter your site id here>';
/**
* the MAC address of the UniFi switch to re-configure
*/
$device_mac = '<enter MAC address>';
/**
* index of port to modify/add
*/
$port_idx = 24;
/**
* port configuration id to apply when enabling/disabling the port
*
* NOTE:
* port configurations are available through list_portconf()
*/
$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
*/
$unifi_connection = new UniFi_API\Client($controlleruser, $controllerpassword, $controllerurl, $site_id, $controllerversion, false);
$set_debug_mode = $unifi_connection->set_debug($debug);
$loginresults = $unifi_connection->login();
$data = $unifi_connection->list_devices($device_mac);
$device_id = $data[0]->device_id;
$existing_overrides = $data[0]->port_overrides;
foreach ($existing_overrides as $key => $value) {
if (!empty($value->port_idx) && $value->port_idx === $port_idx) {
$updated_override = [
'portconf_id' => $port_conf_id,
'port_idx' => $port_idx,
'poe_mode' => $value->poe_mode,
'name' => 'Your-port-name',
];
$existing_overrides[$key] = $updated_override;
}
}
$payload = [
'port_overrides' => $existing_overrides
];
$update_device = $unifi_connection->set_device_settings_base($device_id, $payload);
/**
* provide feedback in json format
*/
echo json_encode($update_device, JSON_PRETTY_PRINT);

View File

@@ -3,20 +3,20 @@
* PHP API usage example * PHP API usage example
* *
* contributed by: Art of WiFi * contributed by: Art of WiFi
* description: example basic PHP script to execute a custom API request using the * description: example basic PHP script to execute a custom API request using the
* custom_api_request() function/method * custom_api_request() function/method
*/ */
/** /**
* using the composer autoloader * using the composer autoloader
*/ */
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 file for an example * see the config.template.php file for an example
*/ */
require_once('config.php'); require_once 'config.php';
/** /**
* The site to authorize the device with * The site to authorize the device with
@@ -27,10 +27,10 @@ $site_id = '<enter your site id here>';
/** /**
* parameters * parameters
*/ */
$url = '/api/s/' . $site_id . '/stat/fwupdate/latest-version'; $url = '/api/s/' . $site_id . '/stat/fwupdate/latest-version';
$request_type = 'GET'; $request_method = 'GET';
$payload = null; $payload = null;
$return = 'array'; $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
@@ -38,7 +38,7 @@ $return = 'array';
$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_type, $payload, $return); $results = $unifi_connection->custom_api_request($url, $request_method, $payload, $return);
/** /**
* provide feedback in JSON format or as PHP Object * provide feedback in JSON format or as PHP Object

View File

@@ -3,19 +3,19 @@
* PHP API usage example * PHP API usage example
* *
* contributed by: mtotone * contributed by: mtotone
* description: example of how to extend validity of guest authorizations * description: example of how to extend validity of guest authorizations
*/ */
/** /**
* using the composer autoloader * using the composer autoloader
*/ */
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 file for an example * see the config.template.php file for an example
*/ */
require_once('config.php'); require_once 'config.php';
/** /**
* must be adapted to your site! * must be adapted to your site!

View File

@@ -3,19 +3,19 @@
* 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: example basic PHP script to pull current alarms from the UniFi controller and output in json format
*/ */
/** /**
* using the composer autoloader * using the composer autoloader
*/ */
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 file for an example * see the config.template.php file for an example
*/ */
require_once('config.php'); require_once 'config.php';
/** /**
* the site to use * the site to use

View File

@@ -3,20 +3,20 @@
* PHP API usage example * PHP API usage example
* *
* contributed by: Art of WiFi * contributed by: Art of WiFi
* description: example to pull connected user numbers for Access Points from the UniFi controller and output the results * description: example to pull connected user numbers for Access Points from the UniFi controller and output the results
* in raw HTML format * in raw HTML format
*/ */
/** /**
* using the composer autoloader * using the composer autoloader
*/ */
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 file for an example * see the config.template.php file for an example
*/ */
require_once('config.php'); require_once 'config.php';
/** /**
* the short name of the site which you wish to query * the short name of the site which you wish to query

View File

@@ -3,19 +3,19 @@
* PHP API usage example * PHP API usage example
* *
* contributed by: @gahujipo * contributed by: @gahujipo
* description: example to pull connected users and their details from the UniFi controller and output the results * description: example to pull connected users and their details from the UniFi controller and output the results
* in JSON format * in JSON format
*/ */
/** /**
* using the composer autoloader * using the composer autoloader
*/ */
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 file for an example * see the config.template.php file for an example
*/ */
require_once('config.php'); require_once 'config.php';
/** /**
* the short name of the site which you wish to query * the short name of the site which you wish to query

View File

@@ -3,20 +3,20 @@
* PHP API usage example * PHP API usage example
* *
* contributed by: Art of WiFi * contributed by: Art of WiFi
* description: example to pull site health metrics from the UniFi controller and output the results * description: example to pull site health metrics from the UniFi controller and output the results
* in json format * in json format
*/ */
/** /**
* using the composer autoloader * using the composer autoloader
*/ */
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 file for an example * see the config.template.php file for an example
*/ */
require_once('config.php'); require_once 'config.php';
/** /**
* the short name of the site you wish to query * the short name of the site you wish to query

46
examples/list_sites.php Executable file
View File

@@ -0,0 +1,46 @@
<?php
/**
* PHP API usage example
*
* contributed by: Art of WiFi
* description: example basic PHP script to list all site on the controller that are
* available to the admin account defined in config.php
*/
/**
* 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';
/**
* we use the default site in the initial connection
*/
$site_id = 'default';
/**
* 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();
$data = $unifi_connection->list_sites();
/**
* we can render the full results in json format
*/
//echo json_encode($data, JSON_PRETTY_PRINT);
/**
* or we print each site name and site id
*/
foreach ($data as $site) {
echo 'Site name: ' . $site->desc . ', site id: ' . $site->name . PHP_EOL;
}
echo PHP_EOL;

View File

@@ -3,20 +3,20 @@
* 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 Facebook social auth details from the UniFi controller and output * description: example basic PHP script to pull Facebook social auth details from the UniFi controller and output
* them in basic HTML format * them in basic HTML format
*/ */
/** /**
* using the composer autoloader * using the composer autoloader
*/ */
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 file for an example * see the config.template.php file for an example
*/ */
require_once('config.php'); require_once 'config.php';
/** /**
* the site to use * the site to use

View File

@@ -3,19 +3,19 @@
* 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 stats for s epcific user/client device from the UniFi controller and output in json format * description: example basic PHP script to pull stats for s epcific user/client device from the UniFi controller and output in json format
*/ */
/** /**
* using the composer autoloader * using the composer autoloader
*/ */
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 file for an example * see the config.template.php file for an example
*/ */
require_once('config.php'); require_once 'config.php';
/** /**
* the site to use * the site to use

View File

@@ -0,0 +1,87 @@
<?php
/**
* PHP API usage example
*
* contributed by: Art of WiFi
* description: example basic PHP script to toggle power of an outlet on the UniFi SmartPower PDU Pro,
* last tested with UniFi controller version 6.1.19
*/
require '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 = 'default';
/**
* MAC of UniFi SmartPower PDU Pro to work with
*/
$pdu_mac = '<MAC ADDRESS of PDU>';
/**
* index value of the outlet to modify
*/
$outlet_idx = 20;
/**
* new values for relay_state (enable/disable Power) and cycle_enabled (disable/enable Modem Power Cycle) for the above outlet,
* values must be boolean (true/false)
*
* NOTES:
* - here you can choose to also change the name of the outlet
* - outlet overrides are structured like this:
* {
* "index": 1,
* "name": "USB Outlet 1",
* "cycle_enabled": false,
* "relay_state": true
* }
*/
$new_relay_state = true;
$new_cycle_enabled = false;
/**
* 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();
if ($loginresults) {
$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)
*/
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;
$outlet_overrides = $pdu_details[0]->outlet_overrides;
foreach ($outlet_overrides as $key => $value) {
if ($value->index === $outlet_idx) {
$outlet_overrides[$key]->relay_state = $new_relay_state;
$outlet_overrides[$key]->cycle_enabled = $new_cycle_enabled;
}
}
$pdu_update = $unifi_connection->set_device_settings_base($device_id, ['outlet_overrides' => $outlet_overrides]);
/**
* provide feedback in json format
*/
echo 'results:' . PHP_EOL . PHP_EOL;
echo json_encode($pdu_update, JSON_PRETTY_PRINT);
echo PHP_EOL;
} else {
echo 'not a PDU device?';
echo PHP_EOL;
}
} else {
echo 'we encountered a login error!';
echo PHP_EOL;
}

View File

@@ -3,19 +3,19 @@
* PHP API usage example * PHP API usage example
* *
* contributed by: Art of WiFi * contributed by: Art of WiFi
* description: example basic PHP script to force a client device to reconnect * description: example basic PHP script to force a client device to reconnect
*/ */
/** /**
* using the composer autoloader * using the composer autoloader
*/ */
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 file for an example * see the config.template.php file for an example
*/ */
require_once('config.php'); require_once 'config.php';
/** /**
* the MAC address to reconnect * the MAC address to reconnect

View File

@@ -3,7 +3,7 @@
* Test the connection to your UniFi controller * Test the connection to your UniFi controller
* *
* contributed by: Art of WiFi * contributed by: Art of WiFi
* description: PHP script to check/debug the connection to your controller using PHP and cURL * description: PHP script to check/debug the connection to your controller using PHP and cURL
*/ */
/** /**
@@ -11,7 +11,7 @@
* see the config.template.php file for an example. * see the config.template.php file for an example.
* (will only be used here to get the URL to the controller) * (will only be used here to get the URL to the controller)
*/ */
require_once('config.php'); require_once 'config.php';
/** /**
* Check whether the cURL module supports SSL * Check whether the cURL module supports SSL

View File

@@ -3,20 +3,20 @@
* PHP API usage example * PHP API usage example
* *
* contributed by: Art of WiFi * contributed by: Art of WiFi
* description: example to toggle the locate function (flashing LED) on an Access Point and * description: example to toggle the locate function (flashing LED) on an Access Point and
* output the response in json format * output the response in json format
*/ */
/** /**
* using the composer autoloader * using the composer autoloader
*/ */
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 file for an example * see the config.template.php file for an example
*/ */
require_once('config.php'); require_once 'config.php';
/** /**
* site id to use * site id to use

View File

@@ -3,8 +3,8 @@
* PHP API usage example * PHP API usage example
* *
* contributed by: @malcolmcif, based on another Art of WiFi example * contributed by: @malcolmcif, based on another Art of WiFi example
* description: basic PHP script to unblock a list of mac addresses passed in via command line, * description: basic PHP script to unblock a list of mac addresses passed in via command line,
* output is to console in non json format * output is to console in non json format
* *
* usage: * usage:
* php unblock_list.php <list of comma seperated mac addresses> * php unblock_list.php <list of comma seperated mac addresses>
@@ -17,13 +17,13 @@
/** /**
* using the composer autoloader * using the composer autoloader
*/ */
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 file for an example * see the config.template.php file for an example
*/ */
require_once('config.php'); require_once 'config.php';
$debug = false; $debug = false;
/** /**

View File

@@ -3,21 +3,21 @@
* PHP API usage example * PHP API usage example
* *
* contributed by: Art of WiFi * contributed by: Art of WiFi
* description: example basic PHP script to update the port settings of an AC-IW device * description: example basic PHP script to update the port settings of an AC-IW device
* FYI: the AC-IW device has three ports, one for the wired uplink and two with external connectors * FYI: the AC-IW device has three ports, one for the wired uplink and two with external connectors
* note: requires controller version 5.5.X or higher (to be verified) * note: requires controller version 5.5.X or higher (to be verified)
*/ */
/** /**
* using the composer autoloader * using the composer autoloader
*/ */
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 file for an example * see the config.template.php file for an example
*/ */
require_once('config.php'); require_once 'config.php';
/** /**
* the site to use to log in to the controller * the site to use to log in to the controller

View File

@@ -3,20 +3,20 @@
* PHP API usage example * PHP API usage example
* *
* contributed by: Art of WiFi * contributed by: Art of WiFi
* description: example basic PHP script to update WLAN settings of a device when using a controller version 5.5.X or higher * description: example basic PHP script to update WLAN settings of a device when using a controller version 5.5.X or higher
* where set_ap_radiosettings() throws an error * where set_ap_radiosettings() throws an error
*/ */
/** /**
* using the composer autoloader * using the composer autoloader
*/ */
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 file for an example * see the config.template.php file for an example
*/ */
require_once('config.php'); require_once 'config.php';
/** /**
* the site to use to log in to the controller * the site to use to log in to the controller

View File

@@ -13,13 +13,13 @@
/** /**
* using the composer autoloader * using the composer autoloader
*/ */
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 file for an example * see the config.template.php file for an example
*/ */
require_once('config.php'); require_once 'config.php';
/** /**
* the site to use to log in to the controller * the site to use to log in to the controller

File diff suppressed because it is too large Load Diff