From b4daebfaff3a7cfb84f5700de0fda1c4dc943a03 Mon Sep 17 00:00:00 2001
From: xaver <xaver@ispconfig3>
Date: Tue, 28 Feb 2012 10:26:42 -0500
Subject: [PATCH] added file count in Website quota #2105

---
 server/lib/classes/monitor_tools.inc.php |   26 ++++++++++++++++++++------
 1 files changed, 20 insertions(+), 6 deletions(-)

diff --git a/server/lib/classes/monitor_tools.inc.php b/server/lib/classes/monitor_tools.inc.php
index 0f0a172..a8a4025 100644
--- a/server/lib/classes/monitor_tools.inc.php
+++ b/server/lib/classes/monitor_tools.inc.php
@@ -151,7 +151,7 @@
 
     //** Email Quota
     public function monitorEmailQuota() {
-        global $conf;
+        global $conf, $app;
 
 		//* Initialize data array
 		$data = array();
@@ -175,7 +175,13 @@
 					$quotafile = file($filename);
 					$data[$email]['used'] = trim($quotafile['1']);
 					unset($quotafile);
-				}   
+				} else {
+					exec('du -s '.escapeshellcmd('/var/vmail/'.$email_parts[1].'/'.$email_parts[0]),$out);
+					$parts = explode(' ',$out[0]);
+					$data[$email]['used'] = intval($parts[0])*1024;
+					unset($out);
+					unset($parts);
+				}
 			}
 		}
 		
@@ -235,10 +241,12 @@
 						$data['user'][$username]['used'] += $s[2];
 						$data['user'][$username]['soft'] += $s[3];
 						$data['user'][$username]['hard'] += $s[4];
+						$data['user'][$username]['files'] += $s[5];
 					} else {
 						$data['user'][$username]['used'] = $s[2];
 						$data['user'][$username]['soft'] = $s[3];
 						$data['user'][$username]['hard'] = $s[4];
+						$data['user'][$username]['files'] = $s[5];
 					}
 				}
 			}
@@ -873,7 +881,7 @@
 			/*
 			 * Fetch the output
 			 */
-			$data['output'] = shell_exec('zypper --non-interactive up');
+			$data['output'] = shell_exec('zypper lu');
 		} else {
 			/*
 			 * It is not Debian/Ubuntu, so there is no data and no state
@@ -1014,7 +1022,7 @@
 				/*
 				 * Fetch the output
 				 */
-				$data['output'] = shell_exec('mpt-status --autoload -n');
+				$data['output'] = shell_exec('mpt-status --autoload');
 
 				/*
 				 * Then calc the state.
@@ -1026,7 +1034,7 @@
 						* The output contains information for every RAID and every HDD.
 						* We only need the state of the RAID
 						*/
-						if (strpos($item, 'raidlevel:') !== false) {
+						if (strpos($item, 'state ') !== false) {
 							/*
 							* We found a raid, process the state of it
 							*/
@@ -1713,7 +1721,13 @@
 				 * So we can do a deepter test and try to get data over this connection.
 				 * (if apache hangs, we get a connection but a timeout by trying to GET the data!)
 				 */
-				fwrite($fp, "GET / HTTP/1.0\r\n\r\n");
+				// fwrite($fp, "GET / HTTP/1.0\r\n\r\n");
+				$out = "GET / HTTP/1.1\r\n";
+				$out .= "Host: localhost\r\n";
+				$out .= "User-Agent: Mozilla/5.0 (ISPConfig monitor)\r\n";
+				$out .= "Accept: application/xml,application/xhtml+xml,text/html\r\n";
+				$out .= "Connection: Close\r\n\r\n";
+				fwrite($fp, $out);
 				stream_set_timeout($fp, 5); // Timeout after 5 seconds
 				$res = fread($fp, 10);  // try to get 10 bytes (enough to test!)
 				$info = stream_get_meta_data($fp);

--
Gitblit v1.9.1