ISPConfig module for simplify the creation of websites and DNS zones in a only step
25'ten fazla konu seçemezsiniz Konular bir harf veya rakamla başlamalı, kısa çizgiler ('-') içerebilir ve en fazla 35 karakter uzunluğunda olabilir.
 
 
 
 

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