From 45b8e41fd93ffdfd67d3d900c77be16ac08f4e82 Mon Sep 17 00:00:00 2001
From: tbrehm <t.brehm@ispconfig.org>
Date: Fri, 24 Apr 2009 06:25:11 -0400
Subject: [PATCH] Edited todo file.
---
install/lib/install.lib.php | 85 ++++++++++++++++++++++++++++++++++++++----
1 files changed, 76 insertions(+), 9 deletions(-)
diff --git a/install/lib/install.lib.php b/install/lib/install.lib.php
index 24c5962..65d9d82 100644
--- a/install/lib/install.lib.php
+++ b/install/lib/install.lib.php
@@ -31,7 +31,6 @@
/*
This function returns a string that describes the installed
linux distribution. e.g. debian40 for Debian Linux 4.0
-
*/
@@ -60,6 +59,9 @@
function get_distname() {
$distname = '';
+ $distver = '';
+ $distid = '';
+ $distbaseid = '';
//** Debian or Ubuntu
if(file_exists('/etc/debian_version')) {
@@ -68,13 +70,20 @@
$distname = 'Debian';
$distver = '4.0';
$distid = 'debian40';
+ $distbaseid = 'debian';
swriteln("Operating System: Debian 4.0 or compatible\n");
- }
- if(trim(file_get_contents('/etc/debian_version')) == 'lenny/sid') {
+ } elseif(strstr(trim(file_get_contents('/etc/debian_version')),'5.0') || trim(file_get_contents('/etc/debian_version')) == 'lenny/sid') {
$distname = 'Debian';
$distver = 'Lenny/Sid';
$distid = 'debian40';
+ $distbaseid = 'debian';
swriteln("Operating System: Debian Lenny/Sid or compatible\n");
+ } else {
+ $distname = 'Debian';
+ $distver = 'Unknown';
+ $distid = 'debian40';
+ $distbaseid = 'debian';
+ swriteln("Operating System: Debian or compatible, unknown version.\n");
}
}
@@ -84,7 +93,26 @@
$distname = 'openSUSE';
$distver = '11.0';
$distid = 'opensuse110';
+ $distbaseid = 'opensuse';
swriteln("Operating System: openSUSE 11.0 or compatible\n");
+ } elseif(stristr(file_get_contents('/etc/SuSE-release'),'11.1')) {
+ $distname = 'openSUSE';
+ $distver = '11.1';
+ $distid = 'opensuse110';
+ $distbaseid = 'opensuse';
+ swriteln("Operating System: openSUSE 11.1 or compatible\n");
+ } elseif(stristr(file_get_contents('/etc/SuSE-release'),'11.2')) {
+ $distname = 'openSUSE';
+ $distver = '11.1';
+ $distid = 'opensuse110';
+ $distbaseid = 'opensuse';
+ swriteln("Operating System: openSUSE 11.2 or compatible\n");
+ } else {
+ $distname = 'openSUSE';
+ $distver = 'Unknown';
+ $distid = 'opensuse110';
+ $distbaseid = 'opensuse';
+ swriteln("Operating System: openSUSE or compatible, unknown version.\n");
}
}
@@ -98,7 +126,32 @@
$distname = 'Fedora';
$distver = '9';
$distid = 'fedora9';
+ $distbaseid = 'fedora';
swriteln("Operating System: Fedora 9 or compatible\n");
+ } elseif(stristr($content,'Fedora release 10 (Cambridge)')) {
+ $distname = 'Fedora';
+ $distver = '10';
+ $distid = 'fedora9';
+ $distbaseid = 'fedora';
+ swriteln("Operating System: Fedora 10 or compatible\n");
+ } elseif(stristr($content,'CentOS release 5.2 (Final)')) {
+ $distname = 'CentOS';
+ $distver = '5.2';
+ $distid = 'centos52';
+ $distbaseid = 'fedora';
+ swriteln("Operating System: CentOS 5.2 or compatible\n");
+ } elseif(stristr($content,'CentOS release 5.3 (Final)')) {
+ $distname = 'CentOS';
+ $distver = '5.3';
+ $distid = 'centos52';
+ $distbaseid = 'fedora';
+ swriteln("Operating System: CentOS 5.3 or compatible\n");
+ } else {
+ $distname = 'Redhat';
+ $distver = 'Unknown';
+ $distid = 'fedora9';
+ $distbaseid = 'fedora';
+ swriteln("Operating System: Redhat or compatible, unknown version.\n");
}
@@ -106,7 +159,7 @@
die('unrecognized linux distribution');
}
- return array('name' => $distname, 'version' => $distver, 'id' => $distid);
+ return array('name' => $distname, 'version' => $distver, 'id' => $distid, 'baseid' => $distbaseid);
}
function sread() {
@@ -497,8 +550,8 @@
return false;
}
-function replaceLine($filename,$search_pattern,$new_line,$strict = 0) {
- $lines = file($filename);
+function replaceLine($filename,$search_pattern,$new_line,$strict = 0,$append = 1) {
+ if($lines = @file($filename)) {
$out = '';
$found = 0;
foreach($lines as $line) {
@@ -519,13 +572,17 @@
}
}
if($found == 0) {
- $out .= $new_line."\n";
+ //* add \n if the last line does not end with \n or \r
+ if(substr($out,-1) != "\n" && substr($out,-1) != "\r") $out .= "\n";
+ //* add the new line at the end of the file
+ if($append == 1) $out .= $new_line."\n";
}
file_put_contents($filename,$out);
+ }
}
function removeLine($filename,$search_pattern,$strict = 0) {
- $lines = file($filename);
+ if($lines = @file($filename)) {
$out = '';
foreach($lines as $line) {
if($strict == 0) {
@@ -539,8 +596,18 @@
}
}
file_put_contents($filename,$out);
+ }
+}
+
+function is_installed($appname) {
+ exec('which '.escapeshellcmd($appname).' > /dev/null 2> /dev/null',$out);
+ if(isset($out[0]) && stristr($out[0],$appname)) {
+ return true;
+ } else {
+ return false;
+ }
}
-?>
\ No newline at end of file
+?>
--
Gitblit v1.9.1