WEB_DOMAIN.class.php 14 KB

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