From e23c47d06adda746c330be387f042319f0d7e4dc Mon Sep 17 00:00:00 2001
From: Till Brehm <tbrehm@ispconfig.org>
Date: Thu, 21 Aug 2014 04:35:59 -0400
Subject: [PATCH] FS#3635 - Adding Shell Users with remote API is broken in 3.0.5.4p3 FS#3632 - Adding websites with remote API is broken in 3.0.5.4p3 release. Missed to commit one file for: FS#3634 - Add option to disable statistics for a website

---
 interface/lib/classes/validate_ftpuser.inc.php         |   28 +++++++++----
 interface/web/sites/form/ftp_user.tform.php            |    4 ++
 interface/lib/classes/validate_systemuser.inc.php      |   52 +++++++++++++++++++------
 interface/web/sites/form/web_vhost_subdomain.tform.php |    2 
 remoting_client/examples/sites_ftp_user_add.php        |    6 +-
 remoting_client/examples/sites_ftp_user_update.php     |    2 
 remoting_client/examples/sites_shell_user_add.php      |   10 ++--
 remoting_client/examples/sites_shell_user_update.php   |    2 
 8 files changed, 73 insertions(+), 33 deletions(-)

diff --git a/interface/lib/classes/validate_ftpuser.inc.php b/interface/lib/classes/validate_ftpuser.inc.php
index 64ca12f..8e0663e 100644
--- a/interface/lib/classes/validate_ftpuser.inc.php
+++ b/interface/lib/classes/validate_ftpuser.inc.php
@@ -36,7 +36,10 @@
 	function ftp_dir($field_name, $field_value, $validator) {
 		global $app;
 
-		if($app->tform->primary_id == 0) {
+		$primary_id = (isset($app->tform->primary_id) && $app->tform->primary_id > 0)?$app->tform->primary_id:$app->remoting_lib->primary_id;
+		$primary_id = $app->functions->intval($primary_id);
+		
+		if($primary_id == 0 && !isset($app->remoting_lib->dataRecord['parent_domain_id'])) {
 			$errmsg = $validator['errmsg'];
 			if(isset($app->tform->wordbook[$errmsg])) {
 				return $app->tform->wordbook[$errmsg]."<br>\r\n";
@@ -45,18 +48,25 @@
 			}
 		}
 
-
-		$ftp_data = $app->db->queryOneRecord("SELECT parent_domain_id FROM ftp_user WHERE ftp_user_id = '".$app->db->quote($app->tform->primary_id)."'");
-		if(!is_array($ftp_data) || $ftp_data["parent_domain_id"] < 1) {
-			$errmsg = $validator['errmsg'];
-			if(isset($app->tform->wordbook[$errmsg])) {
-				return $app->tform->wordbook[$errmsg]."<br>\r\n";
+		if($primary_id > 0) {
+			//* get parent_domain_id from website
+			$ftp_data = $app->db->queryOneRecord("SELECT parent_domain_id FROM ftp_user WHERE ftp_user_id = '".$app->db->quote($primary_id)."'");
+			if(!is_array($ftp_data) || $ftp_data["parent_domain_id"] < 1) {
+				$errmsg = $validator['errmsg'];
+				if(isset($app->tform->wordbook[$errmsg])) {
+					return $app->tform->wordbook[$errmsg]."<br>\r\n";
+				} else {
+					return $errmsg."<br>\r\n";
+				}
 			} else {
-				return $errmsg."<br>\r\n";
+				$parent_domain_id = $ftp_data["parent_domain_id"];
 			}
+		} else {
+			//* get parent_domain_id from dataRecord when we have a insert operation trough remote API
+			$parent_domain_id = $app->functions->intval($app->remoting_lib->dataRecord['parent_domain_id']);
 		}
 
-		$domain_data = $app->db->queryOneRecord("SELECT domain_id, document_root FROM web_domain WHERE domain_id = '".$app->db->quote($ftp_data["parent_domain_id"])."'");
+		$domain_data = $app->db->queryOneRecord("SELECT domain_id, document_root FROM web_domain WHERE domain_id = '".$app->db->quote($parent_domain_id)."'");
 		if(!is_array($domain_data) || $domain_data["domain_id"] < 1) {
 			$errmsg = $validator['errmsg'];
 			if(isset($app->tform->wordbook[$errmsg])) {
diff --git a/interface/lib/classes/validate_systemuser.inc.php b/interface/lib/classes/validate_systemuser.inc.php
index 6df3a45..2cab1cf 100644
--- a/interface/lib/classes/validate_systemuser.inc.php
+++ b/interface/lib/classes/validate_systemuser.inc.php
@@ -29,6 +29,16 @@
 */
 
 class validate_systemuser {
+	
+	function get_error($errmsg) {
+		global $app;
+
+		if(isset($app->tform->wordbook[$errmsg])) {
+			return $app->tform->wordbook[$errmsg]."<br>\r\n";
+		} else {
+			return $errmsg."<br>\r\n";
+		}
+	}
 
 	/*
 		Validator function to check if a given user is ok.
@@ -36,11 +46,15 @@
 	function check_sysuser($field_name, $field_value, $validator) {
 		global $app;
 		
+		//* Skip Test if we have the placeholder input of the remote APi for the web_domain system_user field here.
+		if($field_name == 'system_user' && $field_value == '-') return '';
+		
+		//* Check the input
 		$errmsg = $validator['errmsg'];
 		$check_names = (isset($validator['check_names']) && $validator['check_names'] == true)?true:false;
 
 		if($app->functions->is_allowed_user(trim(strtolower($field_value)),$check_names) == false) {
-			return $app->tform->wordbook[$errmsg]."<br>\r\n";
+			return $this->get_error($errmsg);
 		}
 	}
 	
@@ -50,11 +64,14 @@
 	function check_sysgroup($field_name, $field_value, $validator) {
 		global $app;
 		
+		//* Skip Test if we have the placeholder input of the remote APi for the web_domain system_group field here.
+		if($field_name == 'system_group' && $field_value == '-') return '';
+		
 		$errmsg = $validator['errmsg'];
 		$check_names = (isset($validator['check_names']) && $validator['check_names'] == true)?true:false;
 
 		if($app->functions->is_allowed_group(trim(strtolower($field_value)),$check_names) == false) {
-			return $app->tform->wordbook[$errmsg]."<br>\r\n";
+			return $this->get_error($errmsg);
 		}
 	}
 
@@ -63,8 +80,11 @@
 	*/
 	function shelluser_dir($field_name, $field_value, $validator) {
 		global $app;
-
-		if($app->tform->primary_id == 0) {
+		
+		$primary_id = (isset($app->tform->primary_id) && $app->tform->primary_id > 0)?$app->tform->primary_id:$app->remoting_lib->primary_id;
+		$primary_id = $app->functions->intval($primary_id);
+		
+		if($primary_id == 0 && !isset($app->remoting_lib->dataRecord['parent_domain_id'])) {
 			$errmsg = $validator['errmsg'];
 			if(isset($app->tform->wordbook[$errmsg])) {
 				return $app->tform->wordbook[$errmsg]."<br>\r\n";
@@ -73,18 +93,25 @@
 			}
 		}
 
-
-		$shell_data = $app->db->queryOneRecord("SELECT parent_domain_id FROM shell_user WHERE shell_user_id = '".$app->db->quote($app->tform->primary_id)."'");
-		if(!is_array($shell_data) || $shell_data["parent_domain_id"] < 1) {
-			$errmsg = $validator['errmsg'];
-			if(isset($app->tform->wordbook[$errmsg])) {
-				return $app->tform->wordbook[$errmsg]."<br>\r\n";
+		if($primary_id > 0) {
+			//* get parent_domain_id from website
+			$shell_data = $app->db->queryOneRecord("SELECT parent_domain_id FROM shell_user WHERE shell_user_id = '".$app->db->quote($primary_id)."'");
+			if(!is_array($shell_data) || $shell_data["parent_domain_id"] < 1) {
+				$errmsg = $validator['errmsg'];
+				if(isset($app->tform->wordbook[$errmsg])) {
+					return $app->tform->wordbook[$errmsg]."<br>\r\n";
+				} else {
+					return $errmsg."<br>\r\n";
+				}
 			} else {
-				return $errmsg."<br>\r\n";
+				$parent_domain_id = $shell_data["parent_domain_id"];
 			}
+		} else {
+			//* get parent_domain_id from dataRecord when we have a insert operation trough remote API
+			$parent_domain_id = $app->functions->intval($app->remoting_lib->dataRecord['parent_domain_id']);
 		}
 
-		$domain_data = $app->db->queryOneRecord("SELECT domain_id, document_root FROM web_domain WHERE domain_id = '".$app->db->quote($shell_data["parent_domain_id"])."'");
+		$domain_data = $app->db->queryOneRecord("SELECT domain_id, document_root FROM web_domain WHERE domain_id = '".$app->db->quote($parent_domain_id)."'");
 		if(!is_array($domain_data) || $domain_data["domain_id"] < 1) {
 			$errmsg = $validator['errmsg'];
 			if(isset($app->tform->wordbook[$errmsg])) {
@@ -115,6 +142,5 @@
 			}
 		}
 	}
-
 
 }
diff --git a/interface/web/sites/form/ftp_user.tform.php b/interface/web/sites/form/ftp_user.tform.php
index ef11b60..e96e63d 100644
--- a/interface/web/sites/form/ftp_user.tform.php
+++ b/interface/web/sites/form/ftp_user.tform.php
@@ -205,6 +205,10 @@
 											1 => array ( 	'type' => 'REGEX',
 															'regex' => '/^\/[a-zA-Z0-9\ \.\-\_\/]{10,128}$/',
 															'errmsg'=> 'directory_error_regex'),
+											2 => array (    'type'  => 'CUSTOM',
+														'class' => 'validate_ftpuser',
+														'function' => 'ftp_dir',
+														'errmsg' => 'directory_error_notinweb'),
 				),
 				'default'   => '',
 				'value'     => '',
diff --git a/interface/web/sites/form/web_vhost_subdomain.tform.php b/interface/web/sites/form/web_vhost_subdomain.tform.php
index e4ca6a2..3aa2276 100644
--- a/interface/web/sites/form/web_vhost_subdomain.tform.php
+++ b/interface/web/sites/form/web_vhost_subdomain.tform.php
@@ -486,7 +486,7 @@
 			'datatype' => 'VARCHAR',
 			'formtype' => 'SELECT',
 			'default' => 'webalizer',
-			'value'  => array('webalizer' => 'Webalizer', 'awstats' => 'AWStats')
+			'value'  => array('webalizer' => 'Webalizer', 'awstats' => 'AWStats', '' => 'None')
 		),
 		//#################################
 		// ENDE Datatable fields
diff --git a/remoting_client/examples/sites_ftp_user_add.php b/remoting_client/examples/sites_ftp_user_add.php
index b8d499b..6e48d80 100644
--- a/remoting_client/examples/sites_ftp_user_add.php
+++ b/remoting_client/examples/sites_ftp_user_add.php
@@ -20,13 +20,13 @@
 	$params = array(
 		'server_id' => 1,
 		'parent_domain_id' => 1,
-		'username' => 'threep',
-		'password' => 'wood',
+		'username' => 'tom',
+		'password' => 'secret',
 		'quota_size' => 10000,
 		'active' => 'y',
 		'uid' => '5000',
 		'gid' => '5000',
-		'dir' => 'maybe',
+		'dir' => '/var/www/clients/client0/web1',
 		'quota_files' => -1,
 		'ul_ratio' => -1,
 		'dl_ratio' => -1,
diff --git a/remoting_client/examples/sites_ftp_user_update.php b/remoting_client/examples/sites_ftp_user_update.php
index d09b416..1f36953 100644
--- a/remoting_client/examples/sites_ftp_user_update.php
+++ b/remoting_client/examples/sites_ftp_user_update.php
@@ -15,7 +15,7 @@
 	}
 
 	//* Parameters
-	$client_id = 1;
+	$client_id = 0;
 	$ftp_user_id = 1;
 
 
diff --git a/remoting_client/examples/sites_shell_user_add.php b/remoting_client/examples/sites_shell_user_add.php
index 84d4012..c3f875b 100644
--- a/remoting_client/examples/sites_shell_user_add.php
+++ b/remoting_client/examples/sites_shell_user_add.php
@@ -20,14 +20,14 @@
 	$params = array(
 		'server_id' => 1,
 		'parent_domain_id' => 1,
-		'username' => 'threep2',
-		'password' => 'wood',
+		'username' => 'tom',
+		'password' => 'test',
 		'quota_size' => 10000,
 		'active' => 'y',
-		'puser' => 'null',
-		'pgroup' => 'null',
+		'puser' => 'web1',
+		'pgroup' => 'client0',
 		'shell' => '/bin/bash',
-		'dir' => 'maybe',
+		'dir' => '/var/www/clients/client0/web1',
 		'chroot' => ''
 	);
 
diff --git a/remoting_client/examples/sites_shell_user_update.php b/remoting_client/examples/sites_shell_user_update.php
index 73b9013..a60262d 100644
--- a/remoting_client/examples/sites_shell_user_update.php
+++ b/remoting_client/examples/sites_shell_user_update.php
@@ -15,7 +15,7 @@
 	}
 
 	//* Parameters
-	$client_id = 3;
+	$client_id = 0;
 	$shell_user_id = 1;
 
 

--
Gitblit v1.9.1