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.
 
 
 
 

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