ISPConfig module for simplify the creation of websites and DNS zones in a only step
No puede seleccionar más de 25 temas Los temas deben comenzar con una letra o número, pueden incluir guiones ('-') y pueden tener hasta 35 caracteres de largo.
 
 
 
 

643 líneas
22 KiB

  1. <?php
  2. /*
  3. 2017, David Ramos García, Open6Hosting <dramos@open6hosting.com>
  4. All rights reserved.
  5. */
  6. /******************************************
  7. * Begin Form configuration
  8. ******************************************/
  9. //Solo se puede tener una variable para cargar los distintos formularios
  10. $tform_def_file = "form/new_service_webdns.tform.php";
  11. /******************************************
  12. * End Form configuration
  13. ******************************************/
  14. require_once '../../lib/config.inc.php';
  15. require_once '../../lib/app.inc.php';
  16. //* Check permissions for module
  17. $app->auth->check_module_permissions('webdns');
  18. // Check the module permissions and redirect if not allowed.
  19. /*if(!stristr($_SESSION['s']['user']['modules'],'customdns')) {
  20. header('Location: ../index.php');
  21. die;
  22. }*/
  23. // Loading classes, asi es como se carga la api, busco la clase que contiene los métodos que se necesiten y se añade aquí
  24. $app->uses('tpl,tform,tform_actions,remoting,tools_sites,remoting_lib,remoting_dns');
  25. $app->load('tform_actions');
  26. class page_action extends tform_actions {
  27. //Con esta funcion se parsean y preparan los campos del formulario, new_service_dns.tform.php
  28. //justo después de la carga de este.
  29. /*function onShowEnd() {
  30. global $app, $conf;*/
  31. //FORMULARIO
  32. //Con esta llamada a al clase $app cargo todos los campos definidos en el formulario,
  33. //en este caso, los definidos en el array $form["tabs"]['webdns'];
  34. //$fields = $app->tform->encode($this->dataRecord, $app->tform->getCurrentTab(), true);
  35. // select first template as default
  36. /*if($fields['dns_template_id'] == 0)
  37. {
  38. $first_template = $app->db->queryOneRecord("SELECT template_id FROM dns_template WHERE visible = 'Y' ORDER BY name ASC");
  39. $fields['dns_template_id'] = $first_template['template_id'];
  40. }*/
  41. //BASE DE DATOS - TEMPLATE
  42. //Cargo todos los valores de la tabla dns_template que coincidan con id del template seleccionado.
  43. ///$template_record = $app->db->queryOneRecord("SELECT * FROM dns_template WHERE template_id = ?", $fields['dns_template_id']);
  44. //IMPORTANTE, aquí­ cargo el campo fields de la tabla dns_template
  45. //que contiene una lista de los campos que se muestran en el template(vista)
  46. /*$fields = explode(',', $template_record['fields']);
  47. if(is_array($fields)) {
  48. foreach($fields as $field) {
  49. $app->tpl->setVar($field."_VISIBLE", 1);
  50. $field = strtolower($field);
  51. $app->tpl->setVar($field, $_POST['dns_'.$field]);
  52. }
  53. }*/
  54. /*parent::onShowEnd();
  55. }*/
  56. public $dominio;
  57. public $subdominio;
  58. public $es_subdominio = false;
  59. public $subdom_error = false;
  60. public $no_ip = false;
  61. //Expresiones regulares para comprobar si es subdominio
  62. function comprobarSubDominios($subdom) {
  63. global $app, $conf;
  64. $patronSubDominos = "/(.*?)\.(.*)$/";
  65. $patronWWW = "/^w{3}/";
  66. //$patronPunto = '/(\.)/';
  67. $patronP1 = '/(^\.)/';
  68. $patronP2 = '/(\.$)/';
  69. $patronP3 = '/(\.\.+)/';
  70. $patronP4 = '/(\.[[:alpha:]]*)$/';
  71. //Se comprueba que no tenga 3 w "www" al principio del nombre del dominio o subdomino
  72. $encontradoWWW = preg_match($patronWWW, $subdom, $coincidencias);
  73. if($encontradoWWW){
  74. $app->tform->errorMessage = $app->tform->wordbook['error_dominio_www'];
  75. return;
  76. }
  77. //Si el dominio tiene mas de dos puntos, es incorrecto
  78. if (substr_count($subdom,".") > 2) {
  79. $app->tform->errorMessage = $app->tform->wordbook['error_dominio_mas_puntos'];
  80. return;
  81. //print 'El Dominio ¡¡NO!! es correcto, hay 3 puntos o más.</p>\n';
  82. //$this->subdom_error = true;
  83. } else if(substr_count($subdom,".") == 2){
  84. $this->encontrado = preg_match($patronSubDominos, $subdom, $coincidencias);
  85. //print "<pre>"; print_r($coincidencias); print "</pre>\n";
  86. $this->subdominio = $coincidencias[1];
  87. $this->dominio = $coincidencias[2];
  88. //print "Subdomino: " . $this->subdomino . "</p>\n Dominio: " . $this->domino;
  89. $this->es_subdominio = true;
  90. }
  91. //print "<pre>El dominio es: " . $this->dominio;
  92. return $this->es_subdominio;
  93. }
  94. //Crear subdominio
  95. function crearSubDominio($remoto, $campoSubDominio){
  96. //para usar variables globales en las funciones hay que declararlas dentro de la funcion.
  97. global $app, $conf;
  98. //print "<pre>"; print_r($campoSubDominio); print "</pre>\n";
  99. //Compruebo que el subdominio no existe consultando la tabla web_domain.
  100. $existeSubDominio = $app->db->queryOneRecord('SELECT domain_id, domain FROM web_domain WHERE domain = "'.$campoSubDominio.'"');
  101. //print '<pre>El Sub existe '. $existeSubDominio['domain'];
  102. if($existeSubDominio){
  103. $this->subdom_error = true;
  104. $app->tform->errorMessage = $app->tform->wordbook['error_subdominio_existe'];
  105. $this->onError();
  106. return;
  107. }
  108. //print "<pre>El dominio es: " . $this->dominio;
  109. $camDominio = $app->db->queryOneRecord('SELECT domain_id, domain FROM domain WHERE domain = "'.$this->dominio.'"');
  110. $camDnsRR = $app->db->queryOneRecord('SELECT server_id, zone FROM dns_rr WHERE name LIKE "'.$this->dominio.'%"');
  111. $camServIP = $app->db->queryOneRecord('SELECT ip_address FROM server_ip WHERE server_id = "'.$camDnsRR['server_id'].'"');
  112. //print_r($camDominio);
  113. //print_r($camDnsRR);
  114. //Si el dominio NO existe mostramos mensaje de error y salimos de la ejecución
  115. if(!$camDominio['domain']){
  116. $this->subdom_error = true;
  117. $app->tform->errorMessage = $app->tform->wordbook['error_no_existe_dominio_padre'];
  118. $this->onError();
  119. //return;
  120. /*echo '<div class="table-wrapper marginTop15">
  121. <table class="table">
  122. <tbody>
  123. <tr>
  124. <td bgcolor="#f7dfdf" colspan="2"><b>El dominio padre para este subdominio ¡NO EXISTE!</b></td>
  125. </tr>
  126. </tbody>
  127. </table>
  128. </div>';*/
  129. //print 'No existe el dominio';
  130. return $this->subdom_error;
  131. } else {
  132. //Parametros para la creación de subdominios
  133. $paramSubDominios = array(
  134. 'server_id' => $camDnsRR['server_id'],
  135. 'zone' => $camDnsRR['zone'],
  136. 'name' => $this->subdominio,
  137. 'type' => 'a',
  138. 'data' => $camServIP['ip_address'],
  139. //'aux' => '0',
  140. 'ttl' => '3600',
  141. 'active' => 'y',
  142. //comento el campo stamp, ya que introducia solo ceros en la bbdd
  143. //'stamp' => time(),
  144. 'serial' => '1',
  145. );
  146. //print "<pre>"; print_r($paramSubDominios); print "</pre>\n";
  147. //$remote = new remote_actions;
  148. //Inserto en bbdd usando la clase remoto que se la he pasado en parámetros de la función
  149. $resultado = $remoto->insert_query('../dns/form/dns_a.tform.php', $fields['client_id'], $paramSubDominios);
  150. echo '<br><div class="alert alert-success"><br>
  151. Se ha dado de alta Web y Subdominio, <b>'.$this->subdominio.'</b>, ¡Correctamente!
  152. <br><br></div></br>';
  153. //$this->onShow();
  154. }
  155. }
  156. function crearSitioWebSubdominio($remoto){
  157. global $app, $conf;
  158. $fields = $app->tform->encode($this->dataRecord, $app->tform->getCurrentTab(), true);
  159. $dns_ip_servidor_ipv6 = $app->db->queryOneRecord("SELECT ip_type, ip_address FROM server_ip WHERE client_id = ".$fields['client_id']." AND ip_type='IPv6'");
  160. //Comprobamos que el resultado para el cliente seleccionado no esta vacío,
  161. //si lo esta tomamos los datos del cliente id 0
  162. if(!$dns_ip_servidor_ipv6){
  163. $dns_ip_servidor = $app->db->queryOneRecord("SELECT ip_type, ip_address FROM server_ip WHERE client_id = 0 AND ip_type='IPv4'");
  164. $dns_ip_servidor_ipv6 = $app->db->queryOneRecord("SELECT ip_type, ip_address FROM server_ip WHERE client_id = 0 AND ip_type='IPv6'");
  165. /*echo '<br><br>Valor de la consulta '.$dns_ip_servidor_ipv6[ip_address].' ';
  166. echo '<br><br>Valor de la consulta '.$dns_ip_servidor[ip_address].' ';*/
  167. }
  168. $dns_servidor = $app->db->queryOneRecord("SELECT client_id, default_dnsserver, default_webserver FROM client WHERE client_id = ".$app->functions->intval($fields['client_id']));
  169. $clienteID = $dns_servidor['client_id'];
  170. $res = $app->db->queryOneRecord("SELECT groupid FROM sys_group WHERE client_id = ".$app->functions->intval($fields['client_id']));
  171. $client_group_id = $res['groupid'];
  172. // add site
  173. $paramsite = array(
  174. 'type' => 'vhost',
  175. 'domain' => $fields['domain'], //$this->subdominio,
  176. 'server_id' => $dns_servidor['default_webserver'],
  177. 'ip_address' => '*', //$dns_ip_servidor['ip_address'],
  178. 'ipv6_address' => $dns_ip_servidor_ipv6['ip_address'],
  179. 'traffic_quota' => '-1',
  180. 'hd_quota' => '0',
  181. 'cgi' => 'y',
  182. 'ssi' => 'y',
  183. 'suexec' => 'y',
  184. 'ruby' => 'n',
  185. 'python' => 'n',
  186. 'perl' => 'n',
  187. 'errordocs' => '1',
  188. 'subdomain' => '',
  189. 'php' => 'php-fpm',
  190. 'fastcgi_php_version' => '',
  191. 'seo_redirect' => '',
  192. 'rewrite_to_https' => 'n',
  193. 'allow_override' => 'All',
  194. 'http_port' => 80,
  195. 'https_port' => 443,
  196. 'apache_directives' => '',
  197. 'nginx_directives' => '',
  198. 'php_fpm_use_socket' => 'y',
  199. 'pm' => 'ondemand',
  200. 'pm_max_children' => 10,
  201. 'pm_start_servers' => 1,
  202. 'pm_min_spare_servers' => 1,
  203. 'pm_max_spare_servers' => 5,
  204. 'pm_process_idle_timeout' => 10,
  205. 'pm_max_requests' => 0,
  206. 'custom_php_ini' => '',
  207. 'active' => 'y',
  208. 'document_root' => '-',
  209. 'system_user' => '-',
  210. 'system_group' => '-',
  211. 'log_retention' => 30,
  212. 'client_group_id' => $client_group_id,
  213. );
  214. //$app->uses('remoting_lib');
  215. //$formulario = $app->remoting_lib->loadFormDef('../sites/form/web_vhost_domain.tform.php');
  216. //$formulario = $app->tform->loadFormDef('../sites/form/web_vhost_domain.tform.php');
  217. /*print 'Valores: ' . $dns_ip_servidor_ipv6;
  218. print "<pre> Parametros:"; print_r($paramsite); print "</pre>\n";
  219. print '<pre> cliente id ' . $fields['client_id'];
  220. print "<pre>";print_r($fields);print "</pre>\n" . $fields['client_id'];*/
  221. //print "<pre>Formulario ";print_r($formulario);print "</pre>\n";
  222. //print '<pre>DNS IPV6 ' . $dns_ip_servidor_ipv6['ip_address'];
  223. //$tform_def_file2 = "../sites/form/web_vhost_domain.tform.php";
  224. //$app->tform->loadFormDef($tform_def_file2);
  225. //El último parámetro es para lanzar un evento que llama a la función on_after_insert que prepara los campos document_root, system_user y system_group
  226. $site_id = $remoto->insert_query('../sites/form/web_vhost_domain.tform.php', $fields['client_id'], $paramsite, 'sites:web_vhost_domain:on_after_insert');
  227. //print '<pre>ID sitio web del subdominio --> ' . $site_id;
  228. }
  229. function tieneIPs(){
  230. global $app, $conf;
  231. $fields = $app->tform->encode($this->dataRecord, $app->tform->getCurrentTab(), true);
  232. //Llamada a la tabla server_ip para recuperar la ip4 e ip6
  233. $dns_ip_servidor = $app->db->queryOneRecord("SELECT ip_type, ip_address FROM server_ip WHERE client_id = ".$app->functions->intval($fields['client_id']. " AND ip_type='IPv4'"));
  234. $dns_ip_servidor_ipv6 = $app->db->queryOneRecord("SELECT ip_type, ip_address FROM server_ip WHERE client_id = ".$fields['client_id']." AND ip_type='IPv6'");
  235. /*print "<pre>Campos ";print_r($fields);print "</pre>\n";
  236. print "<pre>IP4 ";print_r($dns_ip_servidor);print "</pre>\n";
  237. print "<pre>IP6 ";print_r($dns_ip_servidor_ipv6);print "</pre>\n";*/
  238. if(!$dns_ip_servidor['ip_address'] || !$dns_ip_servidor_ipv6['ip_address']){
  239. $app->tform->errorMessage = $app->tform->wordbook['error_no_ip'];
  240. $this->onError();
  241. //$this->no_ip = true;
  242. //print 'dentro if';
  243. return true;
  244. }
  245. return false;
  246. }
  247. function onSubmit() {
  248. global $app, $conf;
  249. //Carga de campos del formulario.
  250. $fields = $app->tform->encode($this->dataRecord, $app->tform->getCurrentTab(), true);
  251. //Creo la clase remote para usar las librerias
  252. $remote = new remote_actions;
  253. //$this->tieneIPs();
  254. if($this->tieneIPs()){
  255. return;
  256. }
  257. if($this->comprobarSubDominios($fields['domain'])){
  258. //print 'despues de comprobar que es un subD ' . $fields['domain'];
  259. $this->crearSubDominio($remote, $fields['domain']);
  260. if(!$this->subdom_error){
  261. $this->crearSitioWebSubdominio($remote);
  262. }
  263. return;
  264. } //else if(!$this->subdom_error){
  265. // check for domain unique name
  266. if($app->db->queryOneRecord('SELECT domain_id FROM domain WHERE domain = "'.$fields['domain'].'"')) {
  267. $app->tform->errorMessage = $app->tform->wordbook['domain_error_unique'];
  268. }
  269. if($app->tform->errorMessage)
  270. {
  271. $this->onError();
  272. return;
  273. }
  274. //Esta variable nos llega por jQuery desde el htm para el control de errores en la vista.
  275. if($_POST['create'] != 1)
  276. {
  277. $app->tform->errorMessage = 'DUMMY';
  278. $app->tpl->setVar($this->dataRecord);
  279. $this->onShow();
  280. return;
  281. }
  282. // Domain OK, continue
  283. //$remote = new remote_actions;
  284. // client prefix and group id
  285. $res = $app->db->queryOneRecord("SELECT groupid FROM sys_group WHERE client_id = ".$app->functions->intval($fields['client_id']));
  286. $client_group_id = $res['groupid'];
  287. $client_prefix = 'c'.$fields['client_id'];
  288. // add domain. Llamada que inserta el dominio en la tabla domain
  289. $domain_id = $remote->insert_query('../client/form/domain.tform.php', $fields['client_id'], array('domain' => $fields['domain']));
  290. //Carga del formulario dns_soa para guardar en base de datos
  291. $tform_def_file = "../dns/form/dns_soa.tform.php";
  292. $app->tform->loadFormDef($tform_def_file);
  293. // Carga y seleccion de dns_template, si no esta creado se informa de que tiene que crearse
  294. $template_record = $app->db->queryOneRecord("SELECT * FROM dns_template WHERE visible = 'Y' AND name = 'webdns'"); /*'open6hosting'");*/
  295. /*if($template_record) {
  296. //echo '<br><br>Teplate '.$template_record.', ';
  297. $app->tform->errorMessage = 'Error hay que crear un template llamado webdns';
  298. $this->onError();
  299. return;
  300. } else {
  301. $app->tform->errorMessage = 'Error hay que crear un template llamado webdnsssssss';
  302. $this->onError();
  303. return;
  304. }*/
  305. /*if($app->tform->errorMessage)
  306. {
  307. $this->onError();
  308. return;
  309. }*/
  310. //$template_record = $app->db->queryOneRecord("SELECT * FROM dns_template WHERE visible = 'Y' AND name = 'webdns'"); /*'open6hosting'");*/
  311. //Llamada a la tabla server_ip para recuperar la ip4 e ip6
  312. $dns_ip_servidor = $app->db->queryOneRecord("SELECT ip_type, ip_address FROM server_ip WHERE client_id = ".$app->functions->intval($fields['client_id']. " AND ip_type='IPv4'"));
  313. $dns_ip_servidor_ipv6 = $app->db->queryOneRecord("SELECT ip_type, ip_address FROM server_ip WHERE client_id = ".$fields['client_id']." AND ip_type='IPv6'");
  314. //Comprobamos que el resultado para el cliente seleccionado no esta vacío,
  315. //si lo esta tomamos los datos del cliente id 0
  316. if(!$dns_ip_servidor_ipv6){
  317. $dns_ip_servidor = $app->db->queryOneRecord("SELECT ip_type, ip_address FROM server_ip WHERE client_id = 0 AND ip_type='IPv4'");
  318. $dns_ip_servidor_ipv6 = $app->db->queryOneRecord("SELECT ip_type, ip_address FROM server_ip WHERE client_id = 0 AND ip_type='IPv6'");
  319. /*echo '<br><br>Valor de la consulta '.$dns_ip_servidor_ipv6[ip_address].' ';
  320. echo '<br><br>Valor de la consulta '.$dns_ip_servidor[ip_address].' ';*/
  321. }
  322. $tpl_content = $template_record['template'];
  323. // Reemplazo la variable que nos encontramos en base de datos por el valor que se ha introducido en el formulario
  324. $tpl_content = str_replace('{DOMAIN}', $fields['domain'], $tpl_content);
  325. //Carga de los datos en las variables ns
  326. $tpl_content = str_replace('{IP}', $dns_ip_servidor['ip_address'], $tpl_content);
  327. $tpl_content = str_replace('{IPV6}', $dns_ip_servidor_ipv6['ip_address'], $tpl_content);
  328. /*$tpl_content = str_replace('{NS1}', '.open6servers.com', $tpl_content);
  329. $tpl_content = str_replace('{NS2}', '.open6servers.com', $tpl_content); */
  330. $enable_dnssec = 'N';//(($_POST['dns_dnssec'] == 'Y') ? 'Y' : 'N');
  331. // Parse the template
  332. $tpl_rows = explode("\n", $tpl_content);
  333. $section = '';
  334. $vars = array();
  335. $vars['xfer']='';
  336. $dns_rr = array();
  337. foreach($tpl_rows as $row) {
  338. $row = trim($row);
  339. if(substr($row, 0, 1) == '[') {
  340. if($row == '[ZONE]') {
  341. $section = 'zone';
  342. } elseif($row == '[DNS_RECORDS]') {
  343. $section = 'dns_records';
  344. } else {
  345. die('Unknown section type');
  346. }
  347. } else {
  348. if($row != '') {
  349. // Handle zone section
  350. if($section == 'zone') {
  351. $parts = explode('=', $row);
  352. $key = trim($parts[0]);
  353. $val = trim($parts[1]);
  354. if($key != '') $vars[$key] = $val;
  355. }
  356. // Handle DNS Record rows
  357. if($section == 'dns_records') {
  358. $parts = explode('|', $row);
  359. $dns_rr[] = array(
  360. 'name' => $parts[1],
  361. 'type' => $parts[0],
  362. 'data' => $parts[2],
  363. 'aux' => $parts[3],
  364. 'ttl' => $parts[4]
  365. );
  366. }
  367. }
  368. }
  369. } // end foreach
  370. $dns_error = '';
  371. /*if($vars['origin'] == '') $dns_error .= $app->lng('error_origin_empty').'<br />';
  372. if($vars['ns'] == '') $dns_error .= $app->lng('error_ns_empty').'<br />';
  373. if($vars['mbox'] == '') $dns_error .= $app->lng('error_mbox_empty').'<br />';
  374. if($vars['refresh'] == '') $dns_error .= $app->lng('error_refresh_empty').'<br />';
  375. if($vars['retry'] == '') $dns_error .= $app->lng('error_retry_empty').'<br />';
  376. if($vars['expire'] == '') $dns_error .= $app->lng('error_expire_empty').'<br />';
  377. if($vars['minimum'] == '') $dns_error .= $app->lng('error_minimum_empty').'<br />';
  378. if($vars['ttl'] == '') $dns_error .= $app->lng('error_ttl_empty').'<br />';
  379. // check for dns errors
  380. if($dns_error)
  381. {
  382. $app->tform->errorMessage = $dns_error;
  383. $this->onError();
  384. return;
  385. }*/
  386. //Llamada a la tabla client para recuperar el client_id y su default_dnsserver
  387. $dns_servidor = $app->db->queryOneRecord("SELECT client_id, default_dnsserver, default_webserver FROM client WHERE client_id = ".$app->functions->intval($fields['client_id']));
  388. $valor_recuperado1 = $dns_servidor['client_id'];
  389. /*$valor_recuperado2 = $dns_servidor['default_dnsserver'];
  390. $valor_recuperado3 = $dns_servidor['default_webserver'];
  391. */
  392. // Insert the soa record
  393. $sys_userid = $_SESSION['s']['user']['userid'];
  394. $origin = $vars['origin'];
  395. $ns = $vars['ns'];
  396. $mbox = str_replace('@', '.', $vars['mbox']);
  397. $refresh = $vars['refresh'];
  398. $retry = $vars['retry'];
  399. $expire = $vars['expire'];
  400. $minimum = $vars['minimum'];
  401. $ttl = $vars['ttl'];
  402. $xfer = $vars['xfer'];
  403. $also_notify = $vars['also_notify'];
  404. $update_acl = $vars['update_acl'];
  405. $serial = $app->validate_dns->increase_serial(0);
  406. $insert_data = array(
  407. "sys_userid" => $sys_userid,
  408. "sys_groupid" => $client_group_id,
  409. "sys_perm_user" => 'riud',
  410. "sys_perm_group" => 'riud',
  411. "sys_perm_other" => '',
  412. "server_id" => $dns_servidor['default_dnsserver'],
  413. "origin" => $origin,
  414. "ns" => $ns,
  415. "mbox" => $mbox,
  416. "serial" => $serial,
  417. "refresh" => $refresh,
  418. "retry" => $retry,
  419. "expire" => $expire,
  420. "minimum" => $minimum,
  421. "ttl" => $ttl,
  422. "active" => 'Y',
  423. "xfer" => $xfer,
  424. "also_notify" => $also_notify,
  425. "update_acl" => $update_acl,
  426. "dnssec_wanted" => $enable_dnssec
  427. );
  428. $dns_soa_id = $app->db->datalogInsert('dns_soa', $insert_data, 'id');
  429. // Insert the dns_rr records
  430. if(is_array($dns_rr) && $dns_soa_id > 0) {
  431. foreach($dns_rr as $rr) {
  432. $insert_data = array(
  433. "sys_userid" => $sys_userid,
  434. "sys_groupid" => $client_group_id,
  435. "sys_perm_user" => 'riud',
  436. "sys_perm_group" => 'riud',
  437. "sys_perm_other" => '',
  438. "server_id" => $dns_servidor['default_dnsserver'],
  439. "zone" => $dns_soa_id,
  440. "name" => $rr['name'],
  441. "type" => $rr['type'],
  442. "data" => $rr['data'],
  443. "aux" => $rr['aux'],
  444. "ttl" => $rr['ttl'],
  445. "active" => 'Y'
  446. );
  447. $dns_rr_id = $app->db->datalogInsert('dns_rr', $insert_data, 'id');
  448. }
  449. }
  450. //sites_web_domain_add
  451. $tform_def_file = "../sites/form/web_vhost_domain.tform.php";
  452. $app->tform->loadFormDef($tform_def_file);
  453. //$app->remoting_lib->loadFormDef($tform_def_file);
  454. // add site
  455. $paramsite = array(
  456. 'type' => 'vhost',
  457. 'domain' => $fields['domain'],
  458. 'server_id' => $dns_servidor['default_webserver'],
  459. 'ip_address' => '*', //$dns_ip_servidor['ip_address'],
  460. 'ipv6_address' => $dns_ip_servidor_ipv6['ip_address'],
  461. 'traffic_quota' => '-1',
  462. 'hd_quota' => '0',
  463. 'cgi' => 'y',
  464. 'ssi' => 'y',
  465. 'suexec' => 'y',
  466. 'ruby' => 'n',
  467. 'python' => 'n',
  468. 'perl' => 'n',
  469. 'errordocs' => '1',
  470. 'subdomain' => 'www',
  471. 'php' => 'php-fpm',
  472. 'fastcgi_php_version' => '',
  473. 'seo_redirect' => '',
  474. 'rewrite_to_https' => 'n',
  475. 'allow_override' => 'All',
  476. 'http_port' => 80,
  477. 'https_port' => 443,
  478. 'apache_directives' => '',
  479. 'nginx_directives' => '',
  480. 'php_fpm_use_socket' => 'y',
  481. 'pm' => 'ondemand',
  482. 'pm_max_children' => 10,
  483. 'pm_start_servers' => 1,
  484. 'pm_min_spare_servers' => 1,
  485. 'pm_max_spare_servers' => 5,
  486. 'pm_process_idle_timeout' => 10,
  487. 'pm_max_requests' => 0,
  488. 'custom_php_ini' => '',
  489. 'active' => 'y',
  490. 'document_root' => '-',
  491. 'system_user' => '-',
  492. 'system_group' => '-',
  493. 'log_retention' => 30,
  494. 'client_group_id' => $client_group_id,
  495. );
  496. /*print 'Valores: ' . $dns_ip_servidor_ipv6 . " " . $formulario . " Parametros: " ;
  497. print "<pre>"; print_r($paramsite); print "</pre>\n";
  498. print '<pre> cliente id ' . $fields['client_id'];
  499. print "<pre>";print_r($fields);print "</pre>\n";*/
  500. //print "<pre>Formulario ";print_r($formulario);print "</pre>\n";
  501. //print 'DNS IPV6 ' . $dns_ip_servidor_ipv6['ip_address'];
  502. //El último parámetro es para lanzar un evento que llama a la función on_after_insert que prepara los campos document_root, system_user y system_group
  503. $site_id = $remote->insert_query('../sites/form/web_vhost_domain.tform.php', $fields['client_id'], $paramsite, 'sites:web_vhost_domain:on_after_insert');
  504. // get site data
  505. $app->uses('remoting_lib');
  506. $app->remoting_lib->loadFormDef('../sites/form/web_vhost_domain.tform.php');
  507. $site_data = $app->remoting_lib->getDataRecord($site_id);
  508. //$remote->insert_query('../sites/form/web_vhost_domain.tform.php', $fields['client_id'], $paramsite);
  509. //Si todo va bien, el resultado
  510. echo '<br><div class="alert alert-success"><br>
  511. Altas Web y DNS del dominio <b>'.$fields['domain'].'</b>, ¡Creadas correctamente!
  512. <br><br></div></br>';
  513. //$this->onShow();
  514. /*echo '<div class="table-wrapper marginTop15">
  515. <table class="table">
  516. <tbody>
  517. <tr>
  518. <td bgcolor="#1ccb00" colspan="2">Altas Web y DNS del dominio <b>'.$fields['domain'].'</b>, ¡Creadas correctamente!</td>
  519. </tr>
  520. </tbody>
  521. </table>
  522. </div>';*/
  523. //}
  524. //parent::onSubmit();
  525. //}//FIN IF
  526. }
  527. }
  528. class remote_actions extends remoting {
  529. public function insert_query($formdef_file, $client_id, $params, $event_identifier = '') {
  530. return $this->insertQuery($formdef_file, $client_id, $params, $event_identifier);
  531. }
  532. }
  533. $page = new page_action;
  534. $page->onLoad();