ISPConfig module for simplify the creation of websites and DNS zones in a only step
Ви не можете вибрати більше 25 тем Теми мають розпочинатися з літери або цифри, можуть містити дефіси (-) і не повинні перевищувати 35 символів.
 
 
 
 

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