index.php 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224
  1. <?php
  2. // Init
  3. error_reporting(NULL);
  4. ob_start();
  5. session_start();
  6. $TAB = 'DNS';
  7. include($_SERVER['DOCUMENT_ROOT']."/inc/main.php");
  8. // Check domain name
  9. if (empty($_GET['domain'])) {
  10. header("Location: /list/dns/");
  11. exit;
  12. }
  13. // Edit as someone else?
  14. if (($_SESSION['user'] == 'admin') && (!empty($_GET['user']))) {
  15. $user=escapeshellarg($_GET['user']);
  16. }
  17. // List dns domain
  18. if ((!empty($_GET['domain'])) && (empty($_GET['record_id']))) {
  19. $v_domain = escapeshellarg($_GET['domain']);
  20. exec (VESTA_CMD."v-list-dns-domain ".$user." ".$v_domain." json", $output, $return_var);
  21. check_return_code($return_var,$output);
  22. $data = json_decode(implode('', $output), true);
  23. unset($output);
  24. // Parse dns domain
  25. $v_username = $user;
  26. $v_domain = $_GET['domain'];
  27. $v_ip = $data[$v_domain]['IP'];
  28. $v_template = $data[$v_domain]['TPL'];
  29. $v_ttl = $data[$v_domain]['TTL'];
  30. $v_exp = $data[$v_domain]['EXP'];
  31. $v_soa = $data[$v_domain]['SOA'];
  32. $v_date = $data[$v_domain]['DATE'];
  33. $v_time = $data[$v_domain]['TIME'];
  34. $v_suspended = $data[$v_domain]['SUSPENDED'];
  35. if ( $v_suspended == 'yes' ) {
  36. $v_status = 'suspended';
  37. } else {
  38. $v_status = 'active';
  39. }
  40. // List dns templates
  41. exec (VESTA_CMD."v-list-dns-templates json", $output, $return_var);
  42. $templates = json_decode(implode('', $output), true);
  43. unset($output);
  44. }
  45. // List dns record
  46. if ((!empty($_GET['domain'])) && (!empty($_GET['record_id']))) {
  47. $v_domain = escapeshellarg($_GET['domain']);
  48. $v_record_id = escapeshellarg($_GET['record_id']);
  49. exec (VESTA_CMD."v-list-dns-records ".$user." ".$v_domain." 'json'", $output, $return_var);
  50. check_return_code($return_var,$output);
  51. $data = json_decode(implode('', $output), true);
  52. unset($output);
  53. // Parse dns record
  54. $v_username = $user;
  55. $v_domain = $_GET['domain'];
  56. $v_record_id = $_GET['record_id'];
  57. $v_rec = $data[$v_record_id]['RECORD'];
  58. $v_type = $data[$v_record_id]['TYPE'];
  59. $v_val = $data[$v_record_id]['VALUE'];
  60. $v_priority = $data[$v_record_id]['PRIORITY'];
  61. $v_suspended = $data[$v_record_id]['SUSPENDED'];
  62. if ( $v_suspended == 'yes' ) {
  63. $v_status = 'suspended';
  64. } else {
  65. $v_status = 'active';
  66. }
  67. $v_date = $data[$v_record_id]['DATE'];
  68. $v_time = $data[$v_record_id]['TIME'];
  69. }
  70. // Check POST request for dns domain
  71. if ((!empty($_POST['save'])) && (!empty($_GET['domain'])) && (empty($_GET['record_id']))) {
  72. $v_domain = escapeshellarg($_POST['v_domain']);
  73. // Check token
  74. if ((!isset($_POST['token'])) || ($_SESSION['token'] != $_POST['token'])) {
  75. header('location: /login/');
  76. exit();
  77. }
  78. // Change domain IP
  79. if (($v_ip != $_POST['v_ip']) && (empty($_SESSION['error_msg']))) {
  80. $v_ip = escapeshellarg($_POST['v_ip']);
  81. exec (VESTA_CMD."v-change-dns-domain-ip ".$v_username." ".$v_domain." ".$v_ip." 'no'", $output, $return_var);
  82. check_return_code($return_var,$output);
  83. $restart_dns = 'yes';
  84. unset($output);
  85. }
  86. // Change domain template
  87. if (($v_template != $_POST['v_template']) && (empty($_SESSION['error_msg']))) {
  88. $v_template = escapeshellarg($_POST['v_template']);
  89. exec (VESTA_CMD."v-change-dns-domain-tpl ".$v_username." ".$v_domain." ".$v_template." 'no'", $output, $return_var);
  90. check_return_code($return_var,$output);
  91. unset($output);
  92. $restart_dns = 'yes';
  93. }
  94. // Change SOA record
  95. if (($v_soa != $_POST['v_soa']) && (empty($_SESSION['error_msg']))) {
  96. $v_soa = escapeshellarg($_POST['v_soa']);
  97. exec (VESTA_CMD."v-change-dns-domain-soa ".$v_username." ".$v_domain." ".$v_soa." 'no'", $output, $return_var);
  98. check_return_code($return_var,$output);
  99. unset($output);
  100. $restart_dns = 'yes';
  101. }
  102. // Change expiriation date
  103. if (($v_exp != $_POST['v_exp']) && (empty($_SESSION['error_msg']))) {
  104. $v_exp = escapeshellarg($_POST['v_exp']);
  105. exec (VESTA_CMD."v-change-dns-domain-exp ".$v_username." ".$v_domain." ".$v_exp." 'no'", $output, $return_var);
  106. check_return_code($return_var,$output);
  107. unset($output);
  108. }
  109. // Change domain ttl
  110. if (($v_ttl != $_POST['v_ttl']) && (empty($_SESSION['error_msg']))) {
  111. $v_ttl = escapeshellarg($_POST['v_ttl']);
  112. exec (VESTA_CMD."v-change-dns-domain-ttl ".$v_username." ".$v_domain." ".$v_ttl." 'no'", $output, $return_var);
  113. check_return_code($return_var,$output);
  114. unset($output);
  115. $restart_dns = 'yes';
  116. }
  117. // Restart dns server
  118. if (!empty($restart_dns) && (empty($_SESSION['error_msg']))) {
  119. exec (VESTA_CMD."v-restart-dns", $output, $return_var);
  120. check_return_code($return_var,$output);
  121. unset($output);
  122. }
  123. // Set success message
  124. if (empty($_SESSION['error_msg'])) {
  125. $_SESSION['ok_msg'] = __('Changes has been saved.');
  126. }
  127. }
  128. // Check POST request for dns record
  129. if ((!empty($_POST['save'])) && (!empty($_GET['domain'])) && (!empty($_GET['record_id']))) {
  130. // Check token
  131. if ((!isset($_POST['token'])) || ($_SESSION['token'] != $_POST['token'])) {
  132. header('location: /login/');
  133. exit();
  134. }
  135. // Protect input
  136. $v_domain = escapeshellarg($_POST['v_domain']);
  137. $v_record_id = escapeshellarg($_POST['v_record_id']);
  138. // Change dns record
  139. if (($v_val != $_POST['v_val']) || ($v_priority != $_POST['v_priority']) && (empty($_SESSION['error_msg']))) {
  140. $v_val = escapeshellarg($_POST['v_val']);
  141. $v_priority = escapeshellarg($_POST['v_priority']);
  142. exec (VESTA_CMD."v-change-dns-record ".$v_username." ".$v_domain." ".$v_record_id." ".$v_val." ".$v_priority, $output, $return_var);
  143. check_return_code($return_var,$output);
  144. $v_val = $_POST['v_val'];
  145. unset($output);
  146. $restart_dns = 'yes';
  147. }
  148. // Change dns record id
  149. if (($_GET['record_id'] != $_POST['v_record_id']) && (empty($_SESSION['error_msg']))) {
  150. $v_old_record_id = escapeshellarg($_GET['record_id']);
  151. exec (VESTA_CMD."v-change-dns-record-id ".$v_username." ".$v_domain." ".$v_old_record_id." ".$v_record_id, $output, $return_var);
  152. check_return_code($return_var,$output);
  153. unset($output);
  154. $restart_dns = 'yes';
  155. }
  156. // Restart dns server
  157. if (!empty($restart_dns) && (empty($_SESSION['error_msg']))) {
  158. exec (VESTA_CMD."v-restart-dns", $output, $return_var);
  159. check_return_code($return_var,$output);
  160. unset($output);
  161. }
  162. // Set success message
  163. if (empty($_SESSION['error_msg'])) {
  164. $_SESSION['ok_msg'] = __('Changes has been saved.');
  165. }
  166. // Change url if record id was changed
  167. if ((empty($_SESSION['error_msg'])) && ($_GET['record_id'] != $_POST['v_record_id'])) {
  168. header("Location: /edit/dns/?domain=".$_GET['domain']."&record_id=".$_POST['v_record_id']);
  169. exit;
  170. }
  171. }
  172. // Header
  173. include($_SERVER['DOCUMENT_ROOT'].'/templates/header.html');
  174. // Panel
  175. top_panel($user,$TAB);
  176. // Display body for dns domain
  177. if ((!empty($_GET['domain'])) && (empty($_GET['record_id']))) {
  178. if ($_SESSION['user'] == 'admin') {
  179. include($_SERVER['DOCUMENT_ROOT'].'/templates/admin/edit_dns.html');
  180. } else {
  181. include($_SERVER['DOCUMENT_ROOT'].'/templates/user/edit_dns.html');
  182. }
  183. }
  184. // List dns record
  185. if ((!empty($_GET['domain'])) && (!empty($_GET['record_id']))) {
  186. // Display body for dns record
  187. include($_SERVER['DOCUMENT_ROOT'].'/templates/admin/edit_dns_rec.html');
  188. }
  189. // Flush session messages
  190. unset($_SESSION['error_msg']);
  191. unset($_SESSION['ok_msg']);
  192. // Footer
  193. include($_SERVER['DOCUMENT_ROOT'].'/templates/footer.html');