index.php 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  1. <?php
  2. use function Hestiacp\quoteshellarg\quoteshellarg;
  3. $TAB = 'Access Key';
  4. // Main include
  5. include($_SERVER['DOCUMENT_ROOT']."/inc/main.php");
  6. if (($_SESSION['userContext'] === 'admin') && (!empty($_GET['user']))) {
  7. $user = quoteshellarg($_GET['user']);
  8. $user_plain = $_GET['user'];
  9. }
  10. // Checks if API access is enabled
  11. $api_status = (!empty($_SESSION['API_SYSTEM']) && is_numeric($_SESSION['API_SYSTEM'])) ? $_SESSION['API_SYSTEM'] : 0;
  12. if (($user_plain == 'admin' && $api_status < 1) || ($user_plain != 'admin' && $api_status < 2)) {
  13. header("Location: /edit/user/");
  14. exit;
  15. }
  16. if (!empty($_GET['key'])) {
  17. $v_key = quoteshellarg(trim($_GET['key']));
  18. // Key data
  19. exec(HESTIA_CMD."v-list-access-key ".$v_key." json", $output, $return_var);
  20. $key_data = json_decode(implode('', $output), true);
  21. unset($output);
  22. if (empty($key_data) || $key_data['USER'] != $user_plain) {
  23. header("Location: /list/access-key/");
  24. exit;
  25. }
  26. // APIs
  27. exec(HESTIA_CMD."v-list-apis json", $output, $return_var);
  28. $apis = json_decode(implode('', $output), true);
  29. $apis = array_filter($apis, function ($api) use ($user_plain) {
  30. return ($user_plain == 'admin' || $api['ROLE'] == 'user');
  31. });
  32. ksort($apis);
  33. unset($output);
  34. render_page($user, $TAB, 'list_access_key');
  35. } else {
  36. exec(HESTIA_CMD."v-list-access-keys $user json", $output, $return_var);
  37. $data = json_decode(implode('', $output), true);
  38. uasort($data, function ($a, $b) {
  39. return $a['DATE'] <=> $b['DATE'] ?: $a['TIME'] <=> $b['TIME'];
  40. });
  41. unset($output);
  42. // Render page
  43. render_page($user, $TAB, 'list_access_keys');
  44. }
  45. // Back uri
  46. $_SESSION['back'] = $_SERVER['REQUEST_URI'];