From 7a4489f9853ba9a0c17088f2729ca819a44decab Mon Sep 17 00:00:00 2001
From: tbrehm <t.brehm@ispconfig.org>
Date: Tue, 29 Jun 2010 09:17:20 -0400
Subject: [PATCH] Implemented: FS#1101 - Use relative paths for symlinks to enable modules.

---
 server/plugins-available/apache2_plugin.inc.php |   54 ++++++++++++++++++++++++++++++++++++++++++++++++------
 1 files changed, 48 insertions(+), 6 deletions(-)

diff --git a/server/plugins-available/apache2_plugin.inc.php b/server/plugins-available/apache2_plugin.inc.php
index 61202c6..c0fd822 100644
--- a/server/plugins-available/apache2_plugin.inc.php
+++ b/server/plugins-available/apache2_plugin.inc.php
@@ -838,6 +838,11 @@
 				unset($htp_file);
 			}
 		}
+		
+		//* Create awstats configuration
+		if($data["new"]["stats_type"] == 'awstats' && $data["new"]["type"] == "vhost") {
+			$this->awstats_update($data,$web_config);
+		}
 
 
 		if($apache_chrooted) {
@@ -942,6 +947,11 @@
 			$command .= ' '.$data["old"]["system_user"];
 			exec($command);
 			if($apache_chrooted) $this->_exec("chroot ".escapeshellcmd($web_config['website_basedir'])." ".$command);
+			
+			//* Remove the awstats configuration file
+			if($data["old"]["stats_type"] == 'awstats') {
+				$this->awstats_delete($data,$web_config);
+			}
 
 		}
 	}
@@ -1085,7 +1095,6 @@
 		$changed = false;
 		$in = fopen($filename, 'r');
 		$output = '';
-
 		/*
 		 * read line by line and search for the username and authname
 		*/
@@ -1096,10 +1105,9 @@
 				/*
 				 * found the user. delete or change it?
 				*/
-				if ($pwd != '') {
-					$tmp[2] = $pwdhash;
-					$output .= $tmp[0] . ':' . $tmp[1] . ':' . $tmp[2] . "\n";
-				}
+				if ($pwdhash != '') {
+					$output .= $tmp[0] . ':' . $tmp[1] . ':' . $pwdhash . "\n";
+					}
 				$changed = true;
 			}
 			else {
@@ -1110,7 +1118,7 @@
 		 * if we didn't change anything, we have to add the new user at the end of the file
 		*/
 		if (!$changed) {
-			$output .= $username . ':' . $authname . ':' . md5($username . ':' . $authname . ':' . $pwd) . "\n";
+			$output .= $username . ':' . $authname . ':' . $pwdhash . "\n";
 		}
 		fclose($in);
 
@@ -1198,6 +1206,40 @@
 		file_put_contents($fileName, $output);
 
 	}
+	
+	//* Update the awstats configuration file
+	private function awstats_update ($data,$web_config) {
+		global $app;
+		
+		$awstats_conf_dir = $web_config['awstats_conf_dir'];
+		
+		if(!@is_file($awstats_conf_dir."/awstats.".$data["new"]["domain"].".conf") || ($data["old"]["domain"] != '' && $data["new"]["domain"] != $data["old"]["domain"])) {
+			if ( @is_file($awstats_conf_dir."/awstats.".$data["old"]["domain"].".conf") ) {
+				unlink($awstats_conf_dir."/awstats.".$data["old"]["domain"].".conf");
+			}
+			
+			$content = '';
+			$content .= "Include \"".$awstats_conf_dir."/awstats.conf\"\n";
+			$content .= "LogFile=\"/var/log/ispconfig/httpd/".$data["new"]["domain"]."/access.log\"\n";
+			$content .= "SiteDomain=\"".$data["new"]["domain"]."\"\n";
+			$content .= "HostAliases=\"www.".$data["new"]["domain"]."  localhost 127.0.0.1\"\n";
+			
+			file_put_contents($awstats_conf_dir.'/awstats.'.$data["new"]["domain"].'.conf',$content);
+			$app->log("Created awstats config file: ".$awstats_conf_dir.'/awstats.'.$data["new"]["domain"].'.conf',LOGLEVEL_DEBUG);
+		}
+	}
+	
+	//* Delete the awstats configuration file
+	private function awstats_delete ($data,$web_config) {
+		global $app;
+		
+		$awstats_conf_dir = $web_config['awstats_conf_dir'];
+		
+		if ( @is_file($awstats_conf_dir."/awstats.".$data["old"]["domain"].".conf") ) {
+			unlink($awstats_conf_dir."/awstats.".$data["old"]["domain"].".conf");
+			$app->log("Removed awstats config file: ".$awstats_conf_dir.'/awstats.'.$data["old"]["domain"].'.conf',LOGLEVEL_DEBUG);
+		}
+	}
 
 	//* Wrapper for exec function for easier debugging
 	private function _exec($command) {

--
Gitblit v1.9.1