From d24bc46c8fed8cd15153a1cb1caa646ff545ca37 Mon Sep 17 00:00:00 2001 From: dramos Date: Mon, 6 Nov 2017 11:58:45 +0100 Subject: [PATCH] =?UTF-8?q?Comprobaciones=20del=20nombre=20dominio=20se=20?= =?UTF-8?q?hacen=20en=20la=20tabla=20dns=5Fsoa.=20Comprobaci=C3=B3n=20si?= =?UTF-8?q?=20el=20dominio=20ya=20tiene=20sitio=20web?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- new_service_webdns.php | 55 ++---- new_service_webdnsOLD.php | 361 -------------------------------------- 2 files changed, 11 insertions(+), 405 deletions(-) delete mode 100755 new_service_webdnsOLD.php diff --git a/new_service_webdns.php b/new_service_webdns.php index 9792fcd..9ec6083 100755 --- a/new_service_webdns.php +++ b/new_service_webdns.php @@ -80,11 +80,11 @@ class page_action extends tform_actions { $patronSubDominos = "/(.*?)\.(.*)$/"; $patronWWW = "/^w{3}/"; - //$patronPunto = '/(\.)/'; + /*$patronPunto = '/(\.)/'; $patronP1 = '/(^\.)/'; $patronP2 = '/(\.$)/'; $patronP3 = '/(\.\.+)/'; - $patronP4 = '/(\.[[:alpha:]]*)$/'; + $patronP4 = '/(\.[[:alpha:]]*)$/';*/ //Se comprueba que no tenga 3 w "www" al principio del nombre del dominio o subdomino $encontradoWWW = preg_match($patronWWW, $subdom, $coincidencias); @@ -132,8 +132,8 @@ class page_action extends tform_actions { return; } //print "
El dominio es: " . $this->dominio;
-		$camDominio = $app->db->queryOneRecord('SELECT domain_id, domain FROM domain WHERE domain = "'.$this->dominio.'"');
-		
+		//$camDominio = $app->db->queryOneRecord('SELECT domain_id, domain FROM domain WHERE domain = "'.$this->dominio.'"');
+		$camDominio = $app->db->queryOneRecord('SELECT origin FROM dns_soa WHERE origin LIKE "'.$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'].'"');
@@ -317,10 +317,15 @@ class page_action extends tform_actions {
 		} //else if(!$this->subdom_error){		
 	
 		// check for domain unique name
-		if($app->db->queryOneRecord('SELECT domain_id FROM domain WHERE domain = "'.$fields['domain'].'"')) {
+		if($app->db->queryOneRecord('SELECT * FROM dns_soa WHERE origin LIKE "'.$fields['domain'].'%"')) {
 			$app->tform->errorMessage = $app->tform->wordbook['domain_error_unique'];
 		}
 		
+		if($app->db->queryOneRecord('SELECT domain_id, domain FROM web_domain WHERE domain = "'.$fields['domain'].'"')) {
+			$app->tform->errorMessage = $app->tform->wordbook['error_sitio_web_existe'];
+			//return;
+		}
+
 		if($app->tform->errorMessage)
 		{
 			$this->onError();
@@ -344,7 +349,7 @@ class page_action extends tform_actions {
 		$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']));
+		//$domain_id = $remote->insert_query('../client/form/domain.tform.php', $fields['client_id'], array('domain' => $fields['domain']));
 		
 		
 		//Carga del formulario dns_soa para guardar en base de datos
@@ -353,25 +358,7 @@ class page_action extends tform_actions {
 			
 		// 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 '

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'")); @@ -441,26 +428,6 @@ class page_action extends tform_actions { } // end foreach - - $dns_error = ''; - - /*if($vars['origin'] == '') $dns_error .= $app->lng('error_origin_empty').'
'; - if($vars['ns'] == '') $dns_error .= $app->lng('error_ns_empty').'
'; - if($vars['mbox'] == '') $dns_error .= $app->lng('error_mbox_empty').'
'; - if($vars['refresh'] == '') $dns_error .= $app->lng('error_refresh_empty').'
'; - if($vars['retry'] == '') $dns_error .= $app->lng('error_retry_empty').'
'; - if($vars['expire'] == '') $dns_error .= $app->lng('error_expire_empty').'
'; - if($vars['minimum'] == '') $dns_error .= $app->lng('error_minimum_empty').'
'; - if($vars['ttl'] == '') $dns_error .= $app->lng('error_ttl_empty').'
'; - - // 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']; diff --git a/new_service_webdnsOLD.php b/new_service_webdnsOLD.php deleted file mode 100755 index 5e3960f..0000000 --- a/new_service_webdnsOLD.php +++ /dev/null @@ -1,361 +0,0 @@ - -SQL y expresiones regulares por Pablo Sarria Pérez, Open6Hosting - -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 -$app->uses('tpl,tform,tform_actions,remoting,tools_sites,remoting_lib'); -$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(); - }*/ - - - function onSubmit() { - global $app, $conf; - //Carga de campos del formulario. - $fields = $app->tform->encode($this->dataRecord, $app->tform->getCurrentTab(), true); - - // 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'])); - - - //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 '

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 '

Valor de la consulta '.$dns_ip_servidor_ipv6[ip_address].' '; - echo '

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').'
'; - if($vars['ns'] == '') $dns_error .= $app->lng('error_ns_empty').'
'; - if($vars['mbox'] == '') $dns_error .= $app->lng('error_mbox_empty').'
'; - if($vars['refresh'] == '') $dns_error .= $app->lng('error_refresh_empty').'
'; - if($vars['retry'] == '') $dns_error .= $app->lng('error_retry_empty').'
'; - if($vars['expire'] == '') $dns_error .= $app->lng('error_expire_empty').'
'; - if($vars['minimum'] == '') $dns_error .= $app->lng('error_minimum_empty').'
'; - if($vars['ttl'] == '') $dns_error .= $app->lng('error_ttl_empty').'
'; - - // 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, - ); - - //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'); - - // 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); - - //$remote->insert_query('../sites/form/web_vhost_domain.tform.php', $fields['client_id'], $paramsite); - - //Si todo va bien, el resultado - echo '

Altas Web y DNS del dominio '.$fields['domain'].', ¡Creadas correctamente!
'; - - - //parent::onSubmit(); - } - -} - -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); - } -} - -$page = new page_action; -$page->onLoad();