ISPConfig module for simplify the creation of websites and DNS zones in a only step
25개 이상의 토픽을 선택하실 수 없습니다. Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 

732 lines
27 KiB

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