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

1531 lines
61 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. require_once '../../lib/config.inc.php';
  8. require_once '../../lib/app.inc.php';
  9. //require 'pdf_o6h.php';
  10. //Variable para cargar los distintos formularios.
  11. $tform_def_file = "form/new_service_webdns.tform.php";
  12. //Check permissions for module
  13. $app->auth->check_module_permissions('webdns');
  14. //Loading classes a usar.
  15. $app->uses('tpl,tform,tform_actions,remoting,tools_sites,remoting_lib,remoting_dns');
  16. $app->load('tform_actions');
  17. class page_action extends tform_actions {
  18. function onShowNew() {
  19. global $app;
  20. //Si es usuario no puede usar el módulo webdns
  21. if($_SESSION['s']['user']['typ'] == 'user') {
  22. $app->error($app->tform->wordbook["error_usuario_no_permitido_webdns"]);
  23. }
  24. parent::onShowNew();
  25. }
  26. function onShowEnd() {
  27. global $app, $conf, $interfaceConf;
  28. $this->tratarVariablesPrefix();
  29. $app->uses('getconf,tools_sites');
  30. $global_config = $app->getconf->get_global_config('sites');
  31. $ftpuser_prefix = $app->tools_sites->replacePrefix($global_config['ftpuser_prefix'], $this->dataRecord);
  32. if ($this->dataRecord['username'] != ""){
  33. /* REMOVE the restriction */
  34. $app->tpl->setVar("username", $app->tools_sites->removePrefix($this->dataRecord['username'], $this->dataRecord['username_prefix'], $ftpuser_prefix));
  35. }
  36. if($this->dataRecord['username'] == "") {
  37. $app->tpl->setVar("username_prefix", $ftpuser_prefix);
  38. } else {
  39. $app->tpl->setVar("username_prefix", $app->tools_sites->getPrefix($this->dataRecord['username_prefix'], $ftpuser_prefix, $global_config['ftpuser_prefix']));
  40. }
  41. //Get the database user prefix
  42. $app->uses('getconf,tools_sites');
  43. $global_config = $app->getconf->get_global_config('sites');
  44. //* Client: If the logged in user is not admin and has no sub clients (no reseller)
  45. /* if ($_SESSION["s"]["user"]["typ"] != 'admin' && !$app->auth->has_clients($_SESSION['s']['user']['userid'])) {
  46. // Get the limits of the client
  47. $client_group_id = $app->functions->intval($_SESSION["s"]["user"]["default_group"]);
  48. $client = $app->db->queryOneRecord("SELECT client.company_name, client.contact_name, client.client_id FROM sys_group, client WHERE sys_group.client_id = client.client_id and sys_group.groupid = ?", $client_group_id);
  49. //* Reseller: If the logged in user is not admin and has sub clients (reseller)
  50. }elseif ($_SESSION["s"]["user"]["typ"] != 'admin' && $app->auth->has_clients($_SESSION['s']['user']['userid'])) {
  51. // Get the limits of the client
  52. $client_group_id = $app->functions->intval($_SESSION["s"]["user"]["default_group"]);
  53. $client = $app->db->queryOneRecord("SELECT client.company_name, client.contact_name, client.client_id FROM sys_group, client WHERE sys_group.client_id = client.client_id and sys_group.groupid = ?", $client_group_id);
  54. // Fill the client select field
  55. $sql = "SELECT sys_group.groupid, sys_group.name, CONCAT(IF(client.company_name != '', CONCAT(client.company_name, ' :: '), ''), client.contact_name, ' (', client.username, IF(client.customer_no != '', CONCAT(', ', client.customer_no), ''), ')') as contactname FROM sys_group, client WHERE sys_group.client_id = client.client_id AND client.parent_client_id = ? ORDER BY client.company_name, client.contact_name, sys_group.name";
  56. $records = $app->db->queryAllRecords($sql, $client['client_id']);
  57. $tmp = $app->db->queryOneRecord("SELECT groupid FROM sys_group WHERE client_id = ?", $client['client_id']);
  58. $client_select = '<option value="'.$tmp['groupid'].'">'.$client['contact_name'].'</option>';
  59. //$tmp_data_record = $app->tform->getDataRecord($this->id);
  60. if(is_array($records)) {
  61. foreach( $records as $rec) {
  62. $selected = @(is_array($this->dataRecord) && ($rec["groupid"] == $this->dataRecord['client_group_id'] || $rec["groupid"] == $this->dataRecord['sys_groupid']))?'SELECTED':'';
  63. $client_select .= "<option value='$rec[groupid]' $selected>$rec[contactname]</option>\r\n";
  64. }
  65. }
  66. $app->tpl->setVar("client_group_id", $client_select);
  67. //* Es Admin
  68. } else*/if($_SESSION["s"]["user"]["typ"] == 'admin') {
  69. // Fill the client select field
  70. $sql = "SELECT sys_group.groupid, sys_group.name, CONCAT(IF(client.company_name != '', CONCAT(client.company_name, ' :: '), ''), client.contact_name, ' (', client.username, IF(client.customer_no != '', CONCAT(', ', client.customer_no), ''), ')') as contactname FROM sys_group, client WHERE sys_group.client_id = client.client_id AND sys_group.client_id > 0 ORDER BY client.company_name, client.contact_name, sys_group.name";
  71. $clients = $app->db->queryAllRecords($sql);
  72. $client_select = "<option value='0'></option>";
  73. //$tmp_data_record = $app->tform->getDataRecord($this->id);
  74. if(is_array($clients)) {
  75. foreach( $clients as $client) {
  76. //$selected = @($client["groupid"] == $tmp_data_record["sys_groupid"])?'SELECTED':'';
  77. $selected = @(is_array($this->dataRecord) && ($client["groupid"] == $this->dataRecord['client_group_id'] || $client["groupid"] == $this->dataRecord['sys_groupid']))?'SELECTED':'';
  78. $client_select .= "<option value='$client[groupid]' $selected>$client[contactname]</option>\r\n";
  79. }
  80. }
  81. $app->tpl->setVar("client_group_id", $client_select);
  82. }
  83. if ($this->dataRecord['database_user'] != ""){
  84. /* REMOVE the restriction */
  85. $app->tpl->setVar("database_user", $app->tools_sites->removePrefix($this->dataRecord['database_user'], $this->dataRecord['database_user_prefix'], $dbuser_prefix));
  86. }
  87. if($this->dataRecord['database_user'] == "") {
  88. $app->tpl->setVar("database_user_prefix", $dbuser_prefix);
  89. } else {
  90. $app->tpl->setVar("database_user_prefix", $app->tools_sites->getPrefix($this->dataRecord['database_user_prefix'], $dbuser_prefix, $global_config['dbuser_prefix']));
  91. $app->tools_sites->getPrefix($this->dataRecord['database_user_prefix'], $dbuser_prefix, $global_config['dbuser_prefix']);
  92. $datos_prefix = $app->tools_sites->getPrefix($this->dataRecord['database_user_prefix'], $dbuser_prefix, $global_config['dbuser_prefix']);
  93. $fields['database_user_prefix'] = $datos_prefix;
  94. }
  95. if ($this->dataRecord['username'] != ""){
  96. /* REMOVE the restriction */
  97. $app->tpl->setVar("username", $app->tools_sites->removePrefix($this->dataRecord['username'], $this->dataRecord['username_prefix'], $ftpuser_prefix));
  98. }
  99. if($this->dataRecord['username'] == "") {
  100. $app->tpl->setVar("username_prefix", $ftpuser_prefix);
  101. } else {
  102. $app->tpl->setVar("username_prefix", $app->tools_sites->getPrefix($this->dataRecord['username_prefix'], $ftpuser_prefix, $global_config['ftpuser_prefix']));
  103. }
  104. parent::onShowEnd();
  105. }
  106. public $valor_prefix;
  107. public $valor_prefix_ftp;
  108. function tratarVariablesPrefix() {
  109. global $app, $conf, $interfaceConf;
  110. //Get the database name and database user prefix
  111. $app->uses('getconf,tools_sites');
  112. $global_config = $app->getconf->get_global_config('sites');
  113. $dbuser_prefix = $app->tools_sites->replacePrefix($global_config['dbuser_prefix'], $this->dataRecord);
  114. $ftpuser_prefix = $app->tools_sites->replacePrefix($global_config['ftpuser_prefix'], $this->dataRecord);
  115. $this->dataRecord['username_prefix'] = $ftpuser_prefix;
  116. $this->dataRecord['database_user_prefix'] = $dbuser_prefix;
  117. $this->valor_prefix = $this->dataRecord['database_user_prefix'] = $dbuser_prefix;
  118. $this->valor_prefix_ftp = $this->dataRecord['username_prefix'] = $ftpuser_prefix;
  119. if(strlen($dbuser_prefix . $this->dataRecord['database_user']) > 16)
  120. $app->tform->errorMessage .= str_replace('{user}', htmlentities($dbuser_prefix . $this->dataRecord['database_user'], ENT_QUOTES, 'UTF-8'),
  121. $app->tform->wordbook["database_user_error_len"]).'<br />';
  122. //Check database user against blacklist
  123. $dbuser_blacklist = array($conf['db_user'], 'mysql', 'root');
  124. if(is_array($dbuser_blacklist) && in_array($dbuser_prefix . $this->dataRecord['database_user'], $dbuser_blacklist)) {
  125. $app->tform->errorMessage .= $app->lng('Database user not allowed.').'<br />';
  126. }
  127. /* restrict the names */
  128. /* crop user names if they are too long -> mysql: user: 16 chars / db: 64 chars */
  129. if ($app->tform->errorMessage == ''){
  130. $this->dataRecord['database_user'] = substr($dbuser_prefix . $this->dataRecord['database_user'], 0, 16);
  131. }
  132. $this->dataRecord['server_id'] = 0; // we need this on all servers
  133. if ($this->dataRecord['database_user'] != ""){
  134. /* REMOVE the restriction */
  135. $app->tpl->setVar("database_user", $app->tools_sites->removePrefix($this->dataRecord['database_user'], $this->dataRecord['database_user_prefix'], $dbuser_prefix));
  136. }
  137. if($this->dataRecord['database_user'] == "") {
  138. $app->tpl->setVar("database_user_prefix", $dbuser_prefix);
  139. } else {
  140. $app->tpl->setVar("database_user_prefix", $app->tools_sites->getPrefix($this->dataRecord['database_user_prefix'], $dbuser_prefix, $global_config['dbuser_prefix']));
  141. }
  142. //* Reseller: If the logged in user is not admin and has sub clients (is a reseller)
  143. /* if($_SESSION["s"]["user"]["typ"] != 'admin' && $app->auth->has_clients($_SESSION['s']['user']['userid'])) {
  144. $this->valor_prefix = $dbuser_prefix;
  145. }*/
  146. }
  147. public $dominio;
  148. public $subdominio;
  149. public $es_subdominio = false;
  150. public $subdom_error = false;
  151. public $dominio_error = false;
  152. public $no_ip = false;
  153. //Campos para PDF
  154. public $usuario_db_txt;
  155. public $nombre_db_txt;
  156. public $pass_db_txt;
  157. public $usuario_ftp_txt;
  158. public $pass_ftp_txt;
  159. public $nombre_user_ftp;
  160. public $ip4_pdf;
  161. public $url_db;
  162. function generaNombreFTP(){
  163. $this->tratarVariablesPrefix();
  164. //Cadena de caractares para construir el nombre.
  165. $cadena = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ23456789";
  166. //Obtengo la longitud de las cadenas
  167. $longitudCadena=strlen($cadena);
  168. //Variable para el nombre
  169. $nombre = "";
  170. //Longitud para el nombre
  171. $longitudNombre=8;
  172. //Creo el nombre
  173. for($i=1 ; $i<=$longitudNombre ; $i++){
  174. //Número aleatorio entre 0 y la longitud de la cadena de caracteres-1
  175. $pos=rand(0,$longitudCadena-1);
  176. //Formo la nombre en cada iteracción del bucle, añadiendo a la cadena $nombre
  177. //la letra correspondiente a la posición $pos en la cadena de caracteres definida.
  178. $nombre .= substr($cadena,$pos,1);
  179. }
  180. return $nombre;
  181. }
  182. function generaPass(){
  183. //Cadena de caractares para construir las password.
  184. $cadena = "abcdefghijklmnopqrstuvwxyz!@#_ABCDEFGHIJKLMNOPQRSTUVWXYZ23456789";
  185. $cadSpeciales = "!@#_";
  186. //Obtengo la longitud de las cadenas
  187. $longitudCadena = strlen($cadena);
  188. $longSpeciales = strlen($cadSpeciales);
  189. //Variable para la password
  190. $pass = "";
  191. //Longitud para la password
  192. $longitudPass=13;
  193. //Creo la password
  194. for($i=1 ; $i<=$longitudPass ; $i++){
  195. //Número aleatorio entre 0 y la longitud de la cadena de caracteres-1
  196. $pos=rand(0,$longitudCadena-1);
  197. //Formo la password en cada iteracción del bucle, añadiendo a la cadena $pass
  198. //la letra correspondiente a la posición $pos en la cadena de caracteres definida.
  199. $pass .= substr($cadena,$pos,1);
  200. //Añado algún caracter especial en los últimos cuatro caracteres
  201. for($i2=13;$i2<=$i; $i2++){
  202. $poSpecial=rand(0,$longSpeciales-1);
  203. $pass .= substr($cadSpeciales, $poSpecial, 1);
  204. }
  205. }
  206. return $pass;
  207. }
  208. function generaNombreBD(){
  209. $this->tratarVariablesPrefix();
  210. //Cadena de caractares para construir las nombre.
  211. $cadena = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ23456789";
  212. //$cadSpeciales = "!@#_";
  213. //Obtengo la longitud de las cadenas
  214. $longitudCadena=strlen($cadena);
  215. //$longSpeciales = strlen($cadSpeciales);
  216. //Variable para la nombre
  217. $nombre = "";
  218. //Longitud para la nombre
  219. $longitudNombre=8;
  220. //Creo el nombre
  221. for($i=1 ; $i<=$longitudNombre ; $i++){
  222. //Número aleatorio entre 0 y la longitud de la cadena de caracteres-1
  223. $pos=rand(0,$longitudCadena-1);
  224. //Formo la nombre en cada iteracción del bucle, añadiendo a la cadena $nombre
  225. //la letra correspondiente a la posición $pos en la cadena de caracteres definida.
  226. $nombre .= substr($cadena,$pos,1);
  227. }
  228. return $this->valor_prefix . $nombre;
  229. }
  230. function crearBaseDatosFtp($remoto){
  231. global $app, $conf;
  232. $fields = $app->tform->encode($this->dataRecord, $app->tform->getCurrentTab(), true);
  233. $app->uses('ini_parser,getconf');
  234. $server_config_array = $app->getconf->get_global_config();
  235. $generated_usernameBBDD = $this->generaNombreBD();
  236. $sitio_id = $app->db->queryOneRecord(
  237. 'SELECT domain_id, domain FROM web_domain WHERE domain = "'.$fields['domain'].'"');
  238. $clavePass = $this->generaPass();
  239. //añado database user con su prefix
  240. $db_user_params = array(
  241. 'server_id' => $this->bbdd_serv,
  242. 'sysgroup_id' => $this->cli_grupo_id, //$this->sys_grupo_id,
  243. 'sys_userid' => $this->sys_usuario_id,
  244. 'sys_perm_other' => '-',
  245. 'database_user' => $generated_usernameBBDD,
  246. 'database_user_prefix' => $this->valor_prefix,
  247. 'database_password' => $clavePass
  248. );
  249. $this->usuario_db_txt = $db_user_params['database_user'];
  250. $this->pass_db_txt = $db_user_params['database_password'];
  251. //print "<pre> USUARIO BBDD "; print_r($db_user_params); print "</pre>\n";
  252. //print "<br>". $this->cli_id;
  253. //print "<br>". $this->usuario_db_txt;
  254. //print "<br>". $this->pass_db_txt;
  255. //print "<pre>"; print_r($fields); print "</pre>\n";
  256. //IMPORTANTE. PARA QUE EL PLUGING FUNCIONE HAY QUE CARGAR ANTES EL FORMULARIO
  257. //DE LO QUE SE QUIERE CREAR EN ESTE CASO BBDD. NO FUNCIONA SE LANZA EL AFTER INSERT EN NUESTRA FUNCION.
  258. $tform_def_file = "../sites/form/database_user.tform.php";
  259. $app->tform->loadFormDef($tform_def_file);
  260. $db_user_id = $remoto->insert_query('../sites/form/database_user.tform.php',
  261. $this->cli_id, $db_user_params, 'sites:web_database_user:on_after_insert');
  262. $global_web_config = $app->getconf->get_server_config($this->web_serv, 'server');
  263. $ip4_bbdd = $global_web_config;
  264. // add database
  265. $paramsBD = array(
  266. 'server_id' => $this->bbdd_serv, //$camDnsRR['server_id'],
  267. 'sysgroup_id' => $this->cli_grupo_id, //$this->sys_grupo_id,
  268. 'parent_domain_id' => $sitio_id['domain_id'],
  269. 'type' => 'mysql',
  270. 'database_quota' => '-1',
  271. 'database_name' => $generated_usernameBBDD,
  272. 'database_name_prefix' => $this->valor_prefix,
  273. 'database_user_id' => $db_user_id,
  274. 'database_charset' => 'utf8',
  275. 'remote_access' => 'y',
  276. 'remote_ips' => $ip4_bbdd['ip_address'], //'-1',
  277. 'active' => 'y'
  278. );
  279. $this->nombre_db_txt = $paramsBD['database_name'];
  280. $db_id = $remoto->sites_database_add($this->cli_id, /*$this->cli_grupo_id,*/ $paramsBD);
  281. $this->urlBBDD($db_id, $this->bbdd_serv);
  282. //echo('Id de la BBDD ' . $db_id);
  283. // get site data para usarlo en la creación de la cuenta ftp, otra forma de cargar una tupla dandole un id
  284. $app->uses('remoting_lib');
  285. $app->remoting_lib->loadFormDef('../sites/form/web_vhost_domain.tform.php');
  286. $site_data = $app->remoting_lib->getDataRecord($sitio_id);
  287. $this->nombre_user_ftp = $this->generaNombreFTP();
  288. // add ftp user
  289. $ftp_params = array(
  290. 'server_id' => $this->web_serv,
  291. 'parent_domain_id' => $sitio_id['domain_id'],
  292. 'username' => $this->valor_prefix_ftp . $this->nombre_user_ftp,
  293. 'username_prefix' => $this->valor_prefix_ftp,
  294. 'password' => $clavePass,
  295. 'quota_size' => '-1',
  296. 'dir' => $site_data['0']['document_root'],
  297. 'uid' => $site_data['0']['system_user'],
  298. 'gid' => $site_data['0']['system_group'],
  299. 'sys_groupid' => $site_data['0']['sys_groupid'],
  300. 'quota_files' => '-1',
  301. 'ul_ratio' => '-1',
  302. 'dl_ratio' => '-1',
  303. 'ul_bandwidth' => '-1',
  304. 'dl_bandwidth' => '-1',
  305. 'active' => 'y',
  306. );
  307. $this->usuario_ftp_txt = $ftp_params['username'];
  308. $this->pass_ftp_txt = $ftp_params['password'];
  309. //print "<pre> FTP "; print_r($ftp_params); print "</pre>\n";
  310. //print "<pre>"; print_r($site_data); print "</pre>\n";
  311. //echo('El grupo del usuario es ' . $this->cli_grupo_id);
  312. $tform_def_file = "../sites/form/ftp_user.tform.php";
  313. $app->tform->loadFormDef($tform_def_file);
  314. $remoto->insert_query('../sites/form/ftp_user.tform.php', $this->cli_id,/*$fields['client_group_id'],*/ $ftp_params);
  315. echo '<br><div class="alert alert-success"><br>
  316. Altas de BBDD y FTP, ¡Correctas!<br><br>
  317. Usuario BBDD: <b>'. $this->usuario_db_txt .'</b><br>Contraseña: <b>' . $this->pass_db_txt . '
  318. </b><br>Nombre BBDD: <b>' . $this->nombre_db_txt . '</b><br>
  319. <br>Usuario FTP: <b>'. $this->usuario_ftp_txt .'</b><br>Contraseña: <b>' . $this->pass_ftp_txt . '</b><br><br>
  320. </div></br>';
  321. //$hoy = date("d-m-Y H:i:s");
  322. $html_resultado = '<br><br><b>BBDD</b><br>
  323. Usuario: <b>'. $this->usuario_db_txt .'</b><br>
  324. Nombre Base de Datos: <b>' . $this->nombre_db_txt .'</b><br>
  325. Clave: <b>' . $this->pass_db_txt . '</b><br><br>
  326. <b>FTP</b><br>
  327. Usuario: <b>'. $this->usuario_ftp_txt .'</b><br>
  328. Clave: <b>' . $this->pass_ftp_txt . '</b><br><br>
  329. <b> </b><br>Nuevo dominio: <b>'. $fields['domain'].'</b><br><br>';
  330. $eldom = $fields['domain'];
  331. //Ahora en dirección ftp para el pdf ponemos el nombre del domino.
  332. $this->ip4_pdf = $eldom;
  333. echo '<form method="post" id="formulario" action="webdns/pdf_o6h.php" target="_blank">';
  334. echo '<input id="pdf_power" name="pdf_power" type="hidden" value="'.$html_resultado.'">';
  335. echo '<input id="nombre_bd" name="nombre_bd" type="hidden" value="'.$this->nombre_db_txt.'">';
  336. echo '<input id="usuario_bd" name="usuario_bd" type="hidden" value="'.$this->usuario_db_txt.'">';
  337. echo '<input id="pass_bd" name="pass_bd" type="hidden" value="'.$this->pass_db_txt.'">';
  338. echo '<input id="usuario_ftp" name="usuario_ftp" type="hidden" value="'.$this->usuario_ftp_txt.'">';
  339. echo '<input id="pass_ftp" name="pass_ftp" type="hidden" value="'.$this->pass_ftp_txt.'">';
  340. echo '<input id="ip4" name="ip4" type="hidden" value="'.$this->ip4_pdf.'">';
  341. echo '<input id="url_db" name="url_db" type="hidden" value="'.$this->url_db.'">';
  342. echo '<input id="dominio_nuevo" name="dominio_nuevo" type="hidden" value="'.$eldom.'">';
  343. echo '<input type="submit" class="btn btn-default formbutton-success" value="Descargar PDF">';
  344. echo '</form>';
  345. echo '<div id="resp"></div>';
  346. }
  347. function urlBBDD($idBBDD, $servidor_id){
  348. global $app, $conf;
  349. $dbData = $app->db->queryOneRecord(
  350. "SELECT server_id, database_name FROM web_database WHERE database_id = ?", $idBBDD);
  351. $serverData = $app->db->queryOneRecord(
  352. "SELECT server_name FROM server WHERE server_id = ?", $servidor_id);
  353. $app->uses('getconf');
  354. $global_config = $app->getconf->get_global_config('sites');
  355. $web_config = $app->getconf->get_server_config($servidor_id, 'web');
  356. //print "<pre>"; print_r($global_config); print "</pre>\n";
  357. //print "<pre>"; print_r($web_config); print "</pre>\n";
  358. if($global_config['phpmyadmin_url'] != '') {
  359. $phpmyadmin_url = $global_config['phpmyadmin_url'];
  360. $phpmyadmin_url = str_replace(array('[SERVERNAME]', '[DATABASENAME]'), array($serverData['server_name'], $dbData['database_name']), $phpmyadmin_url);
  361. //header('Location: '.$phpmyadmin_url);
  362. $this->url_db = $phpmyadmin_url;
  363. //print('la url ' . $phpmyadmin_url);
  364. }
  365. }
  366. //Expresiones regulares para comprobar si es subdominio
  367. function comprobarSubDominios($subdom) {
  368. global $app, $conf;
  369. $patronSubDominos = "/(.*?)\.(.*)$/";
  370. $patronWWW = "/^w{3}/";
  371. //Se comprueba que no tenga 3 w "www" al principio del nombre del dominio o subdomino
  372. $encontradoWWW = preg_match($patronWWW, $subdom, $coincidencias);
  373. if($encontradoWWW){
  374. $app->tform->errorMessage = $app->tform->wordbook['error_dominio_www'];
  375. return;
  376. }
  377. //print "<pre>"; print_r($subdom); print "</pre>\n";
  378. //Si el dominio tiene mas de dos puntos, es incorrecto
  379. if(substr_count($subdom,".") > 2) {
  380. $this->es_subdominio = false;
  381. $this->dominio_error = true;
  382. $app->tform->errorMessage = $app->tform->wordbook['error_dominio_mas_puntos'];
  383. //return;
  384. }else if(substr_count($subdom,".") == 2){
  385. $this->encontrado = preg_match($patronSubDominos, $subdom, $coincidencias);
  386. //print "<pre>"; print_r($coincidencias); print "</pre>\n";
  387. $this->subdominio = $coincidencias[1];
  388. $this->dominio = $coincidencias[2];
  389. $this->es_subdominio = true;
  390. }
  391. return $this->es_subdominio;
  392. }
  393. public $cli_id;
  394. public $cli_grupo_id;
  395. public $sys_usuario_id;
  396. public $sys_grupo_id;
  397. //Control del usuario logeado y captura de sus variables de systema.
  398. function controlUserGrupoId(){
  399. global $app, $conf;
  400. $fields = $app->tform->encode($this->dataRecord, $app->tform->getCurrentTab(), true);
  401. //Captura de los distintos ids del cliente y usuario de sistema.
  402. //combinando un query a las dos tablas sys_group y sys_user que comparten el client_id.
  403. //print "<pre>Seleccionado: "; print_r($fields['client_group_id']); print "</pre>\n";
  404. if($fields['client_group_id']==0) {
  405. //En la tabla sys_user el client_id 0 es admin. En sys_group este valor es 0
  406. $this->cli_id = 0;
  407. $this->cli_grupo_id = 1;
  408. $this->sys_usuario_id = 1;//$this->cli_id;
  409. $this->sys_grupo_id = 0; //$this->cli_grupo_id;//0
  410. //echo('Quien es ' . $_SESSION["s"]["user"]["typ"]);
  411. }else{
  412. //echo('Quien es else ' . $_SESSION["s"]["user"]["typ"]);
  413. $client = $app->db->queryOneRecord(
  414. 'SELECT sys_user.userid, sys_user.sys_userid, sys_user.sys_groupid, sys_user.default_group, sys_user.client_id
  415. FROM sys_group, sys_user
  416. WHERE sys_group.client_id = sys_user.client_id and sys_group.groupid = ?', $fields['client_group_id']);
  417. $this->cli_id = $client['client_id'];
  418. $this->cli_grupo_id = $client['default_group'];
  419. $this->sys_usuario_id = $client['userid'];//$client['sys_userid'];
  420. $this->sys_grupo_id = $this->cli_grupo_id;//$client['sys_groupid'];
  421. //echo('Es cliente cli_id ' . $this->cli_id . ' cli_grupo_id ' . $this->cli_grupo_id . ' sys_usuario ' . $this->sys_usuario_id . ' sys_grupo ' . $this->sys_grupo_id);
  422. }
  423. }
  424. //Crear subdominio
  425. function crearSubDominio($remoto, $campoSubDominio){
  426. global $app, $conf;
  427. $fields = $app->tform->encode($this->dataRecord, $app->tform->getCurrentTab(), true);
  428. //COMO LE PASO EL DOMINIO CORRECTO NO ES NECESARIO PONER EL % EN LA SQL AÑADO EL PUNTO.
  429. //EL PROBLEMA ES QUE CON UN DOMINIO .COM TOMA POR VALIDO UN .CO POR EL %
  430. //NO --> ('SELECT server_id, name FROM dns_rr WHERE name LIKE "'.$this->dominio.'%"');
  431. $existeDominioParaSubDominio = $app->db->queryOneRecord(
  432. 'SELECT server_id, name FROM dns_rr WHERE name LIKE "'.$this->dominio.'."');
  433. // print "<pre>En crearSubDominio campo que se le pasa subdominio es: "; print_r($campoSubDominio); print "</pre>\n";
  434. //Compruebo que el subdominio no existe consultando la tabla web_domain.
  435. $existeSubDominioWeb = $app->db->queryOneRecord(
  436. 'SELECT domain_id, domain FROM web_domain
  437. WHERE domain = "'.$campoSubDominio.'"');
  438. //Compruebo que el subdominio no existe consultando la tabla dns_rr
  439. $existeSubDominioTipoA = $app->db->queryOneRecord(
  440. 'SELECT name, type FROM dns_rr
  441. WHERE name = "'.$campoSubDominio.'" AND type = "A"');
  442. if(!$existeDominioParaSubDominio['name']){
  443. $this->subdom_error = true;
  444. $app->tform->errorMessage = $app->tform->wordbook['error_no_existe_dominio_padre'];
  445. // print "<pre>Error En crearSubDominio campo comprobacion dns_rr es: "; print_r($existeDominioParaSubDominio); print "</pre>\n";
  446. $this->onError();
  447. return;
  448. }
  449. // print "<pre>En crearSubDominio campo comprobacion dns_rr es: "; print_r($existeDominioParaSubDominio); print "</pre>\n";
  450. //print '<pre>El Sub existe '. $existeSubDominio['domain'];
  451. if($existeSubDominioWeb['domain']){
  452. $this->subdom_error = true;
  453. $app->tform->errorMessage = $app->tform->wordbook['error_no_existe_dominio_padre'];
  454. $this->onError();
  455. return $this->subdom_error;
  456. }
  457. if($existeSubDominioTipoA['name']){
  458. $this->subdom_error = true;
  459. $app->tform->errorMessage = $app->tform->wordbook['error_no_existe_dominio_padre'];
  460. $this->onError();
  461. return $this->subdom_error;
  462. }
  463. //$camDominio = $app->db->queryOneRecord('SELECT domain_id, domain FROM domain WHERE domain = "'.$this->dominio.'"');
  464. $camDominio = $app->db->queryOneRecord('SELECT origin FROM dns_soa WHERE origin LIKE "'.$this->dominio.'."');
  465. //$camDominio = $app->db->queryOneRecord('SELECT origin FROM dns_soa WHERE origin LIKE "'.$campoSubDominio.'%"');
  466. $camDnsRR = $app->db->queryOneRecord('SELECT server_id, zone FROM dns_rr WHERE name LIKE "'.$this->dominio.'."');
  467. //Para los registros tipo A la ip tiene que ser tipo IPv4
  468. /* $camServIP = $app->db->queryOneRecord(
  469. "SELECT ip_address FROM server_ip
  470. WHERE server_id = ".$camDnsRR['server_id']." AND ip_type='IPv4'");
  471. */
  472. //print_r($camDominio);
  473. //print_r($camDnsRR);
  474. $this->ip4_ultima = $this->ip4_servidor_dns['ip_address'];
  475. //Si el dominio NO existe mostramos mensaje de error y salimos de la ejecución
  476. if(!$camDominio['origin']){
  477. $this->subdom_error = true;
  478. $app->tform->errorMessage = $app->tform->wordbook['error_no_existe_dominio_padre'];
  479. $this->onError();
  480. return $this->subdom_error;
  481. } else {
  482. //Parametros para la creación de subdominios
  483. $paramSubDominios = array(
  484. 'server_id' => $camDnsRR['server_id'],
  485. 'zone' => $camDnsRR['zone'],
  486. 'name' => $this->subdominio,
  487. 'type' => 'a',
  488. 'data' => $this->ip4_ultima, //$camServIP['ip_address'],
  489. //'aux' => '0',
  490. 'ttl' => '3600',
  491. 'active' => 'y',
  492. //comento el campo stamp, ya que introducia solo ceros en la bbdd
  493. //'stamp' => time(),
  494. 'serial' => '1',
  495. );
  496. //echo ('<br>El client_id GLOBAL ' . $this->cli_id . " <br>");
  497. // client group id
  498. /*$res = $app->db->queryOneRecord("SELECT groupid FROM sys_group WHERE client_id = ".$app->functions->intval($fields['client_group_id']));
  499. $client_group_id = $app->functions->intval($this->dataRecord["client_group_id"]);//$res['groupid'];
  500. echo ('El client group id seleccion ' . $client_group_id . " <br>");
  501. echo ('El groupid de la tabla sys_group ' . $res['groupid'] . " ");*/
  502. //print "<pre>"; print_r($paramSubDominios); print "</pre>\n";
  503. //Inserto en bbdd usando la clase remoto que se la he pasado en parámetros de la función
  504. //$resultado = $remoto->insert_query('../dns/form/dns_a.tform.php', $fields['client_id'], $paramSubDominios);
  505. $resultado = $remoto->insert_query('form/dns_a_webdns.tform.php', $this->cli_id, /*$fields['client_group_id'],*/ $paramSubDominios);
  506. echo '<br><div class="alert alert-success"><br>
  507. Se ha dado de alta Web y Subdominio, <b>'.$this->subdominio.'</b>, ¡Correctamente!
  508. <br><br></div></br>';
  509. //$this->onShow();
  510. }
  511. }
  512. function crearSitioWebSubdominio($remoto){
  513. global $app, $conf;
  514. $fields = $app->tform->encode($this->dataRecord, $app->tform->getCurrentTab(), true);
  515. /* print "<pre>DNS SERVER ";print_r($this->dns_serv);print "</pre>\n";
  516. print "<pre>WEB SERVER ";print_r($this->web_serv);print "</pre>\n";
  517. print "<pre>IP4 DNS ";print_r($this->ip4_servidor_dns);print "</pre>\n";
  518. print "<pre>IP6 DNS ";print_r($this->ip6_servidor_dns);print "</pre>\n";
  519. print "<pre>IP4 WEB ";print_r($this->ip4_servidor_web);print "</pre>\n";
  520. print "<pre>IP6 WEB ";print_r($this->ip6_servidor_web);print "</pre>\n";
  521. print "<pre>IP6 WEB LA OTRA ";print_r($this->ip6_ultima['ip_address']);print "</pre>\n";
  522. */
  523. //add site
  524. $paramsite = array(
  525. //"sys_userid" => $this->sys_usuario_id,
  526. //"sys_groupid" => $this->cli_grupo_id,
  527. 'type' => 'vhost',
  528. 'domain' => $fields['domain'], //$this->subdominio,
  529. 'server_id' => $this->web_serv, //$server_id,
  530. 'ip_address' => '*',
  531. 'ipv6_address' =>$this->ip6_servidor_web['ip_address'],
  532. 'traffic_quota' => '-1',
  533. 'hd_quota' => '0',
  534. 'cgi' => 'y',
  535. 'ssi' => 'y',
  536. 'suexec' => 'y',
  537. 'ruby' => 'n',
  538. 'python' => 'n',
  539. 'perl' => 'n',
  540. 'errordocs' => '1',
  541. 'subdomain' => '',
  542. 'php' => 'php-fpm',
  543. 'fastcgi_php_version' => '',
  544. 'seo_redirect' => '',
  545. 'rewrite_to_https' => 'n',
  546. 'allow_override' => 'All',
  547. 'http_port' => 80,
  548. 'https_port' => 443,
  549. 'apache_directives' => '',
  550. 'nginx_directives' => '',
  551. 'php_fpm_use_socket' => 'y',
  552. 'pm' => 'ondemand',
  553. 'pm_max_children' => 10,
  554. 'pm_start_servers' => 1,
  555. 'pm_min_spare_servers' => 1,
  556. 'pm_max_spare_servers' => 5,
  557. 'pm_process_idle_timeout' => 10,
  558. 'pm_max_requests' => 0,
  559. 'custom_php_ini' => '',
  560. 'active' => 'y',
  561. 'document_root' => '-',
  562. 'system_user' => '-',
  563. 'system_group' => '-',
  564. 'log_retention' => 30,
  565. 'client_group_id' => $this->cli_grupo_id, //$client_group_id,
  566. );
  567. //print "<pre> Parametros:"; print_r($paramsite); print "</pre>\n";
  568. /*print '<pre> cliente id ' . $fields['client_id'];
  569. print "<pre>";print_r($fields);print "</pre>\n" . $fields['client_id'];*/
  570. //print '<pre>DNS IPV6 ' . $dns_ip_servidor_ipv6['ip_address'];
  571. //IMPORTANTE. PARA QUE EL PLUGING FUNCIONE HAY QUE CARGAR ANTES EL FORMULARIO
  572. //DE LO QUE SE QUIERE CREAR EN ESTE CASO SITIO WEB
  573. $tform_def_file = "../sites/form/web_vhost_domain.tform.php";
  574. $app->tform->loadFormDef($tform_def_file);
  575. //El último parámetro es para lanzar un evento que llama a la función on_after_insert que prepara
  576. //los campos document_root, system_user y system_group
  577. //$site_id = $remoto->insert_query('../sites/form/web_vhost_domain.tform.php', $fields['client_group_id'], $paramsite, 'sites:web_vhost_domain:on_after_insert');
  578. $site_id = $remoto->insert_query('../sites/form/web_vhost_domain.tform.php',
  579. $this->cli_id, /*$cliente_id_seleccionado,*/
  580. $paramsite, 'sites:web_vhost_domain:on_after_insert');
  581. //IMPORTANTE. HAY QUE CARGAR EL FORMULARIO DE WEBDNS PARA QUE ENCUENTRE EL TAB.
  582. $tform_def_file = "form/new_service_webdns.tform.php";
  583. $app->tform->loadFormDef($tform_def_file);
  584. }
  585. public $ip4_servidor_dns;
  586. public $ip6_servidor_dns;
  587. public $ip4_servidor_web;
  588. public $ip6_servidor_web;
  589. public $ip4_servidor_bbdd;
  590. public $ip6_servidor_bbdd;
  591. public $ip4_servidor_ftp;
  592. public $ip6_servidor_ftp;
  593. public $dns_serv;
  594. public $web_serv;
  595. public $bbdd_serv;
  596. public $ftp_serv;
  597. function tieneServidorIPs(){
  598. global $app, $conf;
  599. $this->controlUserGrupoId();
  600. $app->uses('getconf');
  601. $global_config_sitio = $app->getconf->get_global_config('sites');
  602. $global_config_dns = $app->getconf->get_global_config('dns');
  603. if(!$global_config_dns['default_dnsserver']) {
  604. $app->tform->errorMessage = $app->tform->wordbook['error_no_servidor_default']. 'DNS.';
  605. $this->onError();
  606. return true;
  607. } else if(!$global_config_sitio['default_webserver']) {
  608. $app->tform->errorMessage = $app->tform->wordbook['error_no_servidor_default']. 'WEB.';
  609. $this->onError();
  610. return true;
  611. } else if(!$global_config_sitio['default_dbserver']) {
  612. $app->tform->errorMessage = $app->tform->wordbook['error_no_servidor_default']. 'DB.';
  613. $this->onError();
  614. return true;
  615. }
  616. //print "<pre>WEB SERVER por defecto ";print_r($global_config_sitio);print "</pre>\n";
  617. //print "<pre>DNS SERVER por defecto ";print_r($global_config_dns);print "</pre>\n";
  618. //El cliente 1 es admin.
  619. //Recupero los servidores asignados por defecto y se los asigno a admin o al usuario
  620. //que no tenga asignado ninguno.
  621. if($this->cli_id == 0) {
  622. $this->dns_serv = $global_config_dns['default_dnsserver'];//1;
  623. $this->web_serv = $global_config_sitio['default_webserver'];//1;
  624. $this->bbdd_serv = $global_config_sitio['default_dbserver'];//1;
  625. $this->ftp_serv = $global_config_sitio['default_webserver'];//1;
  626. //print "<pre>tieneServidorIPs el cli_id "; print_r($this->cli_id . ' el servidor ' . $this->dns_serv); print "</pre>\n";
  627. }else{
  628. $servidores = $app->db->queryOneRecord(
  629. "SELECT client_id, dns_servers, web_servers, db_servers FROM client
  630. WHERE client_id = ". $this->cli_id);
  631. $this->dns_serv = $servidores['dns_servers'];
  632. $this->web_serv = $servidores['web_servers'];
  633. $this->bbdd_serv = $servidores['db_servers'];
  634. //para el ftp el servidor es el mismo que para el sitio web.
  635. $this->ftp_serv = $servidores['web_servers'];
  636. //Si el cliente no tiene asignado un servidor se añade por defecto al que hay en la configuración por defecto
  637. if(!$this->dns_serv){
  638. $this->dns_serv = $global_config_dns['default_dnsserver'];//1;
  639. }
  640. //Si el cliente no tiene asignado un servidor se añade por defecto al que hay en la configuración por defecto
  641. if(!$this->web_serv){
  642. $this->web_serv = $global_config_sitio['default_webserver'];//1;
  643. }
  644. //Si el cliente no tiene asignado un servidor se añade por defecto al que hay en la configuración por defecto
  645. if(!$this->bbdd_serv){
  646. $this->bbdd_serv = $global_config_sitio['default_dbserver'];//1;
  647. }
  648. //Si el cliente no tiene asignado un servidor se añade por defecto al que hay en la configuración por defecto
  649. if(!$this->ftp_serv){
  650. $this->ftp_serv = $global_config_sitio['default_webserver'];//1;
  651. }
  652. }
  653. /*print "<pre>DNS SERVER ";print_r($this->dns_serv);print "</pre>\n";
  654. print "<pre>WEB SERVER ";print_r($this->web_serv);print "</pre>\n";
  655. print "<pre>DB SERVER ";print_r($this->bbdd_serv);print "</pre>\n";
  656. print "<pre>FTP SERVER ";print_r($this->ftp_serv);print "</pre>\n";*/
  657. //Captura de las ips del servidor dns de la variable global para ello.
  658. /* $global_dns_config = $app->getconf->get_server_config($this->dns_serv, 'server');
  659. $this->ip4_servidor_dns = $global_dns_config['ip_address'];
  660. $this->ip6_servidor_dns = $global_dns_config['v6_prefix'];*/
  661. //El cliente 1 es admin
  662. if($this->cli_id == 0){
  663. //Compruebo si hay datos para el client_id 0 y si no existe pruebo con el 1.
  664. //Alguno de los dos tiene que existir por configuración de ispconfig.
  665. $this->ip4_servidor_dns = $app->db->queryOneRecord(
  666. 'SELECT ip_type, ip_address FROM server_ip
  667. WHERE client_id = "0" AND server_id = "'.$this->dns_serv.'" AND ip_type="IPv4"');
  668. $this->ip6_servidor_dns = $app->db->queryOneRecord(
  669. 'SELECT ip_type, ip_address FROM server_ip
  670. WHERE client_id = "0" AND server_id = "'.$this->dns_serv.'" AND ip_type="IPv6"');
  671. /*if(!$this->ip4_servidor_dns){
  672. $this->ip4_servidor_dns = $app->db->queryOneRecord(
  673. 'SELECT ip_type, ip_address FROM server_ip
  674. WHERE client_id = "1" AND server_id = "'.$this->dns_serv.'" AND ip_type="IPv4"');
  675. }*/
  676. /* if(!$this->ip6_servidor_dns){
  677. $this->ip6_servidor_dns = $app->db->queryOneRecord(
  678. 'SELECT ip_type, ip_address FROM server_ip
  679. WHERE client_id = "1" AND server_id = "'.$this->dns_serv.'" AND ip_type="IPv6"');*/
  680. //}
  681. }else{
  682. // $this->ip4_servidor_dns = $global_dns_config['ip_address'];
  683. //Comprobamos si el cliente tiene servidor asignado, si no lo tiene asignamos el que admin a seleccionado
  684. //para este servidor.
  685. $this->ip4_servidor_dns = $app->db->queryOneRecord(
  686. 'SELECT ip_type, ip_address
  687. FROM server_ip
  688. WHERE client_id = "'.$this->cli_id.'" AND server_id = "'.$this->dns_serv.'" AND ip_type="IPv4"');
  689. $this->ip6_servidor_dns = $app->db->queryOneRecord(
  690. 'SELECT ip_type, ip_address
  691. FROM server_ip
  692. WHERE client_id = "'.$this->cli_id.'" AND server_id = "'.$this->dns_serv.'"AND ip_type="IPv6"');
  693. //echo(' la ip6 ' . $this->ip6_ultima);
  694. //si no tiene asignado le damos el de admin.
  695. /* if(!$this->ip4_servidor_dns){
  696. // $this->ip4_servidor_dns = $global_dns_config['ip_address'];
  697. //Compruebo si hay datos para el client_id 0 y si no existe pruebo con el 1. Es admin ya que este cliente no tiene ip4 ni ip6 asignadas
  698. //Tomamos las de admin.
  699. //Alguno de los dos tiene que existir por configuración de ispconfig.
  700. $this->ip4_servidor_dns = $app->db->queryOneRecord(
  701. 'SELECT ip_type, ip_address FROM server_ip
  702. WHERE client_id = "0" AND server_id = "'.$this->dns_serv.'" AND ip_type="IPv4"');
  703. if(!$this->ip4_servidor_dns){
  704. $this->ip4_servidor_dns = $app->db->queryOneRecord(
  705. 'SELECT ip_type, ip_address FROM server_ip
  706. WHERE client_id = "1" AND server_id = "'.$this->dns_serv.'" AND ip_type="IPv4"');
  707. }
  708. }*/
  709. if(!$this->ip6_servidor_dns){
  710. //Compruebo si hay datos para el client_id 0 y si no existe pruebo con el 1. Es admin ya que este cliente no tiene ip4 ni ip6 asignadas
  711. //Tomamos las de admin.
  712. //Alguno de los dos tiene que existir por configuración de ispconfig.
  713. //$this->ip4_servidor_dns = $app->db->queryOneRecord('SELECT ip_type, ip_address FROM server_ip WHERE client_id = "0" AND ip_type="IPv4"');
  714. $this->ip6_servidor_dns = $app->db->queryOneRecord(
  715. 'SELECT ip_type, ip_address FROM server_ip
  716. WHERE client_id = "0" AND server_id = "'.$this->dns_serv.'" AND ip_type="IPv6"');
  717. /*if(!$this->ip6_servidor_dns){
  718. $this->ip6_servidor_dns = $app->db->queryOneRecord(
  719. 'SELECT ip_type, ip_address FROM server_ip
  720. WHERE client_id = "1" AND server_id = "'.$this->dns_serv.'" AND ip_type="IPv6"');
  721. }*/
  722. }
  723. $this->ip6_ultima = $this->ip6_servidor_dns['ip_address'];
  724. }
  725. //Captura de las ips del servidor web
  726. if($this->cli_id == 0){
  727. //Compruebo si hay datos para el client_id 0 y si no existe pruebo con el 1.
  728. //Alguno de los dos tiene que existir por configuración de ispconfig.
  729. $this->ip4_servidor_web = $app->db->queryOneRecord(
  730. 'SELECT ip_type, ip_address FROM server_ip
  731. WHERE client_id = "0" AND server_id = "'.$this->web_serv.'" AND ip_type="IPv4"');
  732. $this->ip6_servidor_web = $app->db->queryOneRecord(
  733. 'SELECT ip_type, ip_address FROM server_ip
  734. WHERE client_id = "0" AND server_id = "'.$this->web_serv.'" AND ip_type="IPv6"');
  735. /*if(!$this->ip4_servidor_web){
  736. $this->ip4_servidor_web = $app->db->queryOneRecord(
  737. 'SELECT ip_type, ip_address FROM server_ip
  738. WHERE client_id = "1" AND server_id = "'.$this->web_serv.'" AND ip_type="IPv4"');
  739. }
  740. if(!$this->ip6_servidor_web){
  741. $this->ip6_servidor_web = $app->db->queryOneRecord(
  742. 'SELECT ip_type, ip_address FROM server_ip
  743. WHERE client_id = "1" AND server_id = "'.$this->web_serv.'" AND ip_type="IPv6"');
  744. }*/
  745. }else{//Comprobamos si el cliente tiene servidor asignado
  746. $this->ip4_servidor_web = $app->db->queryOneRecord(
  747. 'SELECT ip_type, ip_address
  748. FROM server_ip
  749. WHERE client_id = "'.$this->cli_id.'" AND server_id = "'.$this->web_serv.'" AND ip_type="IPv4"');
  750. $this->ip6_servidor_web = $app->db->queryOneRecord(
  751. 'SELECT ip_type, ip_address
  752. FROM server_ip
  753. WHERE client_id = "'.$this->cli_id.'" AND server_id = "'.$this->web_serv.'"AND ip_type="IPv6"');
  754. //si no tiene asignado le damos el de admin.
  755. if(!$this->ip4_servidor_web){
  756. $this->ip4_servidor_web = $app->db->queryOneRecord(
  757. 'SELECT ip_type, ip_address FROM server_ip
  758. WHERE client_id = "0" AND server_id = "'.$this->web_serv.'" AND ip_type="IPv4"');
  759. /*if(!$this->ip4_servidor_web){
  760. $this->ip4_servidor_web = $app->db->queryOneRecord(
  761. 'SELECT ip_type, ip_address FROM server_ip
  762. WHERE client_id = "1" AND server_id = "'.$this->web_serv.'" AND ip_type="IPv4"');
  763. }*/
  764. }
  765. //Cargamos variable para el pdf
  766. $this->ip4_pdf = $this->ip4_servidor_web['ip_address'];
  767. if(!$this->ip6_servidor_web){
  768. $this->ip6_servidor_web = $app->db->queryOneRecord(
  769. 'SELECT ip_type, ip_address FROM server_ip
  770. WHERE client_id = "0" AND server_id = "'.$this->web_serv.'" AND ip_type="IPv6"');
  771. /*if(!$this->ip6_servidor_web){
  772. $this->ip6_servidor_web = $app->db->queryOneRecord(
  773. 'SELECT ip_type, ip_address FROM server_ip
  774. WHERE client_id = "1" AND server_id = "'.$this->web_serv.'" AND ip_type="IPv6"');
  775. }*/
  776. }
  777. }
  778. //Captura de las ips del servidor bbdd
  779. if($this->cli_id == 0){
  780. //Compruebo si hay datos para el client_id 0 y si no existe pruebo con el 1.
  781. //Alguno de los dos tiene que existir por configuración de ispconfig.
  782. $this->ip4_servidor_bbdd = $app->db->queryOneRecord(
  783. 'SELECT ip_type, ip_address FROM server_ip
  784. WHERE client_id = "0" AND server_id = "'.$this->bbdd_serv.'" AND ip_type="IPv4"');
  785. $this->ip6_servidor_bbdd = $app->db->queryOneRecord(
  786. 'SELECT ip_type, ip_address FROM server_ip
  787. WHERE client_id = "0" AND server_id = "'.$this->bbdd_serv.'" AND ip_type="IPv6"');
  788. /*if(!$this->ip4_servidor_bbdd){
  789. $this->ip4_servidor_bbdd = $app->db->queryOneRecord(
  790. 'SELECT ip_type, ip_address FROM server_ip
  791. WHERE client_id = "1" AND server_id = "'.$this->bbdd_serv.'" AND ip_type="IPv4"');
  792. }
  793. if(!$this->ip6_servidor_bbdd){
  794. $this->ip6_servidor_bbdd = $app->db->queryOneRecord(
  795. 'SELECT ip_type, ip_address FROM server_ip
  796. WHERE client_id = "1" AND server_id = "'.$this->bbdd_serv.'" AND ip_type="IPv6"');
  797. }*/
  798. }else{//Comprobamos si el cliente tiene servidor asignado
  799. $this->ip4_servidor_bbdd = $app->db->queryOneRecord(
  800. 'SELECT ip_type, ip_address
  801. FROM server_ip
  802. WHERE client_id = "'.$this->cli_id.'" AND server_id = "'.$this->bbdd_serv.'" AND ip_type="IPv4"');
  803. $this->ip6_servidor_bbdd = $app->db->queryOneRecord(
  804. 'SELECT ip_type, ip_address
  805. FROM server_ip
  806. WHERE client_id = "'.$this->cli_id.'" AND server_id = "'.$this->bbdd_serv.'"AND ip_type="IPv6"');
  807. //echo(' (1) la ip4 bbdd ' . print_r($this->ip4_servidor_bbdd));
  808. //si no tiene asignado le damos el de admin.
  809. if(!$this->ip4_servidor_bbdd){
  810. //Compruebo si hay datos para el client_id 0 y si no existe pruebo con el 1. Es admin ya que este cliente no tiene ip4 ni ip6 asignadas
  811. //Tomamos las de admin.
  812. //Alguno de los dos tiene que existir por configuración de ispconfig.
  813. $this->ip4_servidor_bbdd = $app->db->queryOneRecord(
  814. 'SELECT ip_type, ip_address FROM server_ip
  815. WHERE client_id = "0" AND server_id = "'.$this->bbdd_serv.'" AND ip_type="IPv4"');
  816. //echo(' (2) la ip4 bbdd ' . print_r($this->ip4_servidor_bbdd));
  817. /*if(!$this->ip4_servidor_bbdd){
  818. $this->ip4_servidor_bbdd = $app->db->queryOneRecord(
  819. 'SELECT ip_type, ip_address FROM server_ip
  820. WHERE client_id = "1" AND server_id = "'.$this->bbdd_serv.'" AND ip_type="IPv4"');
  821. }*/
  822. }
  823. if(!$this->ip6_servidor_bbdd){
  824. $this->ip6_servidor_bbdd = $app->db->queryOneRecord(
  825. 'SELECT ip_type, ip_address FROM server_ip
  826. WHERE client_id = "0" AND server_id = "'.$this->bbdd_serv.'" AND ip_type="IPv6"');
  827. /*if(!$this->ip6_servidor_bbdd){
  828. $this->ip6_servidor_bbdd = $app->db->queryOneRecord(
  829. 'SELECT ip_type, ip_address FROM server_ip
  830. WHERE client_id = "1" AND server_id = "'.$this->bbdd_serv.'" AND ip_type="IPv6"');
  831. }*/
  832. }
  833. }
  834. //para el servidor ftp no se hacen comprobaciones
  835. //ya que las ips son las mismas que para el servidor web.
  836. //$la_ip4 = $app->db->queryOneRecord("SELECT ip_type, ip_address FROM server_ip WHERE ip_type='IPv4'");
  837. //$dns_ip_servidor['ip_address'];//$la_ip4['ip_address'];
  838. /*print "<pre>IP4 DNS ";print_r($this->ip4_servidor_dns);print "</pre>\n";
  839. print "<pre>IP6 DNS ";print_r($this->ip6_servidor_dns);print "</pre>\n";
  840. print "<pre>IP4 WEB ";print_r($this->ip4_servidor_web);print "</pre>\n";
  841. print "<pre>IP6 WEB ";print_r($this->ip6_servidor_web);print "</pre>\n";
  842. print "<pre>IP4 BBDD ";print_r($this->ip4_servidor_bbdd);print "</pre>\n";
  843. print "<pre>IP6 BBDD ";print_r($this->ip6_servidor_bbdd);print "</pre>\n";
  844. echo('El cliente ' . $this->cli_id . '<br>');*/
  845. if(!$this->ip4_servidor_dns['ip_address']){
  846. //si no tiene servidor dns en la lista de ips se toma el servidor por defecto web y se usan sus ips
  847. $global_web_config = $app->getconf->get_server_config($this->web_serv, 'server');
  848. $this->ip4_servidor_dns = $global_web_config;
  849. //$this->ip6_servidor_dns = $global_web_config;
  850. /*$servicio_dns = $app->db->queryOneRecord(
  851. 'SELECT server_id, dns_server, server_name FROM server
  852. WHERE server_id = "'.$this->dns_serv.'"');
  853. $nom_serv_dns = $servicio_dns['server_name'];
  854. $app->tform->errorMessage = $app->tform->wordbook['error_no_ip']. 'la IP4 para el servidor ' . $nom_serv_dns;
  855. $this->onError();
  856. return true;*/
  857. }
  858. //Si no tiene ip6 asignada tomamos la del servidor web
  859. if(!$this->ip6_servidor_dns['ip_address']){
  860. $this->ip6_servidor_dns = $app->db->queryOneRecord(
  861. 'SELECT ip_type, ip_address
  862. FROM server_ip
  863. WHERE client_id = "0" AND server_id = "'.$this->web_serv.'"AND ip_type="IPv6"');
  864. //si no tiene servidor dns en la lista de ips se toma el servidor por defecto web y se usan sus ips
  865. // $global_web_config = $app->getconf->get_server_config($this->web_serv, 'server');
  866. //$this->ip4_servidor_dns = $global_web_config;
  867. // $this->ip6_servidor_dns = $global_web_config['v6_prefix'];
  868. // $this->ip6_ultima = $this->ip6_servidor_dns;
  869. //echo(' la ip6 ' . $this->ip6_servidor_dns);
  870. /* $servicio_dns = $app->db->queryOneRecord(
  871. 'SELECT server_id, dns_server, server_name FROM server
  872. WHERE server_id = "'.$this->dns_serv.'"');
  873. $nom_serv_dns = $servicio_dns['server_name'];
  874. $app->tform->errorMessage = $app->tform->wordbook['error_no_ip']. 'la IP6 para el servidor '. $nom_serv_dns;
  875. $this->onError();
  876. return true;*/
  877. }
  878. if(!$this->ip4_servidor_web['ip_address']){
  879. //Si no hay ip4 en la lista de ips, tomamos esta de la configuración principal.
  880. $global_web_config = $app->getconf->get_server_config($this->web_serv, 'server');
  881. $this->ip4_servidor_web = $global_web_config;
  882. //Cargamos variable para el pdf
  883. $this->ip4_pdf = $this->ip4_servidor_web['ip_address'];
  884. if(!$this->ip4_servidor_web['ip_address']){
  885. $servidor_web = $app->db->queryOneRecord(
  886. 'SELECT server_id, web_server, server_name FROM server
  887. WHERE server_id = "'.$this->web_serv.'"');
  888. $nom_serv_web = $servidor_web['server_name'];
  889. $app->tform->errorMessage = $app->tform->wordbook['error_no_ip']. 'la IP4 para el servidor ' . $nom_serv_web;
  890. $this->onError();
  891. return true;
  892. }
  893. }
  894. if(!$this->ip6_servidor_web['ip_address']){
  895. $servidor_web = $app->db->queryOneRecord(
  896. 'SELECT server_id, web_server, server_name FROM server
  897. WHERE server_id = "'.$this->web_serv.'"');
  898. $nom_serv_web = $servidor_web['server_name'];
  899. $app->tform->errorMessage = $app->tform->wordbook['error_no_ip']. 'la IP6 para el servidor ' . $nom_serv_web;
  900. $this->onError();
  901. return true;
  902. }
  903. if(!$this->ip4_servidor_bbdd['ip_address']){
  904. $global_bbdd_config = $app->getconf->get_server_config($this->bbdd_serv, 'server');
  905. $this->ip4_servidor_bbdd = $global_bbdd_config;
  906. //echo(' (3) la ip4 bbdd ' . print_r($this->ip4_servidor_bbdd));
  907. //Como la ip4 para las bbdd es la ip4 para el sitio web, no es necesario esta comprobación
  908. /* if(!$this->ip4_servidor_bbdd['ip_address']){
  909. $servicio_db = $app->db->queryOneRecord(
  910. 'SELECT server_id, db_server, server_name FROM server
  911. WHERE server_id = "'.$this->bbdd_serv.'"');
  912. $nom_serv_db = $servicio_db['server_name'];
  913. $app->tform->errorMessage = $app->tform->wordbook['error_no_ip']. 'la IP4 para el servidor ' . $nom_serv_db;
  914. $this->onError();
  915. return true;
  916. }*/
  917. }
  918. /* if(!$this->ip6_servidor_bbdd['ip_address']){
  919. /* $servicio_db = $app->db->queryOneRecord(
  920. 'SELECT server_id, db_server, server_name FROM server
  921. WHERE server_id = "'.$this->bbdd_serv.'"');
  922. $nom_serv_db = $servicio_db['server_name'];
  923. $app->tform->errorMessage = $app->tform->wordbook['error_no_ip']. 'la IP6 para el servidor ' . $nom_serv_db;
  924. $this->onError();
  925. return true;
  926. }*/
  927. return false;
  928. }
  929. //Comprueba si los servidores asignados al usuario seleccionado tiene los servicios activos para cada caso.
  930. function servidoresActivados(){
  931. global $app, $conf;
  932. $servicio_web = $app->db->queryOneRecord(
  933. 'SELECT server_id, web_server, server_name FROM server
  934. WHERE server_id = "'.$this->web_serv.'"');
  935. $nom_serv_web = $servicio_web['server_name'];
  936. $servicio_dns = $app->db->queryOneRecord(
  937. 'SELECT server_id, dns_server, server_name FROM server
  938. WHERE server_id = "'.$this->dns_serv.'"');
  939. $nom_serv_dns = $servicio_dns['server_name'];
  940. $servicio_ftp = $app->db->queryOneRecord(
  941. 'SELECT server_id, file_server, server_name FROM server
  942. WHERE server_id = "'.$this->ftp_serv.'"');
  943. $nom_serv_ftp = $servicio_ftp['server_name'];
  944. $servicio_db = $app->db->queryOneRecord(
  945. 'SELECT server_id, db_server, server_name FROM server
  946. WHERE server_id = "'.$this->bbdd_serv.'"');
  947. $nom_serv_db = $servicio_db['server_name'];
  948. //print "<pre>Servidor WEB ";print_r($servicio_web);print "</pre>\n";
  949. if($servicio_web['web_server'] == 0){
  950. $app->tform->errorMessage = $app->tform->wordbook['error_activado_servidor'] . $nom_serv_web . ' el servicio WEB.';
  951. $this->onError();
  952. return true;
  953. }
  954. //print "<pre>Servidor DNS ";print_r($servicio_dns);print "</pre>\n";
  955. if($servicio_dns['dns_server'] == 0){
  956. $app->tform->errorMessage = $app->tform->wordbook['error_activado_servidor'] . $nom_serv_dns . ' el servicio DNS.';
  957. $this->onError();
  958. return true;
  959. }
  960. //print "<pre>Servidor FTP ";print_r($servicio_ftp);print "</pre>\n";
  961. if($servicio_ftp['file_server'] == 0){
  962. $app->tform->errorMessage = $app->tform->wordbook['error_activado_servidor'] . $nom_serv_ftp . ' el servicio FTP.';
  963. $this->onError();
  964. return true;
  965. }
  966. //print "<pre>Servidor DB ";print_r($servicio_db);print "</pre>\n";
  967. if($servicio_db['db_server'] == 0){
  968. $app->tform->errorMessage = $app->tform->wordbook['error_activado_servidor'] . $nom_serv_db . ' el servicio DB.';
  969. $this->onError();
  970. return true;
  971. }
  972. return false;
  973. }
  974. //Comprobación de que tenemos instalada nuestra plantilla
  975. function plantillaWebDNS(){
  976. global $app;
  977. if(!$app->db->queryOneRecord("SELECT name FROM dns_template WHERE name = 'webdns'")) {
  978. $app->tform->errorMessage = $app->tform->wordbook['error_plantilla_webdns'];
  979. $this->onError();
  980. return true;
  981. }
  982. }
  983. //Comprueba que no exista el dominio y que no tenga sitio web, puede tener sitio web y no tener dns.
  984. function existeDominio($campos){
  985. global $app, $conf;
  986. if($app->db->queryOneRecord('SELECT * FROM dns_soa WHERE origin LIKE "'.$campos['domain'].'."')) {
  987. $app->tform->errorMessage = $app->tform->wordbook['domain_error_unique'];
  988. }
  989. if($app->db->queryOneRecord('SELECT domain_id, domain FROM web_domain WHERE domain = "'.$campos['domain'].'"')) {
  990. $app->tform->errorMessage = $app->tform->wordbook['error_sitio_web_existe'];
  991. }
  992. //IMPORTANTE. AQUI CONTROLAMOS LOS ERRORES QUE SE VALIDAN EN EL FORMULARIO, EN ESTE CASO EL CAMPO DEL DOMINIO.
  993. if($app->tform->errorMessage)
  994. {
  995. $this->onError();
  996. return true;
  997. }
  998. }
  999. public $ip4_ultima;
  1000. public $ip6_ultima;
  1001. //Creación del las dns y sitio web para un dominio.
  1002. function crearDnsSitioWeb($remoto){
  1003. global $app, $conf;
  1004. $remote = new remote_actions;
  1005. //Carga de los campos del formulario.
  1006. $fields = $app->tform->encode($this->dataRecord, $app->tform->getCurrentTab(), true);
  1007. //Carga del formulario dns_soa para guardar en base de datos.
  1008. $tform_def_file = "../dns/form/dns_soa.tform.php";
  1009. $app->tform->loadFormDef($tform_def_file);
  1010. //Carga y seleccion de dns_template, si no esta creado se informa de que tiene que crearse.
  1011. $template_record = $app->db->queryOneRecord(
  1012. "SELECT * FROM dns_template WHERE visible = 'Y' AND name = 'webdns'"); /*'open6hosting'");*/
  1013. /*print "<pre>DNS SERVER ";print_r($this->dns_serv);print "</pre>\n";
  1014. print "<pre>WEB SERVER ";print_r($this->web_serv);print "</pre>\n";
  1015. print "<pre>IP4 DNS ";print_r($this->ip4_servidor_dns);print "</pre>\n";
  1016. print "<pre>IP6 DNS ";print_r($this->ip6_servidor_dns);print "</pre>\n";
  1017. print "<pre>IP4 WEB ";print_r($this->ip4_servidor_web);print "</pre>\n";
  1018. print "<pre>IP6 WEB ";print_r($this->ip6_servidor_web);print "</pre>\n";*/
  1019. //Si el servidor es el que tiene asignado el cliente o el de admin por defecto, le damos esta ip4
  1020. //if($this->dns_serv && $this->ip4_servidor_dns){
  1021. $this->ip4_ultima = $this->ip4_servidor_dns['ip_address'];
  1022. //}
  1023. //echo(' ips ' . $this->ip4_ultima . ' ip4dns ' . $this->ip4_servidor_dns);
  1024. //if($this->dns_serv && $this->ip6_servidor_dns){
  1025. $this->ip6_ultima = $this->ip6_servidor_dns['ip_address'];
  1026. //}
  1027. //echo(' ip4 ' . $this->ip4_ultima['ip_address'] . ' ip6 ' . $this->ip6_ultima);
  1028. //if($this->web_serv && $this->ip4_servidor_web){
  1029. //$this->ip4_ultima = $this->ip4_servidor_dns;//$this->ip4_servidor_web;
  1030. //}
  1031. //if($this->web_serv && $this->ip6_servidor_web){
  1032. //$this->ip6_ultima = $this->ip4_servidor_dns;//$this->ip6_servidor_web;
  1033. //}
  1034. $tpl_content = $template_record['template'];
  1035. // Reemplazo la variable que nos encontramos en base de datos por el valor que se ha introducido en el formulario
  1036. $tpl_content = str_replace('{DOMAIN}', $fields['domain'], $tpl_content);
  1037. //Carga de los datos en las variables de las ips.
  1038. $tpl_content = str_replace('{IP}', $this->ip4_ultima, $tpl_content);
  1039. $tpl_content = str_replace('{IPV6}', $this->ip6_ultima, $tpl_content);
  1040. $enable_dnssec = 'N';
  1041. // Parse the template
  1042. $tpl_rows = explode("\n", $tpl_content);
  1043. $section = '';
  1044. $vars = array();
  1045. $vars['xfer']='';
  1046. $dns_rr = array();
  1047. foreach($tpl_rows as $row) {
  1048. $row = trim($row);
  1049. if(substr($row, 0, 1) == '[') {
  1050. if($row == '[ZONE]') {
  1051. $section = 'zone';
  1052. } elseif($row == '[DNS_RECORDS]') {
  1053. $section = 'dns_records';
  1054. } else {
  1055. die('Unknown section type');
  1056. }
  1057. } else {
  1058. if($row != '') {
  1059. // Handle zone section
  1060. if($section == 'zone') {
  1061. $parts = explode('=', $row);
  1062. $key = trim($parts[0]);
  1063. $val = trim($parts[1]);
  1064. if($key != '') $vars[$key] = $val;
  1065. }
  1066. // Handle DNS Record rows
  1067. if($section == 'dns_records') {
  1068. $parts = explode('|', $row);
  1069. $dns_rr[] = array(
  1070. 'name' => $parts[1],
  1071. 'type' => $parts[0],
  1072. 'data' => $parts[2],
  1073. 'aux' => $parts[3],
  1074. 'ttl' => $parts[4]
  1075. );
  1076. }
  1077. }
  1078. }
  1079. } // end foreach
  1080. // Insert the soa record
  1081. $sys_userid = $this->cli_id;
  1082. $origin = $vars['origin'];
  1083. $ns = $vars['ns'];
  1084. $mbox = str_replace('@', '.', $vars['mbox']);
  1085. $refresh = $vars['refresh'];
  1086. $retry = $vars['retry'];
  1087. $expire = $vars['expire'];
  1088. $minimum = $vars['minimum'];
  1089. $ttl = $vars['ttl'];
  1090. $xfer = $vars['xfer'];
  1091. $also_notify = $vars['also_notify'];
  1092. $update_acl = $vars['update_acl'];
  1093. $serial = $app->validate_dns->increase_serial(0);
  1094. $insert_data = array(
  1095. "sys_userid" => $this->sys_usuario_id,//$sysUsuarioId,//$fields['client_group_id'],
  1096. "sys_groupid" => $this->cli_grupo_id,//$cliente_groupid,//$client_group_id,
  1097. "sys_perm_user" => 'riud',
  1098. "sys_perm_group" => 'riud',
  1099. "sys_perm_other" => '',
  1100. "server_id" => $this->dns_serv,
  1101. "origin" => $origin,
  1102. "ns" => $ns,
  1103. "mbox" => $mbox,
  1104. "serial" => $serial,
  1105. "refresh" => $refresh,
  1106. "retry" => $retry,
  1107. "expire" => $expire,
  1108. "minimum" => $minimum,
  1109. "ttl" => $ttl,
  1110. "active" => 'Y',
  1111. "xfer" => $xfer,
  1112. "also_notify" => $also_notify,
  1113. "update_acl" => $update_acl,
  1114. "dnssec_wanted" => $enable_dnssec
  1115. );
  1116. $dns_soa_id = $app->db->datalogInsert('dns_soa', $insert_data, 'id');
  1117. // Insert the dns_rr records
  1118. if(is_array($dns_rr) && $dns_soa_id > 0) {
  1119. foreach($dns_rr as $rr) {
  1120. $insert_data = array(
  1121. "sys_userid" => $this->sys_usuario_id,//$sysUsuarioId, //$fields['client_group_id'],
  1122. "sys_groupid" => $this->cli_grupo_id,//$cliente_groupid, //$client_group_id,
  1123. "sys_perm_user" => 'riud',
  1124. "sys_perm_group" => 'riud',
  1125. "sys_perm_other" => '',
  1126. "server_id" => $this->dns_serv,
  1127. "zone" => $dns_soa_id,
  1128. "name" => $rr['name'],
  1129. "type" => $rr['type'],
  1130. "data" => $rr['data'],
  1131. "aux" => $rr['aux'],
  1132. "ttl" => $rr['ttl'],
  1133. "active" => 'Y'
  1134. );
  1135. $dns_rr_id = $app->db->datalogInsert('dns_rr', $insert_data, 'id');
  1136. }
  1137. }
  1138. //sites_web_domain_add
  1139. $tform_def_file = "../sites/form/web_vhost_domain.tform.php";
  1140. $app->tform->loadFormDef($tform_def_file);
  1141. //print_r($fields);
  1142. //echo('La sesión user id ' . $_SESSION['s']['user']['userid']);
  1143. // add site
  1144. $paramsite = array(
  1145. 'type' => 'vhost',
  1146. 'domain' => $fields['domain'],
  1147. 'server_id' => $this->web_serv,// $web_servidor, //$server_id,//$dns_servidor['default_webserver'],
  1148. //IMPORTANTE. Aquí­ no se ponen los campos sys_userid ni sys_groupid, el evento on_after_insert
  1149. //'sys_userid' => $sysUsuarioId, //$fields['client_group_id'],//$sys_userid,
  1150. //'sys_groupid' => $cliente_groupid,
  1151. 'ip_address' => '*', //$dns_ip_servidor['ip_address'],
  1152. 'ipv6_address' => $this->ip6_servidor_web['ip_address'],
  1153. 'traffic_quota' => '-1',
  1154. 'hd_quota' => '0',
  1155. 'cgi' => 'y',
  1156. 'ssi' => 'y',
  1157. 'suexec' => 'y',
  1158. 'ruby' => 'n',
  1159. 'python' => 'n',
  1160. 'perl' => 'n',
  1161. 'errordocs' => '1',
  1162. 'subdomain' => 'www',
  1163. 'php' => 'php-fpm',
  1164. 'fastcgi_php_version' => '',
  1165. 'seo_redirect' => '',
  1166. 'rewrite_to_https' => 'n',
  1167. 'allow_override' => 'All',
  1168. 'http_port' => 80,
  1169. 'https_port' => 443,
  1170. 'apache_directives' => '',
  1171. 'nginx_directives' => '',
  1172. 'php_fpm_use_socket' => 'y',
  1173. 'pm' => 'ondemand',
  1174. 'pm_max_children' => 10,
  1175. 'pm_start_servers' => 1,
  1176. 'pm_min_spare_servers' => 1,
  1177. 'pm_max_spare_servers' => 5,
  1178. 'pm_process_idle_timeout' => 10,
  1179. 'pm_max_requests' => 0,
  1180. 'custom_php_ini' => '',
  1181. 'active' => 'y',
  1182. 'document_root' => '-',
  1183. 'system_user' => '-',
  1184. 'system_group' => '-',
  1185. 'log_retention' => 30,
  1186. 'client_group_id' => $this->cli_grupo_id,//$cliente_groupid, //$client_group_id,
  1187. );
  1188. //print 'Valores: ' . $dns_ip_servidor_ipv6 . " " . $formulario . " Parametros: " ;
  1189. //print "<pre>"; print_r($paramsite); print "</pre>\n";
  1190. /*print '<pre> cliente id ' . $fields['client_id'];
  1191. print "<pre>";print_r($fields);print "</pre>\n";*/
  1192. //print "<pre>Formulario ";print_r($formulario);print "</pre>\n";
  1193. //$this->crearBaseDatosFtp($remote);
  1194. //print 'DNS IPV6 ' . $dns_ip_servidor_ipv6['ip_address'];
  1195. //IMPORTANTE. El último parámetro es para lanzar un evento que llama a la función on_after_insert
  1196. //que prepara los campos document_root, system_user y system_group
  1197. //$site_id = $remoto->insert_query('../sites/form/web_vhost_domain.tform.php', $fields['client_group_id'], $paramsite, 'sites:web_vhost_domain:on_after_insert');
  1198. //IMPORTANTE. ESTE ES EL ÚNICO PLUGING QUE FUNCIONA.
  1199. $site_id = $remoto->insert_query('../sites/form/web_vhost_domain.tform.php',
  1200. $this->cli_id, /*$cliente_id_seleccionado,*/
  1201. $paramsite, 'sites:web_vhost_domain:on_after_insert');
  1202. //print 'Sitio id '. $site_id;
  1203. }
  1204. function onSubmit() {
  1205. global $app, $conf;
  1206. if($this->plantillaWebDNS()){
  1207. return;
  1208. }
  1209. //Carga de campos del formulario.
  1210. $fields = $app->tform->encode($this->dataRecord, $app->tform->getCurrentTab(), true);
  1211. //Creo la clase remote para usar las librerias
  1212. $remote = new remote_actions;
  1213. if($this->tieneServidorIPs()){
  1214. return;
  1215. }
  1216. if($this->servidoresActivados()){
  1217. return;
  1218. }
  1219. if($this->existeDominio($fields)){
  1220. return;
  1221. }
  1222. //Esta variable nos llega por jQuery desde el htm para el control de errores en la vista.
  1223. if($_POST['create'] != 1)
  1224. {
  1225. $app->tform->errorMessage = 'DUMMY';
  1226. $app->tpl->setVar($this->dataRecord);
  1227. $this->onShow();
  1228. return;
  1229. }
  1230. if($this->comprobarSubDominios($fields['domain'])){
  1231. $this->crearSubDominio($remote, $fields['domain']);
  1232. if(!$this->subdom_error){
  1233. $this->crearSitioWebSubdominio($remote);
  1234. $this->crearBaseDatosFtp($remote);
  1235. }
  1236. } else {
  1237. if(!$this->dominio_error){
  1238. $this->crearDnsSitioWeb($remote);
  1239. //Si todo va bien, el resultado de la web y dns
  1240. echo '<br><div class="alert alert-success"><br>
  1241. Altas Web y DNS del dominio <b>'.$fields['domain'].'</b>, ¡Creadas correctamente!
  1242. <br><br></div></br>';
  1243. //IMPORTANTE, es necesario cargar nuestro formulario para poder ejecutar la función que crea
  1244. //la base de datos y el ftp ya que hay datos que tomamos de el antes de ejecutarla.
  1245. $app->tform->loadFormDef('form/new_service_webdns.tform.php');
  1246. $this->crearBaseDatosFtp($remote);
  1247. }else{
  1248. $this->onError();
  1249. return;
  1250. }
  1251. }
  1252. }
  1253. }
  1254. class remote_actions extends remoting {
  1255. public function insert_query($formdef_file, $client_id, $params, $event_identifier = '') {
  1256. return $this->insertQuery($formdef_file, $client_id, $params, $event_identifier);
  1257. }
  1258. public function sites_database_add($client_id, $params){
  1259. global $app, $conf;
  1260. //$app->remoting_lib->loadFormDef('../sites/form/database.tform.php');
  1261. //$app->tform->formDef('../sites/form/database.tform.php');
  1262. $sql = $this->insertQueryPrepare('../sites/form/database.tform.php', $client_id, $params);
  1263. if($sql !== false) {
  1264. $app->uses('sites_database_plugin');
  1265. //print_r($sql);
  1266. $this->id = 0;
  1267. $this->dataRecord = $params;
  1268. //$app->uses('sites_database_plugin');
  1269. $app->sites_database_plugin->processDatabaseInsert($this);
  1270. $retval = $this->insertQueryExecute($sql, $params);
  1271. // set correct values for backup_interval and backup_copies
  1272. if(isset($params['backup_interval']) || isset($params['backup_copies'])){
  1273. $sql_set = array();
  1274. if(isset($params['backup_interval'])) $sql_set[] = "backup_interval = '".$app->db->quote($params['backup_interval'])."'";
  1275. if(isset($params['backup_copies'])) $sql_set[] = "backup_copies = ".$app->functions->intval($params['backup_copies']);
  1276. //$app->db->query("UPDATE web_database SET ".implode(', ', $sql_set)." WHERE database_id = ".$retval);
  1277. $this->updateQueryExecute("UPDATE web_database SET ".implode(', ', $sql_set)." WHERE database_id = ".$retval, $retval, $params);
  1278. }
  1279. return $retval;
  1280. }
  1281. return false;
  1282. }
  1283. }
  1284. $page = new page_action;
  1285. $page->onLoad();
  1286. //IMPORTENTE, es necesario estas lí­neas para que el botón del pdf funcione. Activa el javascript
  1287. //echo '<script type="text/javascript">';
  1288. //echo '</script>';
  1289. ?>
  1290. <!--IMPORTENTE, es necesario estas lí­neas para que el botón del pdf funcione. Activa el javascript -->
  1291. <script type="text/javascript">
  1292. </script>