json_api.php 7.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243
  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']) && isset($_GET['object'])) {
  6. $action = filter_input(INPUT_GET, 'action', FILTER_SANITIZE_STRING);
  7. $object = filter_input(INPUT_GET, 'object', FILTER_SANITIZE_STRING);
  8. switch ($action) {
  9. case "domain":
  10. switch ($object) {
  11. case "all":
  12. $domains = mailbox_get_domains();
  13. if (!empty($domains)) {
  14. foreach ($domains as $domain) {
  15. $data[] = mailbox_get_domain_details($domain);
  16. }
  17. if (!isset($data) || empty($data)) {
  18. echo '{}';
  19. }
  20. else {
  21. echo json_encode($data, JSON_UNESCAPED_UNICODE | JSON_PRETTY_PRINT);
  22. }
  23. }
  24. else {
  25. echo '{}';
  26. }
  27. break;
  28. default:
  29. $data = mailbox_get_domain_details($object);
  30. if (!isset($data) || empty($data)) {
  31. echo '{}';
  32. }
  33. else {
  34. echo json_encode(mailbox_get_domain_details($object), JSON_UNESCAPED_UNICODE | JSON_PRETTY_PRINT);
  35. }
  36. break;
  37. }
  38. break;
  39. case "mailbox":
  40. switch ($object) {
  41. case "all":
  42. $domains = mailbox_get_domains();
  43. if (!empty($domains)) {
  44. foreach ($domains as $domain) {
  45. $mailboxes = mailbox_get_mailboxes($domain);
  46. if (!empty($mailboxes)) {
  47. foreach ($mailboxes as $mailbox) {
  48. $data[] = mailbox_get_mailbox_details($mailbox);
  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. else {
  60. echo '{}';
  61. }
  62. break;
  63. default:
  64. $data = mailbox_get_mailbox_details($object);
  65. if (!isset($data) || empty($data)) {
  66. echo '{}';
  67. }
  68. else {
  69. echo json_encode(mailbox_get_mailbox_details($object), JSON_UNESCAPED_UNICODE | JSON_PRETTY_PRINT);
  70. }
  71. break;
  72. }
  73. break;
  74. case "resource":
  75. switch ($object) {
  76. case "all":
  77. $domains = mailbox_get_domains();
  78. if (!empty($domains)) {
  79. foreach ($domains as $domain) {
  80. $resources = mailbox_get_resources($domain);
  81. if (!empty($resources)) {
  82. foreach ($resources as $resource) {
  83. $data[] = mailbox_get_resource_details($resource);
  84. }
  85. }
  86. }
  87. if (!isset($data) || empty($data)) {
  88. echo '{}';
  89. }
  90. else {
  91. echo json_encode($data, JSON_UNESCAPED_UNICODE | JSON_PRETTY_PRINT);
  92. }
  93. }
  94. else {
  95. echo '{}';
  96. }
  97. break;
  98. default:
  99. $data = mailbox_get_resource_details($object);
  100. if (!isset($data) || empty($data)) {
  101. echo '{}';
  102. }
  103. else {
  104. echo json_encode(mailbox_get_resource_details($object), JSON_UNESCAPED_UNICODE | JSON_PRETTY_PRINT);
  105. }
  106. break;
  107. }
  108. break;
  109. case "alias-domain":
  110. switch ($object) {
  111. case "all":
  112. $domains = mailbox_get_domains();
  113. if (!empty($domains)) {
  114. foreach ($domains as $domain) {
  115. $alias_domains = mailbox_get_alias_domains($domain);
  116. if (!empty($alias_domains)) {
  117. foreach ($alias_domains as $alias_domain) {
  118. $data[] = mailbox_get_alias_domain_details($alias_domain);
  119. }
  120. }
  121. }
  122. if (!isset($data) || empty($data)) {
  123. echo '{}';
  124. }
  125. else {
  126. echo json_encode($data, JSON_UNESCAPED_UNICODE | JSON_PRETTY_PRINT);
  127. }
  128. }
  129. else {
  130. echo '{}';
  131. }
  132. break;
  133. default:
  134. $data = mailbox_get_alias_domains($object);
  135. if (!isset($data) || empty($data)) {
  136. echo '{}';
  137. }
  138. else {
  139. echo json_encode(mailbox_get_alias_domains($object), JSON_UNESCAPED_UNICODE | JSON_PRETTY_PRINT);
  140. }
  141. break;
  142. }
  143. break;
  144. case "alias":
  145. switch ($object) {
  146. case "all":
  147. $domains = array_merge(mailbox_get_domains(), mailbox_get_alias_domains());
  148. if (!empty($domains)) {
  149. foreach ($domains as $domain) {
  150. $aliases = mailbox_get_aliases($domain);
  151. if (!empty($aliases)) {
  152. foreach ($aliases as $alias) {
  153. $data[] = mailbox_get_alias_details($alias);
  154. }
  155. }
  156. }
  157. if (!isset($data) || empty($data)) {
  158. echo '{}';
  159. }
  160. else {
  161. echo json_encode($data, JSON_UNESCAPED_UNICODE | JSON_PRETTY_PRINT);
  162. }
  163. }
  164. else {
  165. echo '{}';
  166. }
  167. break;
  168. default:
  169. $data = mailbox_get_alias_details($object);
  170. if (!isset($data) || empty($data)) {
  171. echo '{}';
  172. }
  173. else {
  174. echo json_encode(mailbox_get_alias_details($object), JSON_UNESCAPED_UNICODE | JSON_PRETTY_PRINT);
  175. }
  176. break;
  177. }
  178. break;
  179. case "domain-admin":
  180. switch ($object) {
  181. case "all":
  182. $domain_admins = get_domain_admins();
  183. if (!empty($domain_admins)) {
  184. foreach ($domain_admins as $domain_admin) {
  185. $data[] = get_domain_admin_details($domain_admin);
  186. }
  187. if (!isset($data) || empty($data)) {
  188. echo '{}';
  189. }
  190. else {
  191. echo json_encode($data, JSON_UNESCAPED_UNICODE | JSON_PRETTY_PRINT);
  192. }
  193. }
  194. else {
  195. echo '{}';
  196. }
  197. break;
  198. default:
  199. $data = get_domain_admin_details($object);
  200. if (!isset($data) || empty($data)) {
  201. echo '{}';
  202. }
  203. else {
  204. echo json_encode(get_domain_admin_details($object), JSON_UNESCAPED_UNICODE | JSON_PRETTY_PRINT);
  205. }
  206. break;
  207. }
  208. break;
  209. case "u2f-registration":
  210. if (($_SESSION["mailcow_cc_role"] == "admin" || $_SESSION["mailcow_cc_role"] == "domainadmin") && $_SESSION["mailcow_cc_username"] == $object) {
  211. $data = $u2f->getRegisterData(get_u2f_registrations($object));
  212. list($req, $sigs) = $data;
  213. $_SESSION['regReq'] = json_encode($req);
  214. echo 'var req = ' . json_encode($req) . '; var sigs = ' . json_encode($sigs) . ';';
  215. }
  216. else {
  217. return;
  218. }
  219. break;
  220. case "u2f-authentication":
  221. if (isset($_SESSION['pending_mailcow_cc_username']) && $_SESSION['pending_mailcow_cc_username'] == $object) {
  222. $reqs = json_encode($u2f->getAuthenticateData(get_u2f_registrations($object)));
  223. $_SESSION['authReq'] = $reqs;
  224. echo 'var req = ' . $reqs . ';';
  225. }
  226. else {
  227. return;
  228. }
  229. break;
  230. default:
  231. echo '{}';
  232. break;
  233. }
  234. }
  235. }