WEB_DOMAIN.class.php 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397
  1. <?php
  2. /**
  3. * DOMAIN
  4. *
  5. * @author vesta, http://vestacp.com/
  6. * @author Dmitry Malishev <dima.malishev@gmail.com>
  7. * @author Dmitry Naumov-Socolov <naumov.socolov@gmail.com>
  8. * @copyright vesta 2010-2011
  9. */
  10. class WEB_DOMAIN extends AjaxHandler
  11. {
  12. public function getListExecute(Request $request)
  13. {
  14. $user = $this->getLoggedUser();
  15. $reply = array();
  16. $result = Vesta::execute(Vesta::V_LIST_WEB_DOMAINS, array($user['uid'], Config::get('response_type')));
  17. foreach($result['data'] as $web_domain => $data)
  18. {
  19. $reply[$web_domain] = array(
  20. 'IP' => $record['IP'],
  21. 'U_DISK' => $record['U_DISK'],
  22. 'U_BANDWIDTH' => $record['U_BANDWIDTH'],
  23. 'TPL' => $record['TPL'],
  24. 'ALIAS' => $record['ALIAS'],
  25. 'PHP' => $record['PHP'],
  26. 'CGI' => $record['CGI'],
  27. 'ELOG' => $record['ELOG'],
  28. 'STATS' => $record['STATS'],
  29. 'STATS_AUTH' => $record['STATS_AUTH'],
  30. 'SSL' => $record['SSL'],
  31. 'SSL_HOME' => $record['SSL_HOME'],
  32. 'SSL_CERT' => $record['SSL_CERT'],
  33. 'NGINX' => $record['NGINX'],
  34. 'NGINX_EXT' => $record['NGINX_EXT'],
  35. 'SUSPEND' => $record['SUSPEND'],
  36. 'DATE' => date(Config::get('ui_date_format', strtotime($record['DATE'])))
  37. );
  38. }
  39. if (!$result['status']) {
  40. $this->errors[] = array($result['error_code'] => $result['error_message']);
  41. }
  42. return $this->reply($result['status'], $reply);
  43. }
  44. public function addExecute(Request $request)
  45. {
  46. $_s = $request->getParameter('spell');
  47. $user = $this->getLoggedUser();
  48. $params = array(
  49. 'USER' => $user['uid'],
  50. 'DOMAIN' => $_s['DOMAIN'],
  51. 'IP' => $_s['IP']
  52. );
  53. $result = Vesta::execute(Vesta::V_ADD_WEB_DOMAIN, $params);
  54. if (!$result['status']) {
  55. $this->errors[] = array($result['error_code'] => $result['error_message']);
  56. }
  57. if ($_s['TPL']) {
  58. $params = array(
  59. 'USER' => $user['uid'],
  60. 'DOMAIN' => $_s['DOMAIN'],
  61. 'TPL' => $_s['TPL']
  62. );
  63. $result = 0;
  64. $result = Vesta::execute(Vesta::V_CHANGE_WEB_DOMAIN_TPL, $params);
  65. if (!$result['status']) {
  66. $this->errors['CHANGE_TPL'] = array($result['error_code'] => $result['error_message']);
  67. }
  68. }
  69. if ($_s['ALIAS']) {
  70. $alias_arr = explode(',', $_s['ALIAS']);
  71. foreach ($alias_arr as $alias) {
  72. $params = array(
  73. 'USER' => $user['uid'],
  74. 'DOMAIN' => $_s['DOMAIN'],
  75. 'ALIAS' => trim($alias)
  76. );
  77. $result = 0;
  78. $result = Vesta::execute(Vesta::V_ADD_WEB_DOMAIN_ALIAS, $params);
  79. if (!$result['status']) {
  80. $this->errors['ALIAS'] = array($result['error_code'] => $result['error_message']);
  81. }
  82. }
  83. }
  84. if ($_s['STAT']) {
  85. $params = array(
  86. 'USER' => $user['uid'],
  87. 'DOMAIN' => $_s['DOMAIN'],
  88. 'STAT' => $_s['STAT']);
  89. $result = 0;
  90. $result = Vesta::execute(Vesta::V_ADD_WEB_DOMAIN_STAT, $params);
  91. if (!$result['status']) {
  92. $this->errors['STATS'] = array($result['error_code'] => $result['error_message']);
  93. }
  94. }
  95. if ($_s['STAT_AUTH']) {
  96. $params = array(
  97. 'USER' => $user['uid'],
  98. 'DOMAIN' => $_s['DOMAIN'],
  99. 'STAT_USER' => $_s['STAT_USER'],
  100. 'STAT_PASSWORS' => $_s['STAT_PASSWORD']
  101. );
  102. $result = 0;
  103. $result = Vesta::execute(Vesta::V_ADD_WEB_DOMAIN_STAT_AUTH, $params);
  104. if(!$result['status'])
  105. $this->errors['STAT_AUTH'] = array($result['error_code'] => $result['error_message']);
  106. }
  107. if (0) {
  108. if ($_s['SSL']) {
  109. $params = array(
  110. 'USER' => $user[''],
  111. 'DOMAIN' => $_s['DOMAIN'],
  112. 'SSL_CERT' => $_s['SSL_CERT']
  113. );
  114. if ($_s['SSL_HOME']) {
  115. $params['SSL_HOME'] = $_s['SSL_HOME'];
  116. }
  117. if ($_s['SSL_TEXT']) {
  118. // TODO: implement
  119. }
  120. $result = 0;
  121. $result = Vesta::execute(Vesta::V_ADD_WEB_DOMAIN_SSL, $params);
  122. if (!$result['status']) {
  123. $this->errors['SSL'] = array($result['error_code'] => $result['error_message']);
  124. }
  125. }
  126. }
  127. if ($_s['CREATE_DNS_DOMAIN']) {
  128. $params = array(
  129. 'USER' => $user['uid'],
  130. 'DNS_DOMAIN' => $_s['DOMAIN'],
  131. 'IP' => $_s['IP']
  132. );
  133. require_once V_ROOT_DIR . 'api/DNS.class.php';
  134. $dns = new DNS();
  135. $result = 0;
  136. $result = $dns->addExecute($params);
  137. if (!$result['status']) {
  138. $this->errors['DNS_DOMAIN'] = array($result['error_code'] => $result['error_message']);
  139. }
  140. }
  141. /*
  142. if ($_s['CREATE_MAIL_DOMAIN']) {
  143. $params = array(
  144. 'USER' => $_user,
  145. 'MAIL_DOMAIN' => $_s['DOMAIN'],
  146. 'IP' => $_s['IP']
  147. );
  148. require_once V_ROOT_DIR . 'api/MAIL.class.php';
  149. $mail = new MAIL();
  150. $result = 0;
  151. $result = $mail->addExecute($params);
  152. if (!$result['status'])
  153. $this->errors['MAIL_DOMAIN'] = array($result['error_code'] => $result['error_message']);
  154. }
  155. */
  156. return $this->reply($result['status'], $result['data']);
  157. }
  158. public function deleteExecute(Request $request)
  159. {
  160. $_s = $request->getParameter('spell');
  161. $user = $this->getLoggedUser();
  162. $params = array(
  163. 'USER' => $user['uid'],
  164. 'DOMAIN' => $_s['DOMAIN']
  165. );
  166. $result = Vesta::execute(Vesta::V_DEL_WEB_DOMAIN, $params);
  167. if (!$result['status']) {
  168. $this->errors[] = array($result['error_code'] => $result['error_message']);
  169. }
  170. $params = array(
  171. 'USER' => $_user,
  172. 'DNS_DOMAIN' => $_s['DOMAIN']
  173. );
  174. require_once V_ROOT_DIR . 'api/DNS.class.php';
  175. $dns = new DNS();
  176. $result = $dns->delExecute($params);
  177. if (!$result['status'] && $result['error_code'] != 31) { // domain not found
  178. $this->errors['DNS'] = array($result['error_code'] => $result['error_message']);
  179. }
  180. require_once V_ROOT_DIR . 'api/DNS.class.php';
  181. $params = array(
  182. 'USER' => $user['uid'],
  183. 'MAIL_DOMAIN' => $_s['DOMAIN']
  184. );
  185. return $this->reply($result['status'], $result['data']);
  186. }
  187. public function changeExecute(Request $request)
  188. {
  189. $_s = $request->getParameter('spell');
  190. $_old = $request->getParameter('old');
  191. $_new = $request->getParameter('new');
  192. $user = $this->getLoggedUser();
  193. $_DOMAIN = $_new['DOMAIN'];
  194. if ($_old['IP'] != $_new['IP']) {
  195. $result = array();
  196. $result = Vesta::execute(Vesta::V_CHANGE_WEB_DOMAIN_IP, array('USER' => $_user, 'DOMAIN' => $_DOMAIN, 'IP' => $_new['IP']));
  197. if (!$result['status']) {
  198. $this->status = FALSE;
  199. $this->errors['IP_ADDRESS'] = array($result['error_code'] => $result['error_message']);
  200. }
  201. }
  202. if ($_old['TPL'] != $_new['TPL']) {
  203. $result = array();
  204. $result = Vesta::execute(Vesta::V_CHANGE_WEB_DOMAIN_TPL, array('USER' => $_user, 'DOMAIN' => $_DOMAIN, 'TPL' => $_new['TPL']));
  205. if (!$result['status']) {
  206. $this->status = FALSE;
  207. $this->errors['TPL'] = array($result['error_code'] => $result['error_message']);
  208. }
  209. }
  210. if ($_old['ALIAS'] != $_new['ALIAS']) {
  211. $result = array();
  212. $old_arr = explode(',', $_old['ALIAS']);
  213. $new_arr = explode(',', $_new['ALIAS']);
  214. $added = array_diff($new_arr, $old_arr);
  215. $deleted = array_diff($old_arr, $new_arr);
  216. foreach ($added as $alias) {
  217. $result = Vesta::execute(Vesta::V_ADD_WEB_DOMAIN_ALIAS, array('USER' => $_user, 'DOMAIN' => $_DOMAIN, 'ALIAS' => $alias));
  218. if (!$result['status']) {
  219. $this->status = FALSE;
  220. $this->errors['ADD_ALIAS'] = array($result['error_code'] => $result['error_message']);
  221. }
  222. }
  223. foreach ($deleted as $alias) {
  224. $result = Vesta::execute(Vesta::V_DEL_WEB_DOMAIN_ALIAS, array('USER' => $_user, 'DOMAIN' => $_DOMAIN, 'ALIAS' => $alias));
  225. if (!$result['status']) {
  226. $this->status = FALSE;
  227. $this->errors['DEL_ALIAS'] = array($result['error_code'] => $result['error_message']);
  228. }
  229. }
  230. }
  231. if ($_old['STAT'] != $_new['STAT']) {
  232. if ($_new['STAT'] == true) {
  233. $result = array();
  234. $result = Vesta::execute(Vesta::V_ADD_WEB_DOMAIN_STAT, array('USER' => $_user, 'DOMAIN' => $_DOMAIN, 'STAT' => $_new['STAT']));
  235. if (!$result['status']) {
  236. $this->status = FALSE;
  237. $this->errors['ADD_STAT'] = array($result['error_code'] => $result['error_message']);
  238. }
  239. }
  240. if ($_new['STAT'] == false) {
  241. $result = array();
  242. $result = Vesta::execute(Vesta::V_DEL_WEB_DOMAIN_STAT, array('USER' => $_user, 'DOMAIN' => $_DOMAIN));
  243. if (!$result['status']) {
  244. $this->status = FALSE;
  245. $this->errors['DEL_STAT'] = array($result['error_code'] => $result['error_message']);
  246. }
  247. $result = array();
  248. $result = Vesta::execute(Vesta::V_DEL_WEB_DOMAIN_STAT_AUTH, array('USER' => $_user, 'DOMAIN' => $_DOMAIN, 'STAT_USER' => $_new['STAT_USER']));
  249. if (!$result['status']) {
  250. $this->status = FALSE;
  251. $this->errors['DEL_STAT_AUTH'] = array($result['error_code'] => $result['error_message']);
  252. }
  253. }
  254. }
  255. if ($_old['CGI'] != $_new['CGI']) {
  256. if ($_new['CGI'] == true) {
  257. $result = array();
  258. $result = Vesta::execute(Vesta::V_ADD_WEB_DOMAIN_CGI, array('USER' => $_user, 'DOMAIN' => $_DOMAIN));
  259. if (!$result['status']) {
  260. $this->status = FALSE;
  261. $this->errors['ADD_CGI'] = array($result['error_code'] => $result['error_message']);
  262. }
  263. }
  264. if ($_new['CGI'] == false) {
  265. $result = array();
  266. $result = Vesta::execute(Vesta::V_DEL_WEB_DOMAIN_CGI, array('USER' => $_user, 'DOMAIN' => $_DOMAIN));
  267. if (!$result['status']) {
  268. $this->status = FALSE;
  269. $this->errors['DEL_CGI'] = array($result['error_code'] => $result['error_message']);
  270. }
  271. }
  272. }
  273. if ($_old['ELOG'] != $_new['ELOG']) {
  274. if ($_new['ELOG'] == true) {
  275. $result = array();
  276. $result = Vesta::execute(Vesta::V_ADD_WEB_DOMAIN_ELOG, array('USER' => $_user, 'DOMAIN' => $_DOMAIN));
  277. if (!$result['status']) {
  278. $this->status = FALSE;
  279. $this->errors['ADD_ELOG'] = array($result['error_code'] => $result['error_message']);
  280. }
  281. }
  282. if ($_new['ELOG'] == false) {
  283. $result = array();
  284. $result = Vesta::execute(Vesta::V_DEL_WEB_DOMAIN_ELOG, array('USER' => $_user, 'DOMAIN' => $_DOMAIN));
  285. if (!$result['status']) {
  286. $this->status = FALSE;
  287. $this->errors['DEL_ELOG'] = array($result['error_code'] => $result['error_message']);
  288. }
  289. }
  290. }
  291. return $this->reply($result['status'], $result['data']);
  292. }
  293. public function suspendExecute(Request $request)
  294. {
  295. $_s = $request->getParameter('spell');
  296. $user = $this->getLoggedUser();
  297. $params = array(
  298. 'USER' => $_user['uid'],
  299. 'DOMAIN' => $_s['DOMAIN']
  300. );
  301. $result = Vesta::execute(Vesta::V_SUSPEND_WEB_DOMAIN, $params);
  302. if (!$result['status']) {
  303. $this->errors[] = array($result['error_code'] => $result['error_message']);
  304. }
  305. return $this->reply($result['status'], $result['data']);
  306. }
  307. public function unsuspendExecute(Request $request)
  308. {
  309. $_s = $request->getParameter('spell');
  310. $user = $this->getLoggedUser();
  311. $params = array(
  312. 'USER' => $user['uid'],
  313. 'DOMAIN' => $_s['DOMAIN']
  314. );
  315. $result = Vesta::execute(Vesta::V_UNSUSPEND_WEB_DOMAIN, $params);
  316. if (!$result['status']) {
  317. $this->errors[] = array($result['error_code'] => $result['error_message']);
  318. }
  319. return $this->reply($result['status'], $result['data']);
  320. }
  321. }