ISPConfig module for simplify the creation of websites and DNS zones in a only step
Nie możesz wybrać więcej, niż 25 tematów Tematy muszą się zaczynać od litery lub cyfry, mogą zawierać myślniki ('-') i mogą mieć do 35 znaków.
 
 
 
 

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