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.
 
 
 
 

1649 líneas
70 KiB

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