|
- <?php
- /*
- PHP por David Ramos García, Open6Hosting <dramos@open6hosting.com>
- SQL y expresiones regulares por Pablo Sarria Pérez, Open6Hosting <pablo@sarriaperez.com>
-
- 2017, All rights reserved.
- */
-
- /******************************************
- * Begin Form configuration
- ******************************************/
- //Solo se puede tener una variable para cargar los distintos formularios
- $tform_def_file = "form/new_service_webdns.tform.php";
-
- /******************************************
- * End Form configuration
- ******************************************/
-
- require_once '../../lib/config.inc.php';
- require_once '../../lib/app.inc.php';
-
- //* Check permissions for module
- $app->auth->check_module_permissions('webdns');
-
- // Check the module permissions and redirect if not allowed.
- /*if(!stristr($_SESSION['s']['user']['modules'],'customdns')) {
- header('Location: ../index.php');
- die;
- }*/
-
- // 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í
- $app->uses('tpl,tform,tform_actions,remoting,tools_sites,remoting_lib,remoting_dns');
- $app->load('tform_actions');
-
-
- class page_action extends tform_actions {
- //Con esta funcion se parsean y preparan los campos del formulario, new_service_dns.tform.php
- //justo después de la carga de este.
- /*function onShowEnd() {
- global $app, $conf;*/
- //FORMULARIO
- //Con esta llamada a al clase $app cargo todos los campos definidos en el formulario,
- //en este caso, los definidos en el array $form["tabs"]['webdns'];
- //$fields = $app->tform->encode($this->dataRecord, $app->tform->getCurrentTab(), true);
-
- // select first template as default
- /*if($fields['dns_template_id'] == 0)
- {
- $first_template = $app->db->queryOneRecord("SELECT template_id FROM dns_template WHERE visible = 'Y' ORDER BY name ASC");
- $fields['dns_template_id'] = $first_template['template_id'];
- }*/
- //BASE DE DATOS - TEMPLATE
- //Cargo todos los valores de la tabla dns_template que coincidan con id del template seleccionado.
- ///$template_record = $app->db->queryOneRecord("SELECT * FROM dns_template WHERE template_id = ?", $fields['dns_template_id']);
- //IMPORTANTE, aquí cargo el campo fields de la tabla dns_template
- //que contiene una lista de los campos que se muestran en el template(vista)
- /*$fields = explode(',', $template_record['fields']);
- if(is_array($fields)) {
- foreach($fields as $field) {
- $app->tpl->setVar($field."_VISIBLE", 1);
- $field = strtolower($field);
- $app->tpl->setVar($field, $_POST['dns_'.$field]);
- }
- }*/
-
- /*parent::onShowEnd();
- }*/
-
-
- public $dominio;
- public $subdominio;
- public $es_subdominio = false;
- public $subdom_error = false;
- public $no_ip = false;
-
-
- function crearBaseDatosFtp($remoto){
- global $app, $conf;
-
- $fields = $app->tform->encode($this->dataRecord, $app->tform->getCurrentTab(), true);
- // generate username
- $generated_username = $fields['client_id'].substr(sha1(rand()), 0, 8);//client_prefix.substr(sha1(rand()), 0, 8);
- //print "<pre>"; print_r($generated_username); print "</pre>\n";
- $sitio_id = $app->db->queryOneRecord('SELECT domain_id, domain FROM web_domain WHERE domain = "'.$fields['domain'].'"');
- //print "<pre>"; print_r($camDnsRR); print "</pre>\n";
- $camDnsRR = $app->db->queryOneRecord('SELECT server_id, zone FROM dns_rr WHERE name LIKE "'.$this->dominio.'%"');
-
- // add database user
- $db_user_params = array(
- 'server_id' => $camDnsRR['server_id'],
- 'database_user' => $generated_username,
- 'database_password' => substr(sha1(rand()), 0, 10)
- );
-
- //print "<pre>"; print_r($db_user_params); print "</pre>\n";
- //print "<pre>"; print_r($fields); print "</pre>\n";
- $db_user_id = $remoto->insert_query('../sites/form/database_user.tform.php', $fields['client_id'], $db_user_params, 'sites:web_database_user:on_after_insert');
-
- // add database
- $paramsBD = array(
- 'server_id' => $camDnsRR['server_id'],
- 'parent_domain_id' => $sitio_id['domain_id'],
- 'type' => 'y',
- 'database_quota' => '-1',
- 'database_name' => $db_user_params['database_user'],
- 'database_user_id' => $db_user_id,
- 'database_charset' => 'utf8',
- 'remote_access' => 'n',
- 'remote_ips' => '-1',
- 'active' => 'y'
- );
- //print "<pre>"; print_r($paramsBD); print "</pre>\n";
- //print "<pre>"; print_r($fields); print "</pre>\n";
- $remoto->sites_database_add($fields['client_id'], $paramsBD);
-
- // get site data para usarlo en la creación de la cuenta ftp, otra forma de cargar una tupla dandole un id
- //$app->uses('remoting_lib');
- $app->remoting_lib->loadFormDef('../sites/form/web_vhost_domain.tform.php');
- $site_data = $app->remoting_lib->getDataRecord($sitio_id);
-
- // add ftp user
- $ftp_params = array(
- 'server_id' => $camDnsRR['server_id'],//$template['web_server_id'],
- 'parent_domain_id' => $sitio_id['domain_id'],//$site_id,
- 'username' => $generated_username,
- 'password' => substr(sha1(rand()), 0, 10),
- 'quota_size' => '-1',//$template['hd_quota'],
- 'dir' => $site_data['0']['document_root'],
- 'uid' => $site_data['0']['system_user'],
- 'gid' => $site_data['0']['system_group'],
- 'sys_groupid' => $site_data['0']['sys_groupid'],
- 'quota_files' => '-1',//$template['quota_files'],
- 'ul_ratio' => '-1',//$template['ul_ratio'],
- 'dl_ratio' => '-1',//$template['dl_ratio'],
- 'ul_bandwidth' => '-1',//$template['ul_bandwidth'],
- 'dl_bandwidth' => '-1',//$template['dl_bandwidth'],
- 'active' => 'y',
- );
- //print "<pre>"; print_r($ftp_params); print "</pre>\n";
- //print "<pre>"; print_r($site_data); print "</pre>\n";
- $remoto->insert_query('../sites/form/ftp_user.tform.php', $fields['client_id'], $ftp_params);
- }
-
- //Expresiones regulares para comprobar si es subdominio
- function comprobarSubDominios($subdom) {
- global $app, $conf;
-
- $patronSubDominos = "/(.*?)\.(.*)$/";
- $patronWWW = "/^w{3}/";
- //$patronPunto = '/(\.)/';
- /*$patronP1 = '/(^\.)/';
- $patronP2 = '/(\.$)/';
- $patronP3 = '/(\.\.+)/';
- $patronP4 = '/(\.[[:alpha:]]*)$/';*/
-
- //Se comprueba que no tenga 3 w "www" al principio del nombre del dominio o subdomino
- $encontradoWWW = preg_match($patronWWW, $subdom, $coincidencias);
- if($encontradoWWW){
- $app->tform->errorMessage = $app->tform->wordbook['error_dominio_www'];
- return;
- }
-
- //Si el dominio tiene mas de dos puntos, es incorrecto
- if (substr_count($subdom,".") > 2) {
-
- $app->tform->errorMessage = $app->tform->wordbook['error_dominio_mas_puntos'];
- return;
-
- } else if(substr_count($subdom,".") == 2){
- $this->encontrado = preg_match($patronSubDominos, $subdom, $coincidencias);
- //print "<pre>"; print_r($coincidencias); print "</pre>\n";
-
- $this->subdominio = $coincidencias[1];
- $this->dominio = $coincidencias[2];
-
- //print "Subdomino: " . $this->subdomino . "</p>\n Dominio: " . $this->domino;
- $this->es_subdominio = true;
-
- }
- //print "<pre>El dominio es: " . $this->dominio;
- return $this->es_subdominio;
- }
-
-
- //Crear subdominio
- function crearSubDominio($remoto, $campoSubDominio){
- //para usar variables globales en las funciones hay que declararlas dentro de la funcion.
- global $app, $conf;
-
- //print "<pre>"; print_r($campoSubDominio); print "</pre>\n";
- //Compruebo que el subdominio no existe consultando la tabla web_domain.
- $existeSubDominio = $app->db->queryOneRecord('SELECT domain_id, domain FROM web_domain WHERE domain = "'.$campoSubDominio.'"');
- //print '<pre>El Sub existe '. $existeSubDominio['domain'];
- if($existeSubDominio){
- $this->subdom_error = true;
- $app->tform->errorMessage = $app->tform->wordbook['error_subdominio_existe'];
- $this->onError();
- return;
- }
- //print "<pre>El dominio es: " . $this->dominio;
- $camDominio = $app->db->queryOneRecord('SELECT domain_id, domain FROM domain WHERE domain = "'.$this->dominio.'"');
-
- $camDnsRR = $app->db->queryOneRecord('SELECT server_id, zone FROM dns_rr WHERE name LIKE "'.$this->dominio.'%"');
-
- $camServIP = $app->db->queryOneRecord('SELECT ip_address FROM server_ip WHERE server_id = "'.$camDnsRR['server_id'].'"');
- //print_r($camDominio);
- //print_r($camDnsRR);
-
- //Si el dominio NO existe mostramos mensaje de error y salimos de la ejecución
- if(!$camDominio['domain']){
- $this->subdom_error = true;
- $app->tform->errorMessage = $app->tform->wordbook['error_no_existe_dominio_padre'];
- $this->onError();
- //return;
- //print 'No existe el dominio';
- return $this->subdom_error;
-
- } else {
- //Parametros para la creación de subdominios
- $paramSubDominios = array(
- 'server_id' => $camDnsRR['server_id'],
- 'zone' => $camDnsRR['zone'],
- 'name' => $this->subdominio,
- 'type' => 'a',
- 'data' => $camServIP['ip_address'],
- //'aux' => '0',
- 'ttl' => '3600',
- 'active' => 'y',
- //comento el campo stamp, ya que introducia solo ceros en la bbdd
- //'stamp' => time(),
- 'serial' => '1',
- );
-
- //print "<pre>"; print_r($paramSubDominios); print "</pre>\n";
- //$remote = new remote_actions;
- //Inserto en bbdd usando la clase remoto que se la he pasado en parámetros de la función
- //$resultado = $remoto->insert_query('../dns/form/dns_a.tform.php', $fields['client_id'], $paramSubDominios);
- $resultado = $remoto->insert_query('form/dns_a_webdns.tform.php', $fields['client_id'], $paramSubDominios);
- echo '<br><div class="alert alert-success"><br>
- Se ha dado de alta Web y Subdominio, <b>'.$this->subdominio.'</b>, ¡Correctamente!
- <br><br></div></br>';
- //$this->onShow();
- }
-
- }
-
- function crearSitioWebSubdominio($remoto){
- global $app, $conf;
-
- $fields = $app->tform->encode($this->dataRecord, $app->tform->getCurrentTab(), true);
-
- $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'");
-
- //Comprobamos que el resultado para el cliente seleccionado no esta vacío,
- //si lo esta tomamos los datos del cliente id 0
- if(!$dns_ip_servidor_ipv6){
- $dns_ip_servidor = $app->db->queryOneRecord("SELECT ip_type, ip_address FROM server_ip WHERE client_id = 0 AND ip_type='IPv4'");
- $dns_ip_servidor_ipv6 = $app->db->queryOneRecord("SELECT ip_type, ip_address FROM server_ip WHERE client_id = 0 AND ip_type='IPv6'");
- /*echo '<br><br>Valor de la consulta '.$dns_ip_servidor_ipv6[ip_address].' ';
- echo '<br><br>Valor de la consulta '.$dns_ip_servidor[ip_address].' ';*/
- }
-
- $dns_servidor = $app->db->queryOneRecord("SELECT client_id, default_dnsserver, default_webserver FROM client WHERE client_id = ".$app->functions->intval($fields['client_id']));
- $clienteID = $dns_servidor['client_id'];
-
- $res = $app->db->queryOneRecord("SELECT groupid FROM sys_group WHERE client_id = ".$app->functions->intval($fields['client_id']));
- $client_group_id = $res['groupid'];
-
-
- // add site
- $paramsite = array(
- 'type' => 'vhost',
- 'domain' => $fields['domain'], //$this->subdominio,
- 'server_id' => $dns_servidor['default_webserver'],
- 'ip_address' => '*', //$dns_ip_servidor['ip_address'],
- 'ipv6_address' => $dns_ip_servidor_ipv6['ip_address'],
- 'traffic_quota' => '-1',
- 'hd_quota' => '0',
- 'cgi' => 'y',
- 'ssi' => 'y',
- 'suexec' => 'y',
- 'ruby' => 'n',
- 'python' => 'n',
- 'perl' => 'n',
- 'errordocs' => '1',
- 'subdomain' => '',
- 'php' => 'php-fpm',
- 'fastcgi_php_version' => '',
- 'seo_redirect' => '',
- 'rewrite_to_https' => 'n',
- 'allow_override' => 'All',
- 'http_port' => 80,
- 'https_port' => 443,
- 'apache_directives' => '',
- 'nginx_directives' => '',
- 'php_fpm_use_socket' => 'y',
- 'pm' => 'ondemand',
- 'pm_max_children' => 10,
- 'pm_start_servers' => 1,
- 'pm_min_spare_servers' => 1,
- 'pm_max_spare_servers' => 5,
- 'pm_process_idle_timeout' => 10,
- 'pm_max_requests' => 0,
- 'custom_php_ini' => '',
- 'active' => 'y',
- 'document_root' => '-',
- 'system_user' => '-',
- 'system_group' => '-',
- 'log_retention' => 30,
- 'client_group_id' => $client_group_id,
- );
-
-
-
- //$app->uses('remoting_lib');
- //$formulario = $app->remoting_lib->loadFormDef('../sites/form/web_vhost_domain.tform.php');
- //$formulario = $app->tform->loadFormDef('../sites/form/web_vhost_domain.tform.php');
-
- /*print 'Valores: ' . $dns_ip_servidor_ipv6;
- print "<pre> Parametros:"; print_r($paramsite); print "</pre>\n";
-
- print '<pre> cliente id ' . $fields['client_id'];
- print "<pre>";print_r($fields);print "</pre>\n" . $fields['client_id'];*/
- //print "<pre>Formulario ";print_r($formulario);print "</pre>\n";
-
-
- //print '<pre>DNS IPV6 ' . $dns_ip_servidor_ipv6['ip_address'];
-
-
- //$tform_def_file2 = "../sites/form/web_vhost_domain.tform.php";
- //$app->tform->loadFormDef($tform_def_file2);
- //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
- $site_id = $remoto->insert_query('../sites/form/web_vhost_domain.tform.php', $fields['client_id'], $paramsite, 'sites:web_vhost_domain:on_after_insert');
-
- //print '<pre>ID sitio web del subdominio --> ' . $site_id;
-
-
- }
-
- function tieneIPs(){
- global $app, $conf;
- $fields = $app->tform->encode($this->dataRecord, $app->tform->getCurrentTab(), true);
- //Llamada a la tabla server_ip para recuperar la ip4 e ip6
- $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'"));
-
- $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'");
-
- /*print "<pre>Campos ";print_r($fields);print "</pre>\n";
- print "<pre>IP4 ";print_r($dns_ip_servidor);print "</pre>\n";
- print "<pre>IP6 ";print_r($dns_ip_servidor_ipv6);print "</pre>\n";*/
-
- if(!$dns_ip_servidor['ip_address'] || !$dns_ip_servidor_ipv6['ip_address']){
- $app->tform->errorMessage = $app->tform->wordbook['error_no_ip'];
- $this->onError();
- //$this->no_ip = true;
- //print 'dentro if';
- return true;
- }
- return false;
- }
-
- function onSubmit() {
- global $app, $conf;
- //Carga de campos del formulario.
- $fields = $app->tform->encode($this->dataRecord, $app->tform->getCurrentTab(), true);
-
- //Creo la clase remote para usar las librerias
- $remote = new remote_actions;
-
- //$this->tieneIPs();
-
- if($this->tieneIPs()){
- return;
- }
-
- if($this->comprobarSubDominios($fields['domain'])){
- //print 'despues de comprobar que es un subD ' . $fields['domain'];
- $this->crearSubDominio($remote, $fields['domain']);
- if(!$this->subdom_error){
- $this->crearSitioWebSubdominio($remote);
- }
- $this->crearBaseDatosFtp($remote);
- return;
- } //else if(!$this->subdom_error){
- //$this->crearBaseDatosFtp($remote);
- // check for domain unique name
- if($app->db->queryOneRecord('SELECT domain_id FROM domain WHERE domain = "'.$fields['domain'].'"')) {
- $app->tform->errorMessage = $app->tform->wordbook['domain_error_unique'];
- }
-
- if($app->tform->errorMessage)
- {
- $this->onError();
- return;
- }
- //Esta variable nos llega por jQuery desde el htm para el control de errores en la vista.
- if($_POST['create'] != 1)
- {
- $app->tform->errorMessage = 'DUMMY';
- $app->tpl->setVar($this->dataRecord);
- $this->onShow();
- return;
- }
-
- // Domain OK, continue
- //$remote = new remote_actions;
-
- // client prefix and group id
- $res = $app->db->queryOneRecord("SELECT groupid FROM sys_group WHERE client_id = ".$app->functions->intval($fields['client_id']));
- $client_group_id = $res['groupid'];
- $client_prefix = 'c'.$fields['client_id'];
-
- // add domain. Llamada que inserta el dominio en la tabla domain
- $domain_id = $remote->insert_query('../client/form/domain.tform.php', $fields['client_id'], array('domain' => $fields['domain']));
- //$this->crearBaseDatosFtp($remote);
-
- //Carga del formulario dns_soa para guardar en base de datos
- $tform_def_file = "../dns/form/dns_soa.tform.php";
- $app->tform->loadFormDef($tform_def_file);
-
- // Carga y seleccion de dns_template, si no esta creado se informa de que tiene que crearse
- $template_record = $app->db->queryOneRecord("SELECT * FROM dns_template WHERE visible = 'Y' AND name = 'webdns'"); /*'open6hosting'");*/
-
- /*if($template_record) {
- //echo '<br><br>Teplate '.$template_record.', ';
- $app->tform->errorMessage = 'Error hay que crear un template llamado webdns';
- $this->onError();
- return;
- } else {
- $app->tform->errorMessage = 'Error hay que crear un template llamado webdnsssssss';
- $this->onError();
- return;
- }*/
-
- /*if($app->tform->errorMessage)
- {
- $this->onError();
- return;
- }*/
-
- //$template_record = $app->db->queryOneRecord("SELECT * FROM dns_template WHERE visible = 'Y' AND name = 'webdns'"); /*'open6hosting'");*/
-
- //Llamada a la tabla server_ip para recuperar la ip4 e ip6
- $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'"));
-
- $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'");
-
- //Comprobamos que el resultado para el cliente seleccionado no esta vacío,
- //si lo esta tomamos los datos del cliente id 0
- if(!$dns_ip_servidor_ipv6){
- $dns_ip_servidor = $app->db->queryOneRecord("SELECT ip_type, ip_address FROM server_ip WHERE client_id = 0 AND ip_type='IPv4'");
- $dns_ip_servidor_ipv6 = $app->db->queryOneRecord("SELECT ip_type, ip_address FROM server_ip WHERE client_id = 0 AND ip_type='IPv6'");
- /*echo '<br><br>Valor de la consulta '.$dns_ip_servidor_ipv6[ip_address].' ';
- echo '<br><br>Valor de la consulta '.$dns_ip_servidor[ip_address].' ';*/
- }
-
-
- $tpl_content = $template_record['template'];
- // Reemplazo la variable que nos encontramos en base de datos por el valor que se ha introducido en el formulario
- $tpl_content = str_replace('{DOMAIN}', $fields['domain'], $tpl_content);
-
- //Carga de los datos en las variables ns
- $tpl_content = str_replace('{IP}', $dns_ip_servidor['ip_address'], $tpl_content);
- $tpl_content = str_replace('{IPV6}', $dns_ip_servidor_ipv6['ip_address'], $tpl_content);
- /*$tpl_content = str_replace('{NS1}', '.open6servers.com', $tpl_content);
- $tpl_content = str_replace('{NS2}', '.open6servers.com', $tpl_content); */
-
- $enable_dnssec = 'N';//(($_POST['dns_dnssec'] == 'Y') ? 'Y' : 'N');
-
- // Parse the template
- $tpl_rows = explode("\n", $tpl_content);
- $section = '';
- $vars = array();
- $vars['xfer']='';
- $dns_rr = array();
- foreach($tpl_rows as $row) {
- $row = trim($row);
- if(substr($row, 0, 1) == '[') {
- if($row == '[ZONE]') {
- $section = 'zone';
- } elseif($row == '[DNS_RECORDS]') {
- $section = 'dns_records';
- } else {
- die('Unknown section type');
- }
- } else {
- if($row != '') {
- // Handle zone section
- if($section == 'zone') {
- $parts = explode('=', $row);
- $key = trim($parts[0]);
- $val = trim($parts[1]);
- if($key != '') $vars[$key] = $val;
- }
- // Handle DNS Record rows
- if($section == 'dns_records') {
- $parts = explode('|', $row);
- $dns_rr[] = array(
- 'name' => $parts[1],
- 'type' => $parts[0],
- 'data' => $parts[2],
- 'aux' => $parts[3],
- 'ttl' => $parts[4]
- );
- }
- }
- }
- } // end foreach
-
-
-
- $dns_error = '';
-
- /*if($vars['origin'] == '') $dns_error .= $app->lng('error_origin_empty').'<br />';
- if($vars['ns'] == '') $dns_error .= $app->lng('error_ns_empty').'<br />';
- if($vars['mbox'] == '') $dns_error .= $app->lng('error_mbox_empty').'<br />';
- if($vars['refresh'] == '') $dns_error .= $app->lng('error_refresh_empty').'<br />';
- if($vars['retry'] == '') $dns_error .= $app->lng('error_retry_empty').'<br />';
- if($vars['expire'] == '') $dns_error .= $app->lng('error_expire_empty').'<br />';
- if($vars['minimum'] == '') $dns_error .= $app->lng('error_minimum_empty').'<br />';
- if($vars['ttl'] == '') $dns_error .= $app->lng('error_ttl_empty').'<br />';
-
- // check for dns errors
- if($dns_error)
- {
- $app->tform->errorMessage = $dns_error;
- $this->onError();
- return;
- }*/
-
- //Llamada a la tabla client para recuperar el client_id y su default_dnsserver
- $dns_servidor = $app->db->queryOneRecord("SELECT client_id, default_dnsserver, default_webserver FROM client WHERE client_id = ".$app->functions->intval($fields['client_id']));
- $valor_recuperado1 = $dns_servidor['client_id'];
- /*$valor_recuperado2 = $dns_servidor['default_dnsserver'];
- $valor_recuperado3 = $dns_servidor['default_webserver'];
- */
- // Insert the soa record
- $sys_userid = $_SESSION['s']['user']['userid'];
- $origin = $vars['origin'];
- $ns = $vars['ns'];
- $mbox = str_replace('@', '.', $vars['mbox']);
- $refresh = $vars['refresh'];
- $retry = $vars['retry'];
- $expire = $vars['expire'];
- $minimum = $vars['minimum'];
- $ttl = $vars['ttl'];
- $xfer = $vars['xfer'];
- $also_notify = $vars['also_notify'];
- $update_acl = $vars['update_acl'];
- $serial = $app->validate_dns->increase_serial(0);
-
- $insert_data = array(
- "sys_userid" => $sys_userid,
- "sys_groupid" => $client_group_id,
- "sys_perm_user" => 'riud',
- "sys_perm_group" => 'riud',
- "sys_perm_other" => '',
- "server_id" => $dns_servidor['default_dnsserver'],
- "origin" => $origin,
- "ns" => $ns,
- "mbox" => $mbox,
- "serial" => $serial,
- "refresh" => $refresh,
- "retry" => $retry,
- "expire" => $expire,
- "minimum" => $minimum,
- "ttl" => $ttl,
- "active" => 'Y',
- "xfer" => $xfer,
- "also_notify" => $also_notify,
- "update_acl" => $update_acl,
- "dnssec_wanted" => $enable_dnssec
- );
- $dns_soa_id = $app->db->datalogInsert('dns_soa', $insert_data, 'id');
-
- // Insert the dns_rr records
- if(is_array($dns_rr) && $dns_soa_id > 0) {
- foreach($dns_rr as $rr) {
- $insert_data = array(
- "sys_userid" => $sys_userid,
- "sys_groupid" => $client_group_id,
- "sys_perm_user" => 'riud',
- "sys_perm_group" => 'riud',
- "sys_perm_other" => '',
- "server_id" => $dns_servidor['default_dnsserver'],
- "zone" => $dns_soa_id,
- "name" => $rr['name'],
- "type" => $rr['type'],
- "data" => $rr['data'],
- "aux" => $rr['aux'],
- "ttl" => $rr['ttl'],
- "active" => 'Y'
- );
- $dns_rr_id = $app->db->datalogInsert('dns_rr', $insert_data, 'id');
- }
- }
- //sites_web_domain_add
- $tform_def_file = "../sites/form/web_vhost_domain.tform.php";
- $app->tform->loadFormDef($tform_def_file);
-
- //$app->remoting_lib->loadFormDef($tform_def_file);
-
- // add site
- $paramsite = array(
- 'type' => 'vhost',
- 'domain' => $fields['domain'],
- 'server_id' => $dns_servidor['default_webserver'],
- 'ip_address' => '*', //$dns_ip_servidor['ip_address'],
- 'ipv6_address' => $dns_ip_servidor_ipv6['ip_address'],
- 'traffic_quota' => '-1',
- 'hd_quota' => '0',
- 'cgi' => 'y',
- 'ssi' => 'y',
- 'suexec' => 'y',
- 'ruby' => 'n',
- 'python' => 'n',
- 'perl' => 'n',
- 'errordocs' => '1',
- 'subdomain' => 'www',
- 'php' => 'php-fpm',
- 'fastcgi_php_version' => '',
- 'seo_redirect' => '',
- 'rewrite_to_https' => 'n',
- 'allow_override' => 'All',
- 'http_port' => 80,
- 'https_port' => 443,
- 'apache_directives' => '',
- 'nginx_directives' => '',
- 'php_fpm_use_socket' => 'y',
- 'pm' => 'ondemand',
- 'pm_max_children' => 10,
- 'pm_start_servers' => 1,
- 'pm_min_spare_servers' => 1,
- 'pm_max_spare_servers' => 5,
- 'pm_process_idle_timeout' => 10,
- 'pm_max_requests' => 0,
- 'custom_php_ini' => '',
- 'active' => 'y',
- 'document_root' => '-',
- 'system_user' => '-',
- 'system_group' => '-',
- 'log_retention' => 30,
- 'client_group_id' => $client_group_id,
- );
-
- /*print 'Valores: ' . $dns_ip_servidor_ipv6 . " " . $formulario . " Parametros: " ;
- print "<pre>"; print_r($paramsite); print "</pre>\n";
-
- print '<pre> cliente id ' . $fields['client_id'];
- print "<pre>";print_r($fields);print "</pre>\n";*/
- //print "<pre>Formulario ";print_r($formulario);print "</pre>\n";
-
- //$this->crearBaseDatosFtp($remote);
- //print 'DNS IPV6 ' . $dns_ip_servidor_ipv6['ip_address'];
-
- //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
- $site_id = $remote->insert_query('../sites/form/web_vhost_domain.tform.php', $fields['client_id'], $paramsite, 'sites:web_vhost_domain:on_after_insert');
- print 'Sitio id '. $site_id;
- //$this->crearBaseDatosFtp($remote);
- // get site data
- $app->uses('remoting_lib');
- $app->remoting_lib->loadFormDef('../sites/form/web_vhost_domain.tform.php');
- $site_data = $app->remoting_lib->getDataRecord($site_id);
-
- //IMPORTANTE, es necesario cargar nuestro formulario para poder ejecutar la función que crea
- //la base de datos y el ftp ya que hay datos que tomamos de el antes de ejecutarla.
- $app->tform->loadFormDef('form/new_service_webdns.tform.php');
- $this->crearBaseDatosFtp($remote);
- //$remote->insert_query('../sites/form/web_vhost_domain.tform.php', $fields['client_id'], $paramsite);
-
- //Si todo va bien, el resultado
- echo '<br><div class="alert alert-success"><br>
- Altas Web y DNS del dominio <b>'.$fields['domain'].'</b>, ¡Creadas correctamente!
- <br><br></div></br>';
- //$this->onShow();
-
- /*echo '<div class="table-wrapper marginTop15">
- <table class="table">
- <tbody>
- <tr>
- <td bgcolor="#1ccb00" colspan="2">Altas Web y DNS del dominio <b>'.$fields['domain'].'</b>, ¡Creadas correctamente!</td>
- </tr>
- </tbody>
- </table>
- </div>';*/
- //}
-
- //parent::onSubmit();
-
- //}//FIN IF
- //$this->crearBaseDatosFtp($remote);
- }
-
- }
-
- class remote_actions extends remoting {
- public function insert_query($formdef_file, $client_id, $params, $event_identifier = '') {
- return $this->insertQuery($formdef_file, $client_id, $params, $event_identifier);
- }
-
- public function sites_database_add($client_id, $params){
- global $app;
-
- $sql = $this->insertQueryPrepare('../sites/form/database.tform.php', $client_id, $params);
- if($sql !== false) {
- $app->uses('sites_database_plugin');
-
- $this->id = 0;
- $this->dataRecord = $params;
- $app->sites_database_plugin->processDatabaseInsert($this);
-
- $retval = $this->insertQueryExecute($sql, $params);
-
- // set correct values for backup_interval and backup_copies
- if(isset($params['backup_interval']) || isset($params['backup_copies'])){
- $sql_set = array();
- if(isset($params['backup_interval'])) $sql_set[] = "backup_interval = '".$app->db->quote($params['backup_interval'])."'";
- if(isset($params['backup_copies'])) $sql_set[] = "backup_copies = ".$app->functions->intval($params['backup_copies']);
- //$app->db->query("UPDATE web_database SET ".implode(', ', $sql_set)." WHERE database_id = ".$retval);
- $this->updateQueryExecute("UPDATE web_database SET ".implode(', ', $sql_set)." WHERE database_id = ".$retval, $retval, $params);
- }
-
- return $retval;
- }
-
- return false;
- }
- }
-
- $page = new page_action;
- $page->onLoad();
|