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

1180 lines
46 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 $no_ip = false;
  152. //Campos para PDF
  153. public $usuario_db_txt;
  154. public $nombre_db_txt;
  155. public $pass_db_txt;
  156. public $usuario_ftp_txt;
  157. public $pass_ftp_txt;
  158. public $nombre_user_ftp;
  159. function generaNombreFTP(){
  160. global $app, $conf, $interfaceConf;
  161. //* Database username shall not be empty
  162. //if($this->dataRecord['database_user'] == '') $app->tform->errorMessage .= $app->tform->wordbook["database_user_error_empty"].'<br />';
  163. //* Database password shall not be empty
  164. //if($this->dataRecord['database_password'] == '') $app->tform->errorMessage .= $app->tform->wordbook["database_password_error_empty"].'<br />';
  165. //* Get the database name and database user prefix
  166. $app->uses('getconf,tools_sites');
  167. $global_config = $app->getconf->get_global_config('sites');
  168. $dbuser_prefix = $app->tools_sites->replacePrefix($global_config['dbuser_prefix'], $this->dataRecord);
  169. $dbuser_prefix_valor = $app->tpl->setVar("database_name", $app->tools_sites->removePrefix($this->dataRecord['database_name'], $this->dataRecord['database_name_prefix'], $dbname_prefix));
  170. //echo ('El prefix de los cohone ' . $dbuser_prefix);
  171. $this->dataRecord['database_user_prefix'] = $dbuser_prefix_valor;
  172. //echo ('PreFIX ' . '{user}' . str_replace('{user}', htmlentities($dbuser_prefix . $this->dataRecord['database_user'], ENT_QUOTES, 'UTF-8')));
  173. if(strlen($dbuser_prefix . $this->dataRecord['database_user']) > 16)
  174. $app->tform->errorMessage .= str_replace('{user}', htmlentities($dbuser_prefix . $this->dataRecord['database_user'], ENT_QUOTES, 'UTF-8'),
  175. $app->tform->wordbook["database_user_error_len"]).'<br />';
  176. //* Check database user against blacklist
  177. $dbuser_blacklist = array($conf['db_user'], 'mysql', 'root');
  178. if(is_array($dbuser_blacklist) && in_array($dbuser_prefix . $this->dataRecord['database_user'], $dbuser_blacklist)) {
  179. $app->tform->errorMessage .= $app->lng('Database user not allowed.').'<br />';
  180. }
  181. /* restrict the names */
  182. /* crop user names if they are too long -> mysql: user: 16 chars / db: 64 chars */
  183. if ($app->tform->errorMessage == ''){
  184. $this->dataRecord['database_user'] = substr($dbuser_prefix . $this->dataRecord['database_user'], 0, 16);
  185. }
  186. $this->dataRecord['server_id'] = 0; // we need this on all servers
  187. $this->tratarVariablesHTML();
  188. //echo ('PreFIX Valor ' . $dbuser_prefix_valor);
  189. //Cadena de caractares para construir las nombre.
  190. $cadena = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ23456789";
  191. //$cadSpeciales = "!@#_";
  192. //Obtengo la longitud de las cadenas
  193. $longitudCadena=strlen($cadena);
  194. //$longSpeciales = strlen($cadSpeciales);
  195. //Variable para la nombre
  196. $nombre = "";
  197. //Longitud para la nombre
  198. $longitudNombre=8;
  199. //Creo la nombre
  200. for($i=1 ; $i<=$longitudNombre ; $i++){
  201. //Número aleatorio entre 0 y la longitud de la cadena de caracteres-1
  202. $pos=rand(0,$longitudCadena-1);
  203. //Formo la nombre en cada iteraccion del bucle, añadiendo a la cadena $nombre
  204. //la letra correspondiente a la posicion $pos en la cadena de caracteres definida.
  205. $nombre .= substr($cadena,$pos,1);
  206. }
  207. return $nombre;//$this->valor_prefix_ftp;
  208. }
  209. function generaPass(){
  210. //Cadena de caractares para construir las password.
  211. $cadena = "abcdefghijklmnopqrstuvwxyz!@#_ABCDEFGHIJKLMNOPQRSTUVWXYZ23456789";
  212. $cadSpeciales = "!@#_";
  213. //Obtengo la longitud de las cadenas
  214. $longitudCadena=strlen($cadena);
  215. $longSpeciales = strlen($cadSpeciales);
  216. //Variable para la password
  217. $pass = "";
  218. //Longitud para la password
  219. $longitudPass=13;
  220. //Creo la password
  221. for($i=1 ; $i<=$longitudPass ; $i++){
  222. //Número aleatorio entre 0 y la longitud de la cadena de caracteres-1
  223. $pos=rand(0,$longitudCadena-1);
  224. //Formo la password en cada iteraccion del bucle, añadiendo a la cadena $pass
  225. //la letra correspondiente a la posicion $pos en la cadena de caracteres definida.
  226. $pass .= substr($cadena,$pos,1);
  227. //Añado algún caracter especial en los últimos cuatro caracteres
  228. for($i2=13;$i2<=$i; $i2++){
  229. $poSpecial=rand(0,$longSpeciales-1);
  230. $pass .= substr($cadSpeciales, $poSpecial, 1);
  231. }
  232. }
  233. return $pass;
  234. }
  235. function generaNombreBD(){
  236. global $app, $conf, $interfaceConf;
  237. //* Database username shall not be empty
  238. //if($this->dataRecord['database_user'] == '') $app->tform->errorMessage .= $app->tform->wordbook["database_user_error_empty"].'<br />';
  239. //* Database password shall not be empty
  240. //if($this->dataRecord['database_password'] == '') $app->tform->errorMessage .= $app->tform->wordbook["database_password_error_empty"].'<br />';
  241. //* Get the database name and database user prefix
  242. $app->uses('getconf,tools_sites');
  243. $global_config = $app->getconf->get_global_config('sites');
  244. $dbuser_prefix = $app->tools_sites->replacePrefix($global_config['dbuser_prefix'], $this->dataRecord);
  245. $dbuser_prefix_valor = $app->tpl->setVar("database_name", $app->tools_sites->removePrefix($this->dataRecord['database_name'], $this->dataRecord['database_name_prefix'], $dbname_prefix));
  246. //echo ('El prefix de los cohone ' . $dbuser_prefix);
  247. $this->dataRecord['database_user_prefix'] = $dbuser_prefix_valor;
  248. //echo ('PreFIX ' . '{user}' . str_replace('{user}', htmlentities($dbuser_prefix . $this->dataRecord['database_user'], ENT_QUOTES, 'UTF-8')));
  249. if(strlen($dbuser_prefix . $this->dataRecord['database_user']) > 16)
  250. $app->tform->errorMessage .= str_replace('{user}', htmlentities($dbuser_prefix . $this->dataRecord['database_user'], ENT_QUOTES, 'UTF-8'),
  251. $app->tform->wordbook["database_user_error_len"]).'<br />';
  252. //* Check database user against blacklist
  253. $dbuser_blacklist = array($conf['db_user'], 'mysql', 'root');
  254. if(is_array($dbuser_blacklist) && in_array($dbuser_prefix . $this->dataRecord['database_user'], $dbuser_blacklist)) {
  255. $app->tform->errorMessage .= $app->lng('Database user not allowed.').'<br />';
  256. }
  257. /* restrict the names */
  258. /* crop user names if they are too long -> mysql: user: 16 chars / db: 64 chars */
  259. if ($app->tform->errorMessage == ''){
  260. $this->dataRecord['database_user'] = substr($dbuser_prefix . $this->dataRecord['database_user'], 0, 16);
  261. }
  262. $this->dataRecord['server_id'] = 0; // we need this on all servers
  263. $this->tratarVariablesHTML();
  264. //echo ('PreFIX Valor ' . $dbuser_prefix_valor);
  265. //Cadena de caractares para construir las nombre.
  266. $cadena = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ23456789";
  267. //$cadSpeciales = "!@#_";
  268. //Obtengo la longitud de las cadenas
  269. $longitudCadena=strlen($cadena);
  270. //$longSpeciales = strlen($cadSpeciales);
  271. //Variable para la nombre
  272. $nombre = "";
  273. //Longitud para la nombre
  274. $longitudNombre=8;
  275. //Creo la nombre
  276. for($i=1 ; $i<=$longitudNombre ; $i++){
  277. //Número aleatorio entre 0 y la longitud de la cadena de caracteres-1
  278. $pos=rand(0,$longitudCadena-1);
  279. //Formo la nombre en cada iteraccion del bucle, añadiendo a la cadena $nombre
  280. //la letra correspondiente a la posicion $pos en la cadena de caracteres definida.
  281. $nombre .= substr($cadena,$pos,1);
  282. }
  283. return $this->valor_prefix . $nombre;
  284. }
  285. /*function comprobarPass($claveGenerada){
  286. //compruebo que el tamaño del string sea válido.
  287. if (strlen($claveGenerada)<3 || strlen($claveGenerada)>20){
  288. echo $claveGenerada . " no es válida0<br>";
  289. return false;
  290. }
  291. //compruebo que los caracteres sean los permitidos
  292. $alphachars = "abcdefghijkmnopqrstuvwxyz";
  293. $upperchars = "ABCDEFGHJKLMNPQRSTUVWXYZ";
  294. $numchars = "23456789";
  295. $specialchars = "!@#_";
  296. //$permitidos = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789-_";
  297. if (ereg("^[a-zA-Z0-9\-_]{3,20}$", $claveGenerada)) {
  298. echo $claveGenerada . " es válido<br>";
  299. return true;
  300. } else {
  301. echo $claveGenerada . " NO válido<br>";
  302. return false;
  303. }
  304. echo $claveGenerada . " es válido<br>";
  305. return true;
  306. }*/
  307. function crearBaseDatosFtp($remoto){
  308. global $app, $conf;
  309. $fields = $app->tform->encode($this->dataRecord, $app->tform->getCurrentTab(), true);
  310. $app->uses('ini_parser,getconf');
  311. $server_config_array = $app->getconf->get_global_config();
  312. //Tomo el valor mínimo de dígitos que tiene que tener la contraseña
  313. $min_password_length = 10;
  314. //if(isset($server_config_array['misc']['min_password_length'])) {
  315. $min_password_length = $app->functions->intval($server_config_array['misc']['min_password_length']);
  316. //}
  317. //print "Cantidad de digitos: " . $min_password_length;
  318. //print 'La clave ' . $this->generaPass();
  319. $generated_usernameBBDD = $this->generaNombreBD();//$fields['client_id'].substr(sha1(rand()), 0, 10);//client_prefix.substr(sha1(rand()), 0, 8);
  320. //print "<pre>"; print_r($generated_usernameBBDD); print "</pre>\n";
  321. $sitio_id = $app->db->queryOneRecord('SELECT domain_id, domain FROM web_domain WHERE domain = "'.$fields['domain'].'"');
  322. //print "<pre>"; print_r($camDnsRR); print "</pre>\n";
  323. $camDnsRR = $app->db->queryOneRecord('SELECT server_id, zone FROM dns_rr WHERE name LIKE "'.$this->dominio.'%"');
  324. //print "<pre>"; print_r($fields['client_id']); print "</pre>\n";
  325. $clavePass = $this->generaPass();
  326. //*Recupero todos los prefix necesarios
  327. $app->uses('getconf,tools_sites');
  328. $global_config = $app->getconf->get_global_config('sites');
  329. //$dbuser_prefix = $app->tools_sites->replacePrefix($global_config['dbuser_prefix'], $this->dataRecord);
  330. //$dbname_prefix = $app->tools_sites->replacePrefix($global_config['dbname_prefix'], $this->dataRecord);
  331. $ftpuser_prefix = $app->tools_sites->replacePrefix($global_config['ftpuser_prefix'], $this->dataRecord);
  332. // añado database user con su prefix
  333. $db_user_params = array(
  334. 'server_id' => $camDnsRR['server_id'],
  335. 'sysgroup_id' => $fields['client_group_id'],
  336. 'sys_userid' => $fields['client_group_id'],
  337. 'database_user' => $generated_usernameBBDD, //$dbuser_prefix3 . $generated_usernameBBDD,
  338. 'database_user_prefix' => $this->valor_prefix,
  339. 'database_password' => $clavePass//substr(sha1($dbuser_prefix . $generated_usernameBBDD), 0, 16)
  340. //substr(sha1(rand()), 0, 20)
  341. );
  342. $this->usuario_db_txt = $db_user_params['database_user'];
  343. $this->pass_db_txt = $db_user_params['database_password'];
  344. //print "<pre>"; print_r($db_user_params); print "</pre>\n";
  345. //print "<br>". $this->usuario_db_txt;
  346. //print "<br>". $this->pass_db_txt;
  347. //print "<pre>"; print_r($fields); print "</pre>\n";
  348. $db_user_id = $remoto->insert_query('../sites/form/database_user.tform.php', $fields['client_group_id'], $db_user_params, 'sites:web_database_user:on_after_insert');
  349. // add database
  350. $paramsBD = array(
  351. 'server_id' => $camDnsRR['server_id'],
  352. 'sysgroup_id' => $fields['client_group_id'],
  353. 'parent_domain_id' => $sitio_id['domain_id'],
  354. 'type' => 'mysql',
  355. 'database_quota' => '-1',
  356. 'database_name' => $generated_usernameBBDD, //$dbuser_prefix3 . $generated_usernameBBDD,//$db_user_params['database_user'],
  357. 'database_name_prefix' => $this->valor_prefix,
  358. 'database_user_id' => $db_user_id,
  359. 'database_charset' => 'utf8',
  360. 'remote_access' => 'n',
  361. 'remote_ips' => '-1',
  362. 'active' => 'y'
  363. );
  364. //print "<pre>"; print_r($paramsBD); print "</pre>\n";
  365. //print "<pre>"; print_r($fields); print "</pre>\n";
  366. $this->nombre_db_txt = $paramsBD['database_name'];
  367. $remoto->sites_database_add($fields['client_group_id'], $paramsBD);
  368. // get site data para usarlo en la creación de la cuenta ftp, otra forma de cargar una tupla dandole un id
  369. //$app->uses('remoting_lib');
  370. $app->remoting_lib->loadFormDef('../sites/form/web_vhost_domain.tform.php');
  371. $site_data = $app->remoting_lib->getDataRecord($sitio_id);
  372. $this->nombre_user_ftp = $this->generaNombreFTP();
  373. // add ftp user
  374. $ftp_params = array(
  375. 'server_id' => $camDnsRR['server_id'],
  376. 'parent_domain_id' => $sitio_id['domain_id'],
  377. 'username' => $this->valor_prefix_ftp . $this->nombre_user_ftp, //$ftpuser_prefix . $generated_username,
  378. 'username_prefix' => $this->valor_prefix_ftp,
  379. 'password' => $clavePass,//substr(sha1(rand()), 0, 10),
  380. 'quota_size' => '-1',
  381. 'dir' => $site_data['0']['document_root'],
  382. 'uid' => $site_data['0']['system_user'],
  383. 'gid' => $site_data['0']['system_group'],
  384. 'sys_groupid' => $site_data['0']['sys_groupid'],
  385. 'quota_files' => '-1',
  386. 'ul_ratio' => '-1',
  387. 'dl_ratio' => '-1',
  388. 'ul_bandwidth' => '-1',
  389. 'dl_bandwidth' => '-1',
  390. 'active' => 'y',
  391. );
  392. $this->usuario_ftp_txt = $ftp_params['username'];
  393. $this->pass_ftp_txt = $ftp_params['password'];
  394. //print "<pre>"; print_r($ftp_params); print "</pre>\n";
  395. //print "<pre>"; print_r($site_data); print "</pre>\n";
  396. //echo('El usuario es ' . $fields['client_group_id']);
  397. $remoto->insert_query('../sites/form/ftp_user.tform.php', $fields['client_group_id'], $ftp_params);
  398. echo '<br><div class="alert alert-success"><br>
  399. Altas de BBDD y FTP, ¡Correctas!<br><br>
  400. Usuario BBDD: <b>'. $this->usuario_db_txt .'</b><br>Contraseña: <b>' . $this->pass_db_txt . '
  401. </b><br>Nombre BBDD: <b>' . $this->nombre_db_txt . '</b><br>
  402. <br>Usuario FTP: <b>'. $this->usuario_ftp_txt .'</b><br>Contraseña: <b>' . $this->pass_ftp_txt . '</b><br><br>
  403. </div></br>';
  404. $hoy = date("d-m-Y H:i:s");
  405. $html_resultado = '<br><br><b>BBDD</b><br>
  406. Usuario: <b>'. $this->usuario_db_txt .'</b><br>
  407. Nombre Base de Datos: <b>' . $this->nombre_db_txt .'</b><br>
  408. Clave: <b>' . $this->pass_db_txt . '</b><br><br>
  409. <b>FTP</b><br>
  410. Usuario: <b>'. $this->usuario_ftp_txt .'</b><br>
  411. Clave: <b>' . $this->pass_ftp_txt . '</b><br><br>
  412. <b> </b><br>
  413. Nuevo dominio: <b>'. $fields['domain'].'</b><br><br>
  414. Documento generado: <b>' . $hoy . '</b><br><br>';
  415. $eldom = $fields['domain'];
  416. echo '<form method="post" id="formulario" action="webdns/pdf_o6h.php" target="_blank">';
  417. echo '<input id="pdf_power" name="pdf_power" type="hidden" value="'.$html_resultado.'">';
  418. echo '<input id="nombre_bd" name="nombre_bd" type="hidden" value="'.$this->nombre_db_txt.'">';
  419. echo '<input id="usuario_bd" name="usuario_bd" type="hidden" value="'.$this->usuario_db_txt.'">';
  420. echo '<input id="pass_bd" name="pass_bd" type="hidden" value="'.$this->pass_db_txt.'">';
  421. echo '<input id="usuario_ftp" name="usuario_ftp" type="hidden" value="'.$this->usuario_ftp_txt.'">';
  422. echo '<input id="pass_ftp" name="pass_ftp" type="hidden" value="'.$this->pass_ftp_txt.'">';
  423. echo '<input id="dominio_nuevo" name="dominio_nuevo" type="hidden" value="'.$eldom.'">';
  424. echo '<input type="submit" class="btn btn-default formbutton-success" value="Descargar PDF">';
  425. echo '</form>';
  426. echo '<div id="resp"></div>';
  427. }
  428. //Expresiones regulares para comprobar si es subdominio
  429. function comprobarSubDominios($subdom) {
  430. global $app, $conf;
  431. $patronSubDominos = "/(.*?)\.(.*)$/";
  432. $patronWWW = "/^w{3}/";
  433. //$patronPunto = '/(\.)/';
  434. /*$patronP1 = '/(^\.)/';
  435. $patronP2 = '/(\.$)/';
  436. $patronP3 = '/(\.\.+)/';
  437. $patronP4 = '/(\.[[:alpha:]]*)$/';*/
  438. //Se comprueba que no tenga 3 w "www" al principio del nombre del dominio o subdomino
  439. $encontradoWWW = preg_match($patronWWW, $subdom, $coincidencias);
  440. if($encontradoWWW){
  441. $app->tform->errorMessage = $app->tform->wordbook['error_dominio_www'];
  442. return;
  443. }
  444. //Si el dominio tiene mas de dos puntos, es incorrecto
  445. if (substr_count($subdom,".") > 2) {
  446. $app->tform->errorMessage = $app->tform->wordbook['error_dominio_mas_puntos'];
  447. return;
  448. } else if(substr_count($subdom,".") == 2){
  449. $this->encontrado = preg_match($patronSubDominos, $subdom, $coincidencias);
  450. //print "<pre>"; print_r($coincidencias); print "</pre>\n";
  451. $this->subdominio = $coincidencias[1];
  452. $this->dominio = $coincidencias[2];
  453. //print "Subdomino: " . $this->subdomino . "</p>\n Dominio: " . $this->domino;
  454. $this->es_subdominio = true;
  455. }
  456. //print "<pre>El dominio es: " . $this->dominio;
  457. return $this->es_subdominio;
  458. }
  459. //Crear subdominio
  460. function crearSubDominio($remoto, $campoSubDominio){
  461. //para usar variables globales en las funciones hay que declararlas dentro de la funcion.
  462. global $app, $conf;
  463. $fields = $app->tform->encode($this->dataRecord, $app->tform->getCurrentTab(), true);
  464. //print "<pre>"; print_r($campoSubDominio); print "</pre>\n";
  465. //Compruebo que el subdominio no existe consultando la tabla web_domain.
  466. $existeSubDominio = $app->db->queryOneRecord('SELECT domain_id, domain FROM web_domain WHERE domain = "'.$campoSubDominio.'"');
  467. //print '<pre>El Sub existe '. $existeSubDominio['domain'];
  468. if($existeSubDominio){
  469. $this->subdom_error = true;
  470. $app->tform->errorMessage = $app->tform->wordbook['error_subdominio_existe'];
  471. $this->onError();
  472. return;
  473. }
  474. //print "<pre>El dominio es: " . $this->dominio;
  475. //$camDominio = $app->db->queryOneRecord('SELECT domain_id, domain FROM domain WHERE domain = "'.$this->dominio.'"');
  476. $camDominio = $app->db->queryOneRecord('SELECT origin FROM dns_soa WHERE origin LIKE "'.$this->dominio.'%"');
  477. $camDnsRR = $app->db->queryOneRecord('SELECT server_id, zone FROM dns_rr WHERE name LIKE "'.$this->dominio.'%"');
  478. $camServIP = $app->db->queryOneRecord('SELECT ip_address FROM server_ip WHERE server_id = "'.$camDnsRR['server_id'].'"');
  479. //print_r($camDominio);
  480. //print_r($camDnsRR);
  481. //Si el dominio NO existe mostramos mensaje de error y salimos de la ejecución
  482. if(!$camDominio['origin']){
  483. $this->subdom_error = true;
  484. $app->tform->errorMessage = $app->tform->wordbook['error_no_existe_dominio_padre'];
  485. $this->onError();
  486. //return;
  487. //print 'No existe el dominio';
  488. return $this->subdom_error;
  489. } else {
  490. //Parametros para la creación de subdominios
  491. $paramSubDominios = array(
  492. 'server_id' => $camDnsRR['server_id'],
  493. 'zone' => $camDnsRR['zone'],
  494. 'name' => $this->subdominio,
  495. 'type' => 'a',
  496. 'data' => $camServIP['ip_address'],
  497. //'aux' => '0',
  498. 'ttl' => '3600',
  499. 'active' => 'y',
  500. //comento el campo stamp, ya que introducia solo ceros en la bbdd
  501. //'stamp' => time(),
  502. 'serial' => '1',
  503. );
  504. //print "<pre>"; print_r($paramSubDominios); print "</pre>\n";
  505. //$remote = new remote_actions;
  506. //Inserto en bbdd usando la clase remoto que se la he pasado en parámetros de la función
  507. //$resultado = $remoto->insert_query('../dns/form/dns_a.tform.php', $fields['client_id'], $paramSubDominios);
  508. $resultado = $remoto->insert_query('form/dns_a_webdns.tform.php', $fields['client_group_id'], $paramSubDominios);
  509. echo '<br><div class="alert alert-success"><br>
  510. Se ha dado de alta Web y Subdominio, <b>'.$this->subdominio.'</b>, ¡Correctamente!
  511. <br><br></div></br>';
  512. //$this->onShow();
  513. }
  514. }
  515. function crearSitioWebSubdominio($remoto){
  516. global $app, $conf;
  517. $fields = $app->tform->encode($this->dataRecord, $app->tform->getCurrentTab(), true);
  518. //Captura del servidor id
  519. if($this->id > 0) {
  520. $server_id = $this->dataRecord["server_id"];
  521. } else {
  522. // Get the first server ID
  523. $tmp = $app->db->queryOneRecord("SELECT server_id FROM server WHERE web_server = 1 ORDER BY server_name LIMIT 0,1");
  524. $server_id = $tmp['server_id'];
  525. //$this->elServidor = $server_id;
  526. }
  527. $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'");
  528. //Comprobamos que el resultado para el cliente seleccionado no esta vacío,
  529. //si lo esta tomamos los datos del cliente id 0
  530. if(!$dns_ip_servidor_ipv6){
  531. $dns_ip_servidor = $app->db->queryOneRecord("SELECT ip_type, ip_address FROM server_ip WHERE client_id = 1 AND ip_type='IPv4'");
  532. $dns_ip_servidor_ipv6 = $app->db->queryOneRecord("SELECT ip_type, ip_address FROM server_ip WHERE client_id = 1 AND ip_type='IPv6'");
  533. /*echo '<br><br>Valor de la consulta '.$dns_ip_servidor_ipv6[ip_address].' ';
  534. echo '<br><br>Valor de la consulta '.$dns_ip_servidor[ip_address].' ';*/
  535. }
  536. $dns_servidor = $app->db->queryOneRecord("SELECT client_id, default_dnsserver, default_webserver FROM client WHERE client_id = ".$app->functions->intval($fields['client_group_id']));
  537. $clienteID = $dns_servidor['client_id'];
  538. $res = $app->db->queryOneRecord("SELECT groupid FROM sys_group WHERE client_id = ".$app->functions->intval($fields['client_group_id']));
  539. $client_group_id = $res['groupid'];
  540. //Captura del servidor id
  541. if($this->id > 0) {
  542. $server_id = $this->dataRecord["server_id"];
  543. } else {
  544. // Get the first server ID
  545. $tmp = $app->db->queryOneRecord("SELECT server_id FROM server WHERE web_server = 1 ORDER BY server_name LIMIT 0,1");
  546. $server_id = $tmp['server_id'];
  547. //$this->elServidor = $server_id;
  548. }
  549. //echo ('El server es: ' . $dns_servidor['default_webserver']);
  550. // add site
  551. $paramsite = array(
  552. 'type' => 'vhost',
  553. 'domain' => $fields['domain'], //$this->subdominio,
  554. 'server_id' => $server_id,//$dns_servidor['default_webserver'],
  555. 'ip_address' => '*', //$dns_ip_servidor['ip_address'],
  556. 'ipv6_address' => $dns_ip_servidor_ipv6['ip_address'],
  557. 'traffic_quota' => '-1',
  558. 'hd_quota' => '0',
  559. 'cgi' => 'y',
  560. 'ssi' => 'y',
  561. 'suexec' => 'y',
  562. 'ruby' => 'n',
  563. 'python' => 'n',
  564. 'perl' => 'n',
  565. 'errordocs' => '1',
  566. 'subdomain' => '',
  567. 'php' => 'php-fpm',
  568. 'fastcgi_php_version' => '',
  569. 'seo_redirect' => '',
  570. 'rewrite_to_https' => 'n',
  571. 'allow_override' => 'All',
  572. 'http_port' => 80,
  573. 'https_port' => 443,
  574. 'apache_directives' => '',
  575. 'nginx_directives' => '',
  576. 'php_fpm_use_socket' => 'y',
  577. 'pm' => 'ondemand',
  578. 'pm_max_children' => 10,
  579. 'pm_start_servers' => 1,
  580. 'pm_min_spare_servers' => 1,
  581. 'pm_max_spare_servers' => 5,
  582. 'pm_process_idle_timeout' => 10,
  583. 'pm_max_requests' => 0,
  584. 'custom_php_ini' => '',
  585. 'active' => 'y',
  586. 'document_root' => '-',
  587. 'system_user' => '-',
  588. 'system_group' => '-',
  589. 'log_retention' => 30,
  590. 'client_group_id' => $client_group_id,
  591. );
  592. //$app->uses('remoting_lib');
  593. //$formulario = $app->remoting_lib->loadFormDef('../sites/form/web_vhost_domain.tform.php');
  594. //$formulario = $app->tform->loadFormDef('../sites/form/web_vhost_domain.tform.php');
  595. //print 'Valores: ' . $dns_ip_servidor_ipv6;
  596. //print "<pre> Parametros:"; print_r($paramsite); print "</pre>\n";
  597. /*print '<pre> cliente id ' . $fields['client_id'];
  598. print "<pre>";print_r($fields);print "</pre>\n" . $fields['client_id'];*/
  599. //print "<pre>Formulario ";print_r($formulario);print "</pre>\n";
  600. //print '<pre>DNS IPV6 ' . $dns_ip_servidor_ipv6['ip_address'];
  601. //$tform_def_file2 = "../sites/form/web_vhost_domain.tform.php";
  602. //$app->tform->loadFormDef($tform_def_file2);
  603. //El último parámetro es para lanzar un evento que llama a la función on_after_insert que prepara los campos document_root, system_user y system_group
  604. $site_id = $remoto->insert_query('../sites/form/web_vhost_domain.tform.php', $fields['client_group_id'], $paramsite, 'sites:web_vhost_domain:on_after_insert');
  605. //print '<pre>ID sitio web del subdominio --> ' . $site_id;
  606. }
  607. function tieneIPs(){
  608. global $app, $conf;
  609. //$fields = $app->tform->encode($this->dataRecord, $app->tform->getCurrentTab(), true);
  610. //Llamada a la tabla server_ip para recuperar la ip4 e ip6
  611. $dns_ip_servidor = $app->db->queryOneRecord("SELECT ip_type, ip_address FROM server_ip WHERE ip_type='IPv4'");
  612. $dns_ip_servidor_ipv6 = $app->db->queryOneRecord("SELECT ip_type, ip_address FROM server_ip WHERE ip_type='IPv6'");
  613. /*print "<pre>IP4 ";print_r($dns_ip_servidor);print "</pre>\n";
  614. print "<pre>IP6 ";print_r($dns_ip_servidor_ipv6);print "</pre>\n";*/
  615. if(!$dns_ip_servidor['ip_address'] || !$dns_ip_servidor_ipv6['ip_address']){
  616. $app->tform->errorMessage = $app->tform->wordbook['error_no_ip'];
  617. $this->onError();
  618. return true;
  619. }
  620. return false;
  621. }
  622. //Comprueba que no exista el dominio y que no tenga sitio web, puede tener sitio web y no tener dns.
  623. function existeDominio($campos){
  624. global $app, $conf;
  625. if($app->db->queryOneRecord('SELECT * FROM dns_soa WHERE origin LIKE "'.$campos['domain'].'%"')) {
  626. $app->tform->errorMessage = $app->tform->wordbook['domain_error_unique'];
  627. }
  628. if($app->db->queryOneRecord('SELECT domain_id, domain FROM web_domain WHERE domain = "'.$campos['domain'].'"')) {
  629. $app->tform->errorMessage = $app->tform->wordbook['error_sitio_web_existe'];
  630. }
  631. if($app->tform->errorMessage)
  632. {
  633. $this->onError();
  634. return true;
  635. }
  636. }
  637. function crearSitioDns($remoto){
  638. global $app, $conf;
  639. //Carga de campos del formulario.
  640. $fields = $app->tform->encode($this->dataRecord, $app->tform->getCurrentTab(), true);
  641. //Captura del servidor id
  642. if($this->id > 0) {
  643. $server_id = $this->dataRecord["server_id"];
  644. } else {
  645. // Get the first server ID
  646. $tmp = $app->db->queryOneRecord("SELECT server_id FROM server WHERE web_server = 1 ORDER BY server_name LIMIT 0,1");
  647. $server_id = $tmp['server_id'];
  648. //$this->elServidor = $server_id;
  649. }
  650. //Este if lo he tomado de onAfterInsert del web_domain
  651. /*if($_SESSION["s"]["user"]["typ"] == 'admin' && isset($this->dataRecord["client_group_id"])) {
  652. $client_group_id = $app->functions->intval($this->dataRecord["client_group_id"]);
  653. $app->db->query("UPDATE web_domain SET sys_groupid = ?, sys_perm_group = 'ru' WHERE domain_id = ?", $client_group_id, $this->id);
  654. }*/
  655. // client group id
  656. $res = $app->db->queryOneRecord("SELECT groupid FROM sys_group WHERE client_id = ".$app->functions->intval($fields['client_group_id']));
  657. $client_group_id = $app->functions->intval($this->dataRecord["client_group_id"]);//$res['groupid'];
  658. echo ('El group id ' . $client_group_id . " ");
  659. //Carga del formulario dns_soa para guardar en base de datos
  660. $tform_def_file = "../dns/form/dns_soa.tform.php";
  661. $app->tform->loadFormDef($tform_def_file);
  662. // Carga y seleccion de dns_template, si no esta creado se informa de que tiene que crearse
  663. $template_record = $app->db->queryOneRecord("SELECT * FROM dns_template WHERE visible = 'Y' AND name = 'webdns'"); /*'open6hosting'");*/
  664. //Llamada a la tabla server_ip para recuperar la ip4 e ip6
  665. //$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'"));
  666. //PROVISIONAL
  667. $dns_ip_servidor = $app->db->queryOneRecord("SELECT ip_type, ip_address FROM server_ip WHERE client_id = 1 AND ip_type='IPv4'");
  668. //$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'");
  669. //PROVISIONAL
  670. $dns_ip_servidor_ipv6 = $app->db->queryOneRecord("SELECT ip_type, ip_address FROM server_ip WHERE client_id = 1 AND ip_type='IPv6'");
  671. //$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'");
  672. //Comprobamos que el resultado para el cliente seleccionado no esta vacío,
  673. //si lo esta tomamos los datos del cliente id 0
  674. if(!$dns_ip_servidor_ipv6){
  675. $dns_ip_servidor = $app->db->queryOneRecord("SELECT ip_type, ip_address FROM server_ip WHERE client_id = 0 AND ip_type='IPv4'");
  676. $dns_ip_servidor_ipv6 = $app->db->queryOneRecord("SELECT ip_type, ip_address FROM server_ip WHERE client_id = 0 AND ip_type='IPv6'");
  677. /*echo '<br><br>Valor de la consulta '.$dns_ip_servidor_ipv6[ip_address].' ';
  678. echo '<br><br>Valor de la consulta '.$dns_ip_servidor[ip_address].' ';*/
  679. }
  680. $tpl_content = $template_record['template'];
  681. // Reemplazo la variable que nos encontramos en base de datos por el valor que se ha introducido en el formulario
  682. $tpl_content = str_replace('{DOMAIN}', $fields['domain'], $tpl_content);
  683. //Carga de los datos en las variables ns
  684. $tpl_content = str_replace('{IP}', $dns_ip_servidor['ip_address'], $tpl_content);
  685. $tpl_content = str_replace('{IPV6}', $dns_ip_servidor_ipv6['ip_address'], $tpl_content);
  686. /*$tpl_content = str_replace('{NS1}', '.open6servers.com', $tpl_content);
  687. $tpl_content = str_replace('{NS2}', '.open6servers.com', $tpl_content); */
  688. $enable_dnssec = 'N';//(($_POST['dns_dnssec'] == 'Y') ? 'Y' : 'N');
  689. // Parse the template
  690. $tpl_rows = explode("\n", $tpl_content);
  691. $section = '';
  692. $vars = array();
  693. $vars['xfer']='';
  694. $dns_rr = array();
  695. foreach($tpl_rows as $row) {
  696. $row = trim($row);
  697. if(substr($row, 0, 1) == '[') {
  698. if($row == '[ZONE]') {
  699. $section = 'zone';
  700. } elseif($row == '[DNS_RECORDS]') {
  701. $section = 'dns_records';
  702. } else {
  703. die('Unknown section type');
  704. }
  705. } else {
  706. if($row != '') {
  707. // Handle zone section
  708. if($section == 'zone') {
  709. $parts = explode('=', $row);
  710. $key = trim($parts[0]);
  711. $val = trim($parts[1]);
  712. if($key != '') $vars[$key] = $val;
  713. }
  714. // Handle DNS Record rows
  715. if($section == 'dns_records') {
  716. $parts = explode('|', $row);
  717. $dns_rr[] = array(
  718. 'name' => $parts[1],
  719. 'type' => $parts[0],
  720. 'data' => $parts[2],
  721. 'aux' => $parts[3],
  722. 'ttl' => $parts[4]
  723. );
  724. }
  725. }
  726. }
  727. } // end foreach
  728. //Llamada a la tabla client para recuperar el client_id y su default_dnsserver
  729. $dns_servidor = $app->db->queryOneRecord("SELECT client_id, default_dnsserver, default_webserver FROM client WHERE client_id = ".$app->functions->intval($fields['client_group_id']));
  730. $valor_recuperado1 = $dns_servidor['client_id'];
  731. /*$valor_recuperado2 = $dns_servidor['default_dnsserver'];
  732. $valor_recuperado3 = $dns_servidor['default_webserver'];*/
  733. // Insert the soa record
  734. $sys_userid = $fields['client_group_id']; //$_SESSION['s']['user']['userid'];
  735. $origin = $vars['origin'];
  736. $ns = $vars['ns'];
  737. $mbox = str_replace('@', '.', $vars['mbox']);
  738. $refresh = $vars['refresh'];
  739. $retry = $vars['retry'];
  740. $expire = $vars['expire'];
  741. $minimum = $vars['minimum'];
  742. $ttl = $vars['ttl'];
  743. $xfer = $vars['xfer'];
  744. $also_notify = $vars['also_notify'];
  745. $update_acl = $vars['update_acl'];
  746. $serial = $app->validate_dns->increase_serial(0);
  747. $insert_data = array(
  748. "sys_userid" => $fields['client_group_id'],//$sys_userid,
  749. "sys_groupid" => $client_group_id,
  750. "sys_perm_user" => 'riud',
  751. "sys_perm_group" => 'riud',
  752. "sys_perm_other" => '',
  753. "server_id" => $server_id,//$dns_servidor['default_dnsserver'],
  754. "origin" => $origin,
  755. "ns" => $ns,
  756. "mbox" => $mbox,
  757. "serial" => $serial,
  758. "refresh" => $refresh,
  759. "retry" => $retry,
  760. "expire" => $expire,
  761. "minimum" => $minimum,
  762. "ttl" => $ttl,
  763. "active" => 'Y',
  764. "xfer" => $xfer,
  765. "also_notify" => $also_notify,
  766. "update_acl" => $update_acl,
  767. "dnssec_wanted" => $enable_dnssec
  768. );
  769. $dns_soa_id = $app->db->datalogInsert('dns_soa', $insert_data, 'id');
  770. // Insert the dns_rr records
  771. if(is_array($dns_rr) && $dns_soa_id > 0) {
  772. foreach($dns_rr as $rr) {
  773. $insert_data = array(
  774. "sys_userid" => $fields['client_group_id'],//$sys_userid,
  775. "sys_groupid" => $client_group_id,
  776. "sys_perm_user" => 'riud',
  777. "sys_perm_group" => 'riud',
  778. "sys_perm_other" => '',
  779. "server_id" => $server_id,//$dns_servidor['default_dnsserver'],
  780. "zone" => $dns_soa_id,
  781. "name" => $rr['name'],
  782. "type" => $rr['type'],
  783. "data" => $rr['data'],
  784. "aux" => $rr['aux'],
  785. "ttl" => $rr['ttl'],
  786. "active" => 'Y'
  787. );
  788. $dns_rr_id = $app->db->datalogInsert('dns_rr', $insert_data, 'id');
  789. }
  790. }
  791. //sites_web_domain_add
  792. $tform_def_file = "../sites/form/web_vhost_domain.tform.php";
  793. $app->tform->loadFormDef($tform_def_file);
  794. print_r($fields);
  795. //echo('La sesión user id ' . $_SESSION['s']['user']['userid']);
  796. // add site
  797. $paramsite = array(
  798. 'type' => 'vhost',
  799. 'domain' => $fields['domain'],
  800. 'server_id' => $server_id,//$dns_servidor['default_webserver'],
  801. 'sys_userid' => $fields['client_group_id'],//$sys_userid,
  802. 'sys_groupid' => $client_group_id,
  803. 'ip_address' => '*', //$dns_ip_servidor['ip_address'],
  804. 'ipv6_address' => $dns_ip_servidor_ipv6['ip_address'],
  805. 'traffic_quota' => '-1',
  806. 'hd_quota' => '0',
  807. 'cgi' => 'y',
  808. 'ssi' => 'y',
  809. 'suexec' => 'y',
  810. 'ruby' => 'n',
  811. 'python' => 'n',
  812. 'perl' => 'n',
  813. 'errordocs' => '1',
  814. 'subdomain' => 'www',
  815. 'php' => 'php-fpm',
  816. 'fastcgi_php_version' => '',
  817. 'seo_redirect' => '',
  818. 'rewrite_to_https' => 'n',
  819. 'allow_override' => 'All',
  820. 'http_port' => 80,
  821. 'https_port' => 443,
  822. 'apache_directives' => '',
  823. 'nginx_directives' => '',
  824. 'php_fpm_use_socket' => 'y',
  825. 'pm' => 'ondemand',
  826. 'pm_max_children' => 10,
  827. 'pm_start_servers' => 1,
  828. 'pm_min_spare_servers' => 1,
  829. 'pm_max_spare_servers' => 5,
  830. 'pm_process_idle_timeout' => 10,
  831. 'pm_max_requests' => 0,
  832. 'custom_php_ini' => '',
  833. 'active' => 'y',
  834. 'document_root' => '-',
  835. 'system_user' => '-',
  836. 'system_group' => '-',
  837. 'log_retention' => 30,
  838. 'client_group_id' => $client_group_id,
  839. );
  840. //print 'Valores: ' . $dns_ip_servidor_ipv6 . " " . $formulario . " Parametros: " ;
  841. print "<pre>"; print_r($paramsite); print "</pre>\n";
  842. /*print '<pre> cliente id ' . $fields['client_id'];
  843. print "<pre>";print_r($fields);print "</pre>\n";*/
  844. //print "<pre>Formulario ";print_r($formulario);print "</pre>\n";
  845. //$this->crearBaseDatosFtp($remote);
  846. //print 'DNS IPV6 ' . $dns_ip_servidor_ipv6['ip_address'];
  847. //El último parámetro es para lanzar un evento que llama a la función on_after_insert que prepara los campos document_root, system_user y system_group
  848. $site_id = $remoto->insert_query('../sites/form/web_vhost_domain.tform.php', $fields['client_group_id'], $paramsite, 'sites:web_vhost_domain:on_after_insert');
  849. //print 'Sitio id '. $site_id;
  850. }
  851. function onSubmit() {
  852. global $app, $conf;
  853. //Carga de campos del formulario.
  854. $fields = $app->tform->encode($this->dataRecord, $app->tform->getCurrentTab(), true);
  855. //Creo la clase remote para usar las librerias
  856. $remote = new remote_actions;
  857. if($this->tieneIPs()){
  858. return;
  859. }
  860. if($this->existeDominio($fields)){
  861. return;
  862. }
  863. //Esta variable nos llega por jQuery desde el htm para el control de errores en la vista.
  864. if($_POST['create'] != 1)
  865. {
  866. $app->tform->errorMessage = 'DUMMY';
  867. $app->tpl->setVar($this->dataRecord);
  868. $this->onShow();
  869. return;
  870. }
  871. if($this->comprobarSubDominios($fields['domain'])){
  872. $this->crearSubDominio($remote, $fields['domain']);
  873. if(!$this->subdom_error){
  874. $this->crearSitioWebSubdominio($remote);
  875. $this->crearBaseDatosFtp($remote);
  876. }
  877. } else {
  878. $this->crearSitioDns($remote);
  879. //$variablePHP = "<script> document.write(test) </script>";
  880. //Si todo va bien, el resultado de la web y dns
  881. echo '<br><div class="alert alert-success"><br>
  882. Altas Web y DNS del dominio <b>'.$fields['domain'].'</b>, ¡Creadas correctamente!
  883. <br><br></div></br>';
  884. //IMPORTANTE, es necesario cargar nuestro formulario para poder ejecutar la función que crea
  885. //la base de datos y el ftp ya que hay datos que tomamos de él antes de ejecutarla.
  886. $app->tform->loadFormDef('form/new_service_webdns.tform.php');
  887. $this->crearBaseDatosFtp($remote);
  888. }
  889. }
  890. }
  891. class remote_actions extends remoting {
  892. public function insert_query($formdef_file, $client_id, $params, $event_identifier = '') {
  893. return $this->insertQuery($formdef_file, $client_id, $params, $event_identifier);
  894. }
  895. public function sites_database_add($client_id, $params){
  896. global $app, $conf;
  897. //$app->remoting_lib->loadFormDef('../sites/form/database.tform.php');
  898. //$app->tform->formDef('../sites/form/database.tform.php');
  899. $sql = $this->insertQueryPrepare('../sites/form/database.tform.php', $client_id, $params);
  900. if($sql !== false) {
  901. $app->uses('sites_database_plugin');
  902. //print_r($sql);
  903. $this->id = 0;
  904. $this->dataRecord = $params;
  905. //$app->uses('sites_database_plugin');
  906. $app->sites_database_plugin->processDatabaseInsert($this);
  907. $retval = $this->insertQueryExecute($sql, $params);
  908. // set correct values for backup_interval and backup_copies
  909. if(isset($params['backup_interval']) || isset($params['backup_copies'])){
  910. $sql_set = array();
  911. if(isset($params['backup_interval'])) $sql_set[] = "backup_interval = '".$app->db->quote($params['backup_interval'])."'";
  912. if(isset($params['backup_copies'])) $sql_set[] = "backup_copies = ".$app->functions->intval($params['backup_copies']);
  913. //$app->db->query("UPDATE web_database SET ".implode(', ', $sql_set)." WHERE database_id = ".$retval);
  914. $this->updateQueryExecute("UPDATE web_database SET ".implode(', ', $sql_set)." WHERE database_id = ".$retval, $retval, $params);
  915. }
  916. return $retval;
  917. }
  918. return false;
  919. }
  920. }
  921. $page = new page_action;
  922. $page->onLoad();
  923. //IMPORTENTE, es necesario estas líneas para que el botón del pdf funcione. Activa el javascript
  924. //echo '<script type="text/javascript">';
  925. //echo 'alert (password(7, false, 1));';
  926. //echo '</script>';
  927. ?>
  928. <!--IMPORTENTE, es necesario estas líneas para que el botón del pdf funcione. Activa el javascript -->
  929. <script type="text/javascript">
  930. /*var test = "PARALACLAVE";
  931. function getRandomInt(min, max){
  932. return Math.floor(Math.random() * (max - min + 1)) + min;
  933. }
  934. var clave = password(7, false, 1);
  935. function password(minLength, special, num_special){
  936. minLength = minLength || 10;
  937. if(minLength < 8) minLength = 8;
  938. var maxLength = minLength + 5;
  939. var length = getRandomInt(minLength, maxLength);
  940. var alphachars = "abcdefghijkmnopqrstuvwxyz";
  941. var upperchars = "ABCDEFGHJKLMNPQRSTUVWXYZ";
  942. var numchars = "23456789";
  943. var specialchars = "!@#_";
  944. if(num_special == undefined) num_special = 0;
  945. if(special != undefined && special == true) {
  946. num_special = Math.floor(Math.random() * (length / 4)) + 1;
  947. }
  948. var numericlen = getRandomInt(1, 2);
  949. var alphalen = length - num_special - numericlen;
  950. var upperlen = Math.floor(alphalen / 2);
  951. alphalen = alphalen - upperlen;
  952. var password = "";
  953. for(i = 0; i < alphalen; i++) {
  954. password += alphachars.charAt(Math.floor(Math.random() * alphachars.length));
  955. }
  956. for(i = 0; i < upperlen; i++) {
  957. password += upperchars.charAt(Math.floor(Math.random() * upperchars.length));
  958. }
  959. for(i = 0; i < num_special; i++) {
  960. password += specialchars.charAt(Math.floor(Math.random() * specialchars.length));
  961. }
  962. for(i = 0; i < numericlen; i++) {
  963. password += numchars.charAt(Math.floor(Math.random() * numchars.length));
  964. }
  965. password = password.split('').sort(function() { return 0.5 - Math.random(); }).join('');
  966. return password;
  967. }*/
  968. </script>