From 580d81510e7fb7284f48b7666d46e09f3514e8bf Mon Sep 17 00:00:00 2001
From: wyrie <wyrie@ispconfig3>
Date: Wed, 02 Dec 2009 07:03:15 -0500
Subject: [PATCH] Implemented gentoo support for Server

---
 server/plugins-available/network_settings_plugin.inc.php |  220 +++++++++++++++++++++++++++++--------------
 server/mods-available/monitor_core_module.inc.php        |   38 +++++++
 server/conf/gentoo_network_interfaces.master             |   13 ++
 3 files changed, 199 insertions(+), 72 deletions(-)

diff --git a/server/conf/gentoo_network_interfaces.master b/server/conf/gentoo_network_interfaces.master
new file mode 100644
index 0000000..cca4f08
--- /dev/null
+++ b/server/conf/gentoo_network_interfaces.master
@@ -0,0 +1,13 @@
+# This file describes the network interfaces available on your system
+# and how to activate them. For more information, see interfaces(5).
+
+config_eth0=( 
+			  "<tmpl_var name="ip_address"> netmask <tmpl_var name="netmask"> broadcast <tmpl_var name="broadcast">"
+			  <tmpl_if name="additionl_ip_records">
+			  <tmpl_loop name="interfaces">
+			  "<tmpl_var name="ip_address"> netmask <tmpl_var name="netmask"> broadcast <tmpl_var name="broadcast">"
+			  </tmpl_loop>
+			  </tmpl_if>
+);
+
+routes_eth0=( "default via <tmpl_var name="gateway">" )
diff --git a/server/mods-available/monitor_core_module.inc.php b/server/mods-available/monitor_core_module.inc.php
index 044f079..cc95772 100644
--- a/server/mods-available/monitor_core_module.inc.php
+++ b/server/mods-available/monitor_core_module.inc.php
@@ -520,6 +520,34 @@
              */
             $data['output'] = shell_exec('apt-get -s -q dist-upgrade');
         }
