json_api.php 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154
  1. <?php
  2. require_once 'inc/prerequisites.inc.php';
  3. error_reporting(E_ALL);
  4. if (isset($_SESSION['mailcow_cc_role']) || isset($_SESSION['pending_mailcow_cc_username'])) {
  5. if (isset($_GET['action'])) {
  6. $action = $_GET['action'];
  7. switch ($action) {
  8. case "domain_table_data":
  9. $domains = mailbox_get_domains();
  10. if (!empty($domains)) {
  11. foreach ($domains as $domain) {
  12. $data[] = mailbox_get_domain_details($domain);
  13. }
  14. if (!isset($data) || empty($data)) {
  15. echo '{}';
  16. }
  17. else {
  18. echo json_encode($data, JSON_UNESCAPED_UNICODE | JSON_PRETTY_PRINT);
  19. }
  20. }
  21. break;
  22. case "mailbox_table_data":
  23. $domains = mailbox_get_domains();
  24. if (!empty($domains)) {
  25. foreach ($domains as $domain) {
  26. $mailboxes = mailbox_get_mailboxes($domain);
  27. if (!empty($mailboxes)) {
  28. foreach ($mailboxes as $mailbox) {
  29. $data[] = mailbox_get_mailbox_details($mailbox);
  30. }
  31. }
  32. }
  33. if (!isset($data) || empty($data)) {
  34. echo '{}';
  35. }
  36. else {
  37. echo json_encode($data, JSON_UNESCAPED_UNICODE | JSON_PRETTY_PRINT);
  38. }
  39. }
  40. break;
  41. case "resource_table_data":
  42. $domains = mailbox_get_domains();
  43. if (!empty($domains)) {
  44. foreach ($domains as $domain) {
  45. $resources = mailbox_get_resources($domain);
  46. if (!empty($resources)) {
  47. foreach ($resources as $resource) {
  48. $data[] = mailbox_get_resource_details($resource);
  49. }
  50. }
  51. }
  52. if (!isset($data) || empty($data)) {
  53. echo '{}';
  54. }
  55. else {
  56. echo json_encode($data, JSON_UNESCAPED_UNICODE | JSON_PRETTY_PRINT);
  57. }
  58. }
  59. break;
  60. case "domain_alias_table_data":
  61. $domains = mailbox_get_domains();
  62. if (!empty($domains)) {
  63. foreach ($domains as $domain) {
  64. $alias_domains = mailbox_get_alias_domains($domain);
  65. if (!empty($alias_domains)) {
  66. foreach ($alias_domains as $alias_domain) {
  67. $data[] = mailbox_get_alias_domain_details($alias_domain);
  68. }
  69. }
  70. }
  71. if (!isset($data) || empty($data)) {
  72. echo '{}';
  73. }
  74. else {
  75. echo json_encode($data, JSON_UNESCAPED_UNICODE | JSON_PRETTY_PRINT);
  76. }
  77. }
  78. break;
  79. case "alias_table_data":
  80. $domains = array_merge(mailbox_get_domains(), mailbox_get_alias_domains());
  81. if (!empty($domains)) {
  82. foreach ($domains as $domain) {
  83. $aliases = mailbox_get_aliases($domain);
  84. if (!empty($aliases)) {
  85. foreach ($aliases as $alias) {
  86. $data[] = mailbox_get_alias_details($alias);
  87. }
  88. }
  89. }
  90. if (!isset($data) || empty($data)) {
  91. echo '{}';
  92. }
  93. else {
  94. echo json_encode($data, JSON_UNESCAPED_UNICODE | JSON_PRETTY_PRINT);
  95. }
  96. }
  97. break;
  98. case "get_mailbox_details":
  99. if (!isset($_GET['object'])) { return false; }
  100. $object = $_GET['object'];
  101. $data = mailbox_get_mailbox_details($object);
  102. if (!isset($data) || empty($data)) {
  103. echo '{}';
  104. }
  105. else {
  106. echo json_encode(mailbox_get_mailbox_details($object), JSON_UNESCAPED_UNICODE | JSON_PRETTY_PRINT);
  107. }
  108. break;
  109. case "get_domain_details":
  110. if (!isset($_GET['object'])) { return false; }
  111. $object = $_GET['object'];
  112. $data = mailbox_get_domain_details($object);
  113. if (!isset($data) || empty($data)) {
  114. echo '{}';
  115. }
  116. else {
  117. echo json_encode(mailbox_get_domain_details($object), JSON_UNESCAPED_UNICODE | JSON_PRETTY_PRINT);
  118. }
  119. break;
  120. case "get_u2f_reg_challenge":
  121. if (!isset($_GET['object'])) { return false; }
  122. $object = $_GET['object'];
  123. if (
  124. ($_SESSION["mailcow_cc_role"] == "admin" || $_SESSION["mailcow_cc_role"] == "domainadmin")
  125. &&
  126. ($_SESSION["mailcow_cc_username"] == $object)
  127. ) {
  128. $data = $u2f->getRegisterData(get_u2f_registrations($object));
  129. list($req, $sigs) = $data;
  130. $_SESSION['regReq'] = json_encode($req);
  131. echo 'var req = ' . json_encode($req) . '; var sigs = ' . json_encode($sigs) . ';';
  132. }
  133. else {
  134. echo '{}';
  135. }
  136. break;
  137. case "get_u2f_auth_challenge":
  138. if (!isset($_GET['object'])) { return false; }
  139. $object = $_GET['object'];
  140. if (isset($_SESSION['pending_mailcow_cc_username']) && $_SESSION['pending_mailcow_cc_username'] == $object) {
  141. $reqs = json_encode($u2f->getAuthenticateData(get_u2f_registrations($object)));
  142. $_SESSION['authReq'] = $reqs;
  143. echo 'var req = ' . $reqs . ';';
  144. }
  145. else {
  146. echo '{}';
  147. }
  148. break;
  149. default:
  150. echo '{}';
  151. break;
  152. }
  153. }
  154. }