ISPConfig module for simplify the creation of websites and DNS zones in a only step
No puede seleccionar más de 25 temas Los temas deben comenzar con una letra o número, pueden incluir guiones ('-') y pueden tener hasta 35 caracteres de largo.
 
 
 
 

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