ISPConfig module for simplify the creation of websites and DNS zones in a only step
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 

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