From d053cb07eeb77c0252e23a28de0c834f8442897d Mon Sep 17 00:00:00 2001 From: tbrehm Date: Sat, 14 Feb 2009 15:54:34 +0000 Subject: [PATCH] Fixed moving of site when the client is changed. --- interface/web/sites/web_domain_edit.php | 16 ++++---- .../plugins-available/apache2_plugin.inc.php | 38 +++++++++++++++++++ 2 files changed, 46 insertions(+), 8 deletions(-) diff --git a/interface/web/sites/web_domain_edit.php b/interface/web/sites/web_domain_edit.php index 154e5f480..dae435d39 100644 --- a/interface/web/sites/web_domain_edit.php +++ b/interface/web/sites/web_domain_edit.php @@ -330,15 +330,15 @@ class page_action extends tform_actions { $client_id = intval($client["client_id"]); } - /* - // Set the values for document_root, system_user and system_group - $system_user = 'web'.$this->id; - $system_group = 'client'.$client_id; - $document_root = str_replace("[client_id]",$client_id,$document_root); + if($_SESSION["s"]["user"]["typ"] == 'admin' && isset($this->dataRecord["client_group_id"]) && $this->dataRecord["client_group_id"] != $this->oldDataRecord["client_group_id"]) { + // Set the values for document_root, system_user and system_group + $system_user = 'web'.$this->id; + $system_group = 'client'.$client_id; + $document_root = str_replace("[client_id]",$client_id,$document_root); - $sql = "UPDATE web_domain SET system_user = '$system_user', system_group = '$system_group', document_root = '$document_root' WHERE domain_id = ".$this->id; - $app->db->query($sql); - */ + $sql = "UPDATE web_domain SET system_user = '$system_user', system_group = '$system_group', document_root = '$document_root' WHERE domain_id = ".$this->id; + $app->db->query($sql); + } } diff --git a/server/plugins-available/apache2_plugin.inc.php b/server/plugins-available/apache2_plugin.inc.php index 7e1c3a409..3a5cbda09 100644 --- a/server/plugins-available/apache2_plugin.inc.php +++ b/server/plugins-available/apache2_plugin.inc.php @@ -233,6 +233,44 @@ class apache2_plugin { return 0; } + if($this->action == 'update' && $data["new"]["document_root"] != $data["old"]["document_root"]) { + + // Get the old client ID + $old_client = $app->dbmaster->queryOneRecord("SELECT client_id FROM sys_group WHERE sys_group.groupid = ".intval($data["old"]["sys_groupid"])); + $old_client_id = intval($old_client["client_id"]); + unset($old_client); + + // Remove the old symlinks + $tmp_symlinks_array = explode(':',$web_config["website_symlinks"]); + if(is_array($tmp_symlinks_array)) { + foreach($tmp_symlinks_array as $tmp_symlink) { + $tmp_symlink = str_replace("[client_id]",$old_client_id,$tmp_symlink); + $tmp_symlink = str_replace("[website_domain]",$data["old"]["domain"],$tmp_symlink); + // Remove trailing slash + if(substr($tmp_symlink, -1, 1) == '/') $tmp_symlink = substr($tmp_symlink, 0, -1); + // create the symlinks, if not exist + if(!is_link($tmp_symlink)) { + exec("rm -f ".escapeshellcmd($tmp_symlink)); + $app->log("Removed Symlink: rm -f ".$tmp_symlink,LOGLEVEL_DEBUG); + } + } + } + + $tmp_docroot = explode('/',$data["new"]["document_root"]); + unset($tmp_docroot[count($tmp_docroot)-1]); + $new_dir = implode('/',$tmp_docroot); + + $tmp_docroot = explode('/',$data["old"]["document_root"]); + unset($tmp_docroot[count($tmp_docroot)-1]); + $old_dir = implode('/',$tmp_docroot); + + exec('rm -rf '.$data["new"]["document_root"]); + if(!is_dir($new_dir)) exec('mkdir -p '.$new_dir); + exec('mv '.$data["old"]["document_root"].' '.$new_dir); + $app->log("Moving site to new document root: ".'mv '.$data["old"]["document_root"].' '.$new_dir,LOGLEVEL_DEBUG); + + } + //print_r($data); // Check if the directories are there and create them if nescessary. -- GitLab