+        elseif (file_exists("/etc/gentoo-release")) {
+        	
+        	/*
+        	 * first update the portage tree
+        	 */
+        	shell_exec('emerge --sync --quiet');
+        	
+        	/*
+             * Then test the upgrade.
+             * if there is any output, then there is a needed update
+             */
+            $emergeData = shell_exec('emerge -puDNt --color n --nospinner --quiet world');
+        	if ($emergeData == '')
+            {
+                /* There is nothing to update! */
+                $state = 'ok';
+            }
+            else
+            {
+                /* There is something to update! */
+                $state = 'warning';
+            }
+            
+            /*
+             * Fetch the output
+             */
+            $data['output'] = shell_exec('emerge -pvuDNt --color n --nospinner world');
+        }
         else {
             /*
              * It is not debian/Ubuntu, so there is no data and no state
@@ -1187,52 +1215,62 @@
 		if(@is_file('/etc/debian_version')) $dist = 'debian';
 		if(@is_file('/etc/redhat-release')) $dist = 'redhat';
 		if(@is_file('/etc/SuSE-release')) $dist = 'suse';
+		if(@is_file('/etc/gentoo-release')) $dist = 'gentoo';
 		
 		switch($log) {
             case 'log_mail':
                 if($dist == 'debian') $logfile = '/var/log/mail.log';
 				if($dist == 'redhat') $logfile = '/var/log/maillog';
 				if($dist == 'suse') $logfile = '/var/log/mail.info';
+				if($dist == 'gentoo') $logfile = '/var/log/maillog';
                 break;
             case 'log_mail_warn':
                 if($dist == 'debian') $logfile = '/var/log/mail.warn';
 				if($dist == 'redhat') $logfile = '/var/log/maillog';
 				if($dist == 'suse') $logfile = '/var/log/mail.warn';
+				if($dist == 'gentoo') $logfile = '/var/log/maillog';
                 break;
             case 'log_mail_err':
                 if($dist == 'debian') $logfile = '/var/log/mail.err';
 				if($dist == 'redhat') $logfile = '/var/log/maillog';
 				if($dist == 'suse') $logfile = '/var/log/mail.err';
+				if($dist == 'gentoo') $logfile = '/var/log/maillog';
                 break;
             case 'log_messages':
                 if($dist == 'debian') $logfile = '/var/log/messages';
 				if($dist == 'redhat') $logfile = '/var/log/messages';
 				if($dist == 'suse') $logfile = '/var/log/messages';
+				if($dist == 'gentoo') $logfile = '/var/log/messages';
                 break;
             case 'log_ispc_cron':
                 if($dist == 'debian') $logfile = '/var/log/ispconfig/cron.log';
 				if($dist == 'redhat') $logfile = '/var/log/ispconfig/cron.log';
 				if($dist == 'suse') $logfile = '/var/log/ispconfig/cron.log';
+				if($dist == 'gentoo') $logfile = '/var/log/cron';
                 break;
             case 'log_freshclam':
                 if($dist == 'debian') $logfile = '/var/log/clamav/freshclam.log';
 				if($dist == 'redhat') $logfile = (is_file('/var/log/clamav/freshclam.log') ? '/var/log/clamav/freshclam.log' : '/var/log/freshclam.log');
                 if($dist == 'suse') $logfile = '';
+                if($dist == 'gentoo') $logfile = '/var/log/clamav/freshclam.log';
 				break;
             case 'log_clamav':
                 if($dist == 'debian') $logfile = '/var/log/clamav/clamav.log';
 				if($dist == 'redhat') $logfile = (is_file('/var/log/clamav/clamd.log') ? '/var/log/clamav/clamd.log' : '/var/log/maillog');
 				if($dist == 'suse') $logfile = '';
+				if($dist == 'gentoo') $logfile = '/var/log/clamav/clamd.log';
                 break;
             case 'log_fail2ban':
                 if($dist == 'debian') $logfile = '/var/log/fail2ban.log';
 				if($dist == 'redhat') $logfile = '/var/log/fail2ban.log';
 				if($dist == 'suse') $logfile = '/var/log/fail2ban.log';
+				if($dist == 'gentoo') $logfile = '/var/log/fail2ban.log';
                 break;
             case 'log_ispconfig':
                 if($dist == 'debian') $logfile = '/var/log/ispconfig/ispconfig.log';
 				if($dist == 'redhat') $logfile = '/var/log/ispconfig/ispconfig.log';
 				if($dist == 'suse') $logfile = '/var/log/ispconfig/ispconfig.log';
+				if($dist == 'gentoo') $logfile = '/var/log/ispconfig/ispconfig.log';
                 break;
             default:
                 $logfile = '';
diff --git a/server/plugins-available/network_settings_plugin.inc.php b/server/plugins-available/network_settings_plugin.inc.php
index bf75b40..cfe33c7 100644
--- a/server/plugins-available/network_settings_plugin.inc.php
+++ b/server/plugins-available/network_settings_plugin.inc.php
@@ -80,86 +80,162 @@
 		$server_config = $app->getconf->get_server_config($conf["server_id"], 'server');
 		
 		// Configure the debian network card settings
-		if(is_file('/etc/debian_version') && $server_config['auto_network_configuration'] == 'y') {
-			copy('/etc/network/interfaces','/etc/network/interfaces~');
+		if($server_config['auto_network_configuration'] == 'y') {
 			
-			$app->load('tpl');
+			if (is_file('/etc/debian_version')) 
+			{
+				copy('/etc/network/interfaces','/etc/network/interfaces~');
 			
-			$network_tpl = new tpl();
-			$network_tpl->newTemplate("debian_network_interfaces.master");
+				$app->load('tpl');
 				
-			$network_tpl->setVar('ip_address',$server_config["ip_address"]);
-			$network_tpl->setVar('netmask',$server_config["netmask"]);
-			$network_tpl->setVar('gateway',$server_config["gateway"]);
-			$network_tpl->setVar('broadcast',$this->broadcast($server_config["ip_address"],$server_config["netmask"]));
-			$network_tpl->setVar('network',$this->network($server_config["ip_address"],$server_config["netmask"]));
-			
-			$records = $app->db->queryAllRecords("SELECT ip_address FROM server_ip WHERE server_id = ".intval($conf["server_id"]) . " order by ip_address");
-			$ip_records = array();
-			$additionl_ip_records = 0;
-			$n = 0;
-			if(is_array($records)) {
-				foreach($records as $rec) {
-					/*
-					 * don't insert the main-ip again!
-					 */
-					if ($rec['ip_address'] != $server_config["ip_address"])
-					{
-						$ip_records[$n] = array(
-							'id' => $n,
-							'ip_address' => $rec['ip_address'],
-							'netmask' => $server_config["netmask"],
-							'gateway' => $server_config["gateway"],
-							'broadcast' => $this->broadcast($rec['ip_address'],$server_config["netmask"]),
-							'network' => $this->network($rec['ip_address'],$server_config["netmask"])
-						);
-						$additionl_ip_records = 1;
-						$n++;
+				$network_tpl = new tpl();
+				$network_tpl->newTemplate("debian_network_interfaces.master");
+					
+				$network_tpl->setVar('ip_address',$server_config["ip_address"]);
+				$network_tpl->setVar('netmask',$server_config["netmask"]);
+				$network_tpl->setVar('gateway',$server_config["gateway"]);
+				$network_tpl->setVar('broadcast',$this->broadcast($server_config["ip_address"],$server_config["netmask"]));
+				$network_tpl->setVar('network',$this->network($server_config["ip_address"],$server_config["netmask"]));
+				
+				$records = $app->db->queryAllRecords("SELECT ip_address FROM server_ip WHERE server_id = ".intval($conf["server_id"]) . " order by ip_address");
+				$ip_records = array();
+				$additionl_ip_records = 0;
+				$n = 0;
+				if(is_array($records)) {
+					foreach($records as $rec) {
+						/*
+						 * don't insert the main-ip again!
+						 */
+						if ($rec['ip_address'] != $server_config["ip_address"])
+						{
+							$ip_records[$n] = array(
+								'id' => $n,
+								'ip_address' => $rec['ip_address'],
+								'netmask' => $server_config["netmask"],
+								'gateway' => $server_config["gateway"],
+								'broadcast' => $this->broadcast($rec['ip_address'],$server_config["netmask"]),
+								'network' => $this->network($rec['ip_address'],$server_config["netmask"])
+							);
+							$additionl_ip_records = 1;
+							$n++;
+						}
 					}
 				}
-			}
-			
-			/*
-			 * If we have more than 1 IP we have to add the main-ip at the end
-			 * of the network-ip-list. If we don't do so, there may be problems
-			 * in multi-server-settings (with the acces from other server to the
-			 * main-server) because the LAST IP in the list is the IP mysql uses
-			 * to determine the host, the user is logging in from.
-			 */
-			if ($additionl_ip_records != 0)
-			{
-				$swap["ip_address"] = $ip_records[$n-1]["ip_address"];
-				$swap["netmask"] = $ip_records[$n-1]["netmask"];
-				$swap["gateway"] = $ip_records[$n-1]["gateway"];
 				
-				$ip_records[$n-1] = array(
-					'id' => $n-1,
-					'ip_address' => $server_config['ip_address'],
-					'netmask' => $server_config["netmask"],
-					'gateway' => $server_config["gateway"],
-					'broadcast' => $this->broadcast($server_config['ip_address'],$server_config["netmask"]),
-					'network' => $this->network($server_config['ip_address'],$server_config["netmask"])
-				);
-				$network_tpl->setVar('ip_address',$swap["ip_address"]);
-				$network_tpl->setVar('netmask',$swap["netmask"]);
-				$network_tpl->setVar('gateway',$swap["gateway"]);
-				$network_tpl->setVar('broadcast',$this->broadcast($swap["ip_address"],$swap["netmask"]));
-				$network_tpl->setVar('network',$this->network($swap["ip_address"],$swap["netmask"]));
-			}
-			
-			$network_tpl->setVar('additionl_ip_records',$additionl_ip_records);
-			$network_tpl->setLoop('interfaces',$ip_records);
-			file_put_contents('/etc/network/interfaces',$network_tpl->grab());
-			unset($network_tpl);
-			
-			$app->log("Changed Network settings",LOGLEVEL_DEBUG);
-			exec('/etc/init.d/networking force-reload');
-		} else {
-			if(is_file('/etc/debian_version')) {
-				$app->log("Network configuration disabled in server settings.",LOGLEVEL_WARN);
-			} else {
+				/*
+				 * If we have more than 1 IP we have to add the main-ip at the end
+				 * of the network-ip-list. If we don't do so, there may be problems
+				 * in multi-server-settings (with the acces from other server to the
+				 * main-server) because the LAST IP in the list is the IP mysql uses
+				 * to determine the host, the user is logging in from.
+				 */
+				if ($additionl_ip_records != 0)
+				{
+					$swap["ip_address"] = $ip_records[$n-1]["ip_address"];
+					$swap["netmask"] = $ip_records[$n-1]["netmask"];
+					$swap["gateway"] = $ip_records[$n-1]["gateway"];
+					
+					$ip_records[$n-1] = array(
+						'id' => $n-1,
+						'ip_address' => $server_config['ip_address'],
+						'netmask' => $server_config["netmask"],
+						'gateway' => $server_config["gateway"],
+						'broadcast' => $this->broadcast($server_config['ip_address'],$server_config["netmask"]),
+						'network' => $this->network($server_config['ip_address'],$server_config["netmask"])
+					);
+					$network_tpl->setVar('ip_address',$swap["ip_address"]);
+					$network_tpl->setVar('netmask',$swap["netmask"]);
+					$network_tpl->setVar('gateway',$swap["gateway"]);
+					$network_tpl->setVar('broadcast',$this->broadcast($swap["ip_address"],$swap["netmask"]));
+					$network_tpl->setVar('network',$this->network($swap["ip_address"],$swap["netmask"]));
+				}
+				
+				$network_tpl->setVar('additionl_ip_records',$additionl_ip_records);
+				$network_tpl->setLoop('interfaces',$ip_records);
+				file_put_contents('/etc/network/interfaces',$network_tpl->grab());
+				unset($network_tpl);
+				
+				$app->log("Changed Network settings",LOGLEVEL_DEBUG);
+				exec('/etc/init.d/networking force-reload');
+			} 
+			elseif (is_file('/etc/gentoo-release')) 
+			{
+				copy('/etc/conf.d/net','/etc/conf.d/net~');
+				
+				$app->load('tpl');
+				
+				$network_tpl = new tpl();
+				$network_tpl->newTemplate("gentoo_network_interfaces.master");
+				
+				$network_tpl->setVar('ip_address',$server_config["ip_address"]);
+				$network_tpl->setVar('netmask',$server_config["netmask"]);
+				$network_tpl->setVar('gateway',$server_config["gateway"]);
+				$network_tpl->setVar('broadcast',$this->broadcast($server_config["ip_address"],$server_config["netmask"]));
+				
+				$records = $app->db->queryAllRecords("SELECT ip_address FROM server_ip WHERE server_id = ".intval($conf["server_id"]) . " order by ip_address");
+				$ip_records = array();
+				$additionl_ip_records = 0;
+				$n = 0;
+				if(is_array($records)) {
+					foreach($records as $rec) {
+						/*
+						 * don't insert the main-ip again!
+						 */
+						if ($rec['ip_address'] != $server_config["ip_address"])
+						{
+							$ip_records[$n] = array(
+								'id' => $n,
+								'ip_address' => $rec['ip_address'],
+								'netmask' => $server_config["netmask"],
+								'gateway' => $server_config["gateway"],
+								'broadcast' => $this->broadcast($rec['ip_address'],$server_config["netmask"])
+							);
+							$additionl_ip_records = 1;
+							$n++;
+						}
+					}
+				}
+				
+				/*
+				 * If we have more than 1 IP we have to add the main-ip at the end
+				 * of the network-ip-list. If we don't do so, there may be problems
+				 * in multi-server-settings (with the acces from other server to the
+				 * main-server) because the LAST IP in the list is the IP mysql uses
+				 * to determine the host, the user is logging in from.
+				 */
+				if ($additionl_ip_records != 0)
+				{
+					$swap["ip_address"] = $ip_records[$n-1]["ip_address"];
+					$swap["netmask"] = $ip_records[$n-1]["netmask"];
+					$swap["gateway"] = $ip_records[$n-1]["gateway"];
+					
+					$ip_records[$n-1] = array(
+						'id' => $n-1,
+						'ip_address' => $server_config['ip_address'],
+						'netmask' => $server_config["netmask"],
+						'gateway' => $server_config["gateway"],
+						'broadcast' => $this->broadcast($server_config['ip_address'],$server_config["netmask"])
+					);
+					$network_tpl->setVar('ip_address',$swap["ip_address"]);
+					$network_tpl->setVar('netmask',$swap["netmask"]);
+					$network_tpl->setVar('gateway',$swap["gateway"]);
+					$network_tpl->setVar('broadcast',$this->broadcast($swap["ip_address"],$swap["netmask"]));
+				}
+				
+				$network_tpl->setVar('additionl_ip_records',$additionl_ip_records);
+				$network_tpl->setLoop('interfaces',$ip_records);
+				file_put_contents('/etc/conf.d/net',$network_tpl->grab());
+				unset($network_tpl);
+				
+				$app->log("Changed Network settings",LOGLEVEL_DEBUG);
+				exec('/etc/init.d/net.eth0 restart');
+			} 
+			else {
 				$app->log("Network configuration not available for this linux distribution.",LOGLEVEL_DEBUG);
 			}
+			
+		} else {
+			$app->log("Network configuration disabled in server settings.",LOGLEVEL_WARN);
 		}
 		
 	}

--
Gitblit v1.9.1