ISPConfig module for simplify the creation of websites and DNS zones in a only step
Du kannst nicht mehr als 25 Themen auswählen Themen müssen entweder mit einem Buchstaben oder einer Ziffer beginnen. Sie können Bindestriche („-“) enthalten und bis zu 35 Zeichen lang sein.
 
 
 
 

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