unifi.php 9.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261
  1. <?php
  2. trait UnifiHomepageItem
  3. {
  4. public function unifiSettingsArray($infoOnly = false)
  5. {
  6. $homepageInformation = [
  7. 'name' => 'UniFi',
  8. 'enabled' => true,
  9. 'image' => 'plugins/images/tabs/unifi.png',
  10. 'category' => 'Monitor',
  11. 'settingsArray' => __FUNCTION__
  12. ];
  13. if ($infoOnly) {
  14. return $homepageInformation;
  15. }
  16. $homepageSettings = [
  17. 'debug' => true,
  18. 'settings' => [
  19. 'Enable' => [
  20. $this->settingsOption('enable', 'homepageUnifiEnabled'),
  21. $this->settingsOption('auth', 'homepageUnifiAuth'),
  22. ],
  23. 'Connection' => [
  24. $this->settingsOption('url', 'unifiURL'),
  25. $this->settingsOption('blank'),
  26. $this->settingsOption('disable-cert-check', 'unifiDisableCertCheck'),
  27. $this->settingsOption('use-custom-certificate', 'unifiUseCustomCertificate'),
  28. $this->settingsOption('username', 'unifiUsername', ['help' => 'Username is case-sensitive']),
  29. $this->settingsOption('password', 'unifiPassword'),
  30. $this->settingsOption('input', 'unifiSiteName', ['label' => 'Site Name (Not for UnifiOS)', 'help' => 'Site Name - not Site ID nor Site Description']),
  31. $this->settingsOption('button', '', ['label' => 'Grab Unifi Site (Not for UnifiOS)', 'icon' => 'fa fa-building', 'text' => 'Get Unifi Site', 'attr' => 'onclick="getUnifiSite()"']),
  32. ],
  33. 'Misc Options' => [
  34. $this->settingsOption('refresh', 'homepageUnifiRefresh'),
  35. ],
  36. 'Test Connection' => [
  37. $this->settingsOption('blank', null, ['label' => 'Please Save before Testing']),
  38. $this->settingsOption('test', 'unifi'),
  39. ]
  40. ]
  41. ];
  42. return array_merge($homepageInformation, $homepageSettings);
  43. }
  44. public function unifiHomepagePermissions($key = null)
  45. {
  46. $permissions = [
  47. 'main' => [
  48. 'enabled' => [
  49. 'homepageUnifiEnabled'
  50. ],
  51. 'auth' => [
  52. 'homepageUnifiAuth'
  53. ],
  54. 'not_empty' => [
  55. 'unifiURL',
  56. 'unifiUsername',
  57. 'unifiPassword'
  58. ]
  59. ]
  60. ];
  61. if (array_key_exists($key, $permissions)) {
  62. return $permissions[$key];
  63. } elseif ($key == 'all') {
  64. return $permissions;
  65. } else {
  66. return [];
  67. }
  68. }
  69. public function homepageOrderunifi()
  70. {
  71. if ($this->homepageItemPermissions($this->unifiHomepagePermissions('main'))) {
  72. return '
  73. <div id="' . __FUNCTION__ . '">
  74. <div class="white-box homepage-loading-box"><h2 class="text-center" lang="en">Loading Unifi...</h2></div>
  75. <script>
  76. // Unifi
  77. homepageUnifi("' . $this->config['homepageHealthChecksRefresh'] . '");
  78. // End Unifi
  79. </script>
  80. </div>
  81. ';
  82. }
  83. }
  84. public function getUnifiSiteName()
  85. {
  86. if (empty($this->config['unifiURL'])) {
  87. $this->setAPIResponse('error', 'Unifi URL is not defined', 422);
  88. return false;
  89. }
  90. if (empty($this->config['unifiUsername'])) {
  91. $this->setAPIResponse('error', 'Unifi Username is not defined', 422);
  92. return false;
  93. }
  94. if (empty($this->config['unifiPassword'])) {
  95. $this->setAPIResponse('error', 'Unifi Password is not defined', 422);
  96. return false;
  97. }
  98. $url = $this->qualifyURL($this->config['unifiURL']);
  99. try {
  100. $options = $this->requestOptions($url, $this->config['homepageUnifiRefresh'], $this->config['unifiDisableCertCheck'], $this->config['unifiUseCustomCertificate'], ['follow_redirects' => true]);
  101. $data = array(
  102. 'username' => $this->config['unifiUsername'],
  103. 'password' => $this->decrypt($this->config['unifiPassword']),
  104. 'remember' => true,
  105. 'strict' => true
  106. );
  107. $response = Requests::post($url . '/api/login', array(), json_encode($data), $options);
  108. if ($response->success) {
  109. $cookie['unifises'] = ($response->cookies['unifises']->value) ?? false;
  110. $cookie['csrf_token'] = ($response->cookies['csrf_token']->value) ?? false;
  111. } else {
  112. $this->setAPIResponse('error', 'Unifi response error - Check Credentials', 409);
  113. return false;
  114. }
  115. $headers = array(
  116. 'cookie' => 'unifises=' . $cookie['unifises'] . ';' . 'csrf_token=' . $cookie['csrf_token'] . ';'
  117. );
  118. $response = Requests::get($url . '/api/self/sites', $headers, $options);
  119. if ($response->success) {
  120. $body = json_decode($response->body, true);
  121. $this->setAPIResponse('success', null, 200, $body);
  122. return $body;
  123. } else {
  124. $this->setAPIResponse('error', 'Unifi response error - Error Occurred', 409);
  125. return false;
  126. }
  127. } catch (Requests_Exception $e) {
  128. $this->writeLog('error', 'Unifi Connect Function - Error: ' . $e->getMessage(), 'SYSTEM');
  129. $this->setAPIResponse('error', $e->getMessage(), 500);
  130. return false;
  131. }
  132. }
  133. public function testConnectionUnifi()
  134. {
  135. if (empty($this->config['unifiURL'])) {
  136. $this->setAPIResponse('error', 'Unifi URL is not defined', 422);
  137. return false;
  138. }
  139. if (empty($this->config['unifiUsername'])) {
  140. $this->setAPIResponse('error', 'Unifi Username is not defined', 422);
  141. return false;
  142. }
  143. if (empty($this->config['unifiPassword'])) {
  144. $this->setAPIResponse('error', 'Unifi Password is not defined', 422);
  145. return false;
  146. }
  147. $api['content']['unifi'] = array();
  148. $url = $this->qualifyURL($this->config['unifiURL']);
  149. $options = $this->requestOptions($url, $this->config['homepageUnifiRefresh'], $this->config['unifiDisableCertCheck'], $this->config['unifiUseCustomCertificate'], ['follow_redirects' => true]);
  150. $data = array(
  151. 'username' => $this->config['unifiUsername'],
  152. 'password' => $this->decrypt($this->config['unifiPassword']),
  153. 'remember' => true,
  154. 'strict' => true
  155. );
  156. try {
  157. // Is this UnifiOs or Regular
  158. $response = Requests::get($url, [], $options);
  159. if ($response->success) {
  160. $csrfToken = ($response->headers['x-csrf-token']) ?? false;
  161. $data = ($csrfToken) ? $data : json_encode($data);
  162. } else {
  163. $this->setAPIResponse('error', 'Unifi response error - Check URL', 409);
  164. return false;
  165. }
  166. $urlLogin = ($csrfToken) ? $url . '/api/auth/login' : $url . '/api/login';
  167. $urlStat = ($csrfToken) ? $url . '/proxy/network/api/s/default/stat/health' : $url . '/api/s/' . $this->config['unifiSiteName'] . '/stat/health';
  168. $response = Requests::post($urlLogin, [], $data, $options);
  169. if ($response->success) {
  170. $cookie['unifises'] = ($response->cookies['unifises']->value) ?? false;
  171. $cookie['csrf_token'] = ($response->cookies['csrf_token']->value) ?? false;
  172. $cookie['Token'] = ($response->cookies['Token']->value) ?? false;
  173. $options['cookies'] = $response->cookies;
  174. } else {
  175. $this->setAPIResponse('error', 'Unifi response error - Check Credentials', 409);
  176. return false;
  177. }
  178. $headers = array(
  179. 'cookie' => 'unifises=' . $cookie['unifises'] . ';' . 'csrf_token=' . $cookie['csrf_token'] . ';'
  180. );
  181. $response = Requests::get($urlStat, $headers, $options);
  182. if ($response->success) {
  183. $api['content']['unifi'] = json_decode($response->body, true);
  184. } else {
  185. $this->setAPIResponse('error', 'Unifi response error3', 409);
  186. return false;
  187. }
  188. } catch (Requests_Exception $e) {
  189. $this->writeLog('error', 'Unifi Connect Function - Error: ' . $e->getMessage(), 'SYSTEM');
  190. $this->setAPIResponse('error', $e->getMessage(), 500);
  191. return false;
  192. };
  193. $api['content']['unifi'] = isset($api['content']['unifi']) ? $api['content']['unifi'] : false;
  194. $this->setAPIResponse('success', 'API Connection succeeded', 200);
  195. return true;
  196. }
  197. public function getUnifiHomepageData()
  198. {
  199. if (!$this->homepageItemPermissions($this->unifiHomepagePermissions('main'), true)) {
  200. return false;
  201. }
  202. $api['content']['unifi'] = array();
  203. $url = $this->qualifyURL($this->config['unifiURL']);
  204. $options = $this->requestOptions($url, $this->config['homepageUnifiRefresh'], $this->config['unifiDisableCertCheck'], $this->config['unifiUseCustomCertificate'], ['follow_redirects' => true]);
  205. $data = array(
  206. 'username' => $this->config['unifiUsername'],
  207. 'password' => $this->decrypt($this->config['unifiPassword']),
  208. 'remember' => true,
  209. 'strict' => true
  210. );
  211. try {
  212. // Is this UnifiOs or Regular
  213. $response = Requests::get($url, [], $options);
  214. if ($response->success) {
  215. $csrfToken = ($response->headers['x-csrf-token']) ?? false;
  216. $data = ($csrfToken) ? $data : json_encode($data);
  217. } else {
  218. $this->setAPIResponse('error', 'Unifi response error - Check URL', 409);
  219. return false;
  220. }
  221. $urlLogin = ($csrfToken) ? $url . '/api/auth/login' : $url . '/api/login';
  222. $urlStat = ($csrfToken) ? $url . '/proxy/network/api/s/default/stat/health' : $url . '/api/s/' . $this->config['unifiSiteName'] . '/stat/health';
  223. $response = Requests::post($urlLogin, [], $data, $options);
  224. if ($response->success) {
  225. $cookie['unifises'] = ($response->cookies['unifises']->value) ?? false;
  226. $cookie['csrf_token'] = ($response->cookies['csrf_token']->value) ?? false;
  227. $cookie['Token'] = ($response->cookies['Token']->value) ?? false;
  228. $options['cookies'] = $response->cookies;
  229. } else {
  230. $this->setAPIResponse('error', 'Unifi response error - Check Credentials', 409);
  231. return false;
  232. }
  233. $headers = array(
  234. 'cookie' => 'unifises=' . $cookie['unifises'] . ';' . 'csrf_token=' . $cookie['csrf_token'] . ';'
  235. );
  236. $response = Requests::get($urlStat, $headers, $options);
  237. if ($response->success) {
  238. $api['content']['unifi'] = json_decode($response->body, true);
  239. } else {
  240. $this->setAPIResponse('error', 'Unifi response error3', 409);
  241. return false;
  242. }
  243. } catch (Requests_Exception $e) {
  244. $this->writeLog('error', 'Unifi Connect Function - Error: ' . $e->getMessage(), 'SYSTEM');
  245. $this->setAPIResponse('error', $e->getMessage(), 500);
  246. return false;
  247. };
  248. $api['content']['unifi'] = isset($api['content']['unifi']) ? $api['content']['unifi'] : false;
  249. $this->setAPIResponse('success', null, 200, $api);
  250. return $api;
  251. }
  252. }