Subversion Repositories ALCASAR

Rev

Rev 65 | Go to most recent revision | Only display areas with differences | Ignore whitespace | Details | Blame | Last modification | View Log

Rev 65 Rev 110
1
<?php 
1
<?php 
2
/***************************************************************************
2
/***************************************************************************
3
 *   Copyright (C) 2006 by phpSysInfo - A PHP System Information Script    *
3
 *   Copyright (C) 2006 by phpSysInfo - A PHP System Information Script    *
4
 *   http://phpsysinfo.sourceforge.net/                                    *
4
 *   http://phpsysinfo.sourceforge.net/                                    *
5
 *   Copyright (C) 2010 by 3abtux & Rexy for ALCASAR                       *                                                *
5
 *   Copyright (C) 2010 by 3abtux & Rexy for ALCASAR                       *                                                *
6
 *   This program is free software; you can redistribute it and/or modify  *
6
 *   This program is free software; you can redistribute it and/or modify  *
7
 *   it under the terms of the GNU General Public License as published by  *
7
 *   it under the terms of the GNU General Public License as published by  *
8
 *   the Free Software Foundation; either version 2 of the License, or     *
8
 *   the Free Software Foundation; either version 2 of the License, or     *
9
 *   (at your option) any later version.                                   *
9
 *   (at your option) any later version.                                   *
10
 *                                                                         *
10
 *                                                                         *
11
 *   This program is distributed in the hope that it will be useful,       *
11
 *   This program is distributed in the hope that it will be useful,       *
12
 *   but WITHOUT ANY WARRANTY; without even the implied warranty of        *
12
 *   but WITHOUT ANY WARRANTY; without even the implied warranty of        *
13
 *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         *
13
 *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         *
14
 *   GNU General Public License for more details.                          *
14
 *   GNU General Public License for more details.                          *
15
 *                                                                         *
15
 *                                                                         *
16
 *   You should have received a copy of the GNU General Public License     *
16
 *   You should have received a copy of the GNU General Public License     *
17
 *   along with this program; if not, write to the                         *
17
 *   along with this program; if not, write to the                         *
18
 *   Free Software Foundation, Inc.,                                       *
18
 *   Free Software Foundation, Inc.,                                       *
19
 *   59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.             *
19
 *   59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.             *
20
 ***************************************************************************/
20
 ***************************************************************************/
21
 
21
 
22
// $Id: vitals.php,v 1.32 2007/02/18 18:59:54 bigmichi1 Exp $
22
// $Id: vitals.php,v 1.32 2007/02/18 18:59:54 bigmichi1 Exp $
23
 
23
 
24
// xml_utilisateur()
24
// xml_utilisateur()
25
 
25
 
26
function request ($texte) {
26
function request ($texte) {
27
		$strResult = 0;
27
		$strResult = 0;
28
		// Déclaration des paramètres de connexion
28
		// Déclaration des paramètres de connexion
29
		$host = "localhost";
29
		$host = "localhost";
30
		$DB_USER = "radius";
30
		$DB_USER = "radius";
31
		$DB_RADIUS = "radius";
31
		$DB_RADIUS = "radius";
32
		$radiuspwd = "xKosCPLa";
32
		$radiuspwd = "W7AH5bp8";
33
		// Connexion au serveur
33
		// Connexion au serveur
34
		mysql_connect($host, $DB_USER,$radiuspwd) or die("erreur de connexion au serveur");
34
		mysql_connect($host, $DB_USER,$radiuspwd) or die("erreur de connexion au serveur");
35
		mysql_select_db($DB_RADIUS) or die("erreur de connexion a la base de donnees");
35
		mysql_select_db($DB_RADIUS) or die("erreur de connexion a la base de donnees");
36
		// Creation et envoi de la requete
36
		// Creation et envoi de la requete
37
		if ($texte = 'user') {$query = "SELECT UserName FROM userinfo";}
37
		if ($texte == 'user') {$query = "SELECT UserName FROM userinfo";}
38
		else { $query = "SELECT GroupName FROM radusergroup GROUP BY GroupName";}
38
		else { $query = "SELECT GroupName FROM radusergroup GROUP BY GroupName";}
39
		$result = mysql_query($query);
39
		$result = mysql_query($query);
40
		// Recuperation des resultats
40
		// Recuperation des resultats
41
		$strResult = mysql_num_rows($result);
41
		$strResult = mysql_num_rows($result);
42
		// Deconnexion de la base de donnees
42
		// Deconnexion de la base de donnees
43
		 mysql_close();
43
		 mysql_close();
44
		return $strResult;
44
		return $strResult;
45
  }
45
  }
46
function xml_portail () {
46
function xml_portail () {
47
	global $sysinfo;
47
	global $sysinfo;
48
	
48
	
49
	$_text = "  <Portail>\n"
49
	$_text = "  <Portail>\n"
50
//		. "    <Utilisateur>" . htmlspecialchars( $sysinfo->utilisateur(), ENT_QUOTES ) . "</Utilisateur>\n"
50
//		. "    <Utilisateur>" . htmlspecialchars( request('user'), ENT_QUOTES ) . "</Utilisateur>\n"
51
		. "    <Utilisateur>" . htmlspecialchars( request('user'), ENT_QUOTES ) . "</Utilisateur>\n"
51
		. "    <Utilisateur>" . "</Utilisateur>\n"
-
 
52
		. "    <Groupe>" . "</Groupe>\n";
52
		. "    <Groupe>" . htmlspecialchars( trim( request('group') ), ENT_QUOTES ) . "</Groupe>\n";
53
//		. "    <Groupe>" . htmlspecialchars( trim( request('group') ), ENT_QUOTES ) . "</Groupe>\n";
53
	$_text .= "  </Portail>\n";
54
	$_text .= "  </Portail>\n";
54
	
55
	
55
	return $_text;
56
	return $_text;
56
} 
57
} 
57
// Fonction de test de connectivité internet
58
// Fonction de test de connectivité internet
58
function internetTest(){
59
function internetTest(){
59
	$host = "www.google.fr";
60
	$host = "www.google.fr";
60
	$port = "80";
61
	$port = "80";
61
	//var $num;	//non utilisé
62
	//var $num;	//non utilisé
62
	//var $error;	//non utilisé
63
	//var $error;	//non utilisé
63
	
64
	
64
	if (! $sock = @fsockopen($host, $port, $num, $error, 5)) {
65
	if (! $sock = @fsockopen($host, $port, $num, $error, 5)) {
65
		return false;
66
		return false;
66
	} else {
67
	} else {
67
		fclose($sock);
68
		fclose($sock);
68
		return true;
69
		return true;
69
	}
70
	}
70
}
71
}
71
// Fonction de test du filtrage
72
// Fonction de test du filtrage
72
function filtrageTest($file, $search_regex){
73
function filtrageTest($file, $search_regex){
73
	$pointeur = fopen($file,"r");
74
	$pointeur = fopen($file,"r");
74
	$result = false;
75
	$result = false;
75
	if ($pointeur)
76
	if ($pointeur)
76
		{
77
		{
77
		while (!feof($pointeur))
78
		while (!feof($pointeur))
78
			{
79
			{
79
				$ligne = fgets($pointeur);
80
				$ligne = fgets($pointeur);
80
				if (preg_match($search_regex, $ligne, $r))
81
				if (preg_match($search_regex, $ligne, $r))
81
				{
82
				{
82
				$result = true;
83
				$result = true;
83
				break;
84
				break;
84
				}
85
				}
85
			}
86
			}
86
		}
87
		}
87
	fclose($pointeur);
88
	fclose($pointeur);
88
	return $result;
89
	return $result;
89
}
90
}
90
// html_portail()
91
// html_portail()
91
function html_portail () {
92
function html_portail () {
92
	global $webpath;
93
	global $webpath;
93
	global $XPath;
94
	global $XPath;
94
	global $text;
95
	global $text;
95
 
96
 
96
	$file_version = "/var/www/html/VERSION";
97
	$file_version = "/var/www/html/VERSION";
97
	$handle = fopen ($file_version, "r");
98
	$handle = fopen ($file_version, "r");
98
	$INSTALLEDVERSION = fread ($handle, filesize ($file_version));
99
	$INSTALLEDVERSION = fread ($handle, filesize ($file_version));
99
	fclose ($handle);
100
	fclose ($handle);
100
	$file_bl = "/var/www/html/VERSION-BL";
101
	$file_bl = "/var/www/html/VERSION-BL";
101
	$handle = fopen ($file_bl, "r");
102
	$handle = fopen ($file_bl, "r");
102
	$VERSIONBL = fread ($handle, filesize ($file_bl));
103
	$VERSIONBL = fread ($handle, filesize ($file_bl));
103
	fclose ($handle);
104
	fclose ($handle);
104
	$nbr_user = request ('user');
105
	$nbr_user = request ('user');
105
	$nbr_grp  = request ('group');
106
	$nbr_grp  = request ('group');
106
	$nbr_user_online = exec ("sudo /usr/sbin/chilli_query list | cut -d\" \" -f5 | grep \"1\" | wc -l");
107
	$nbr_user_online = exec ("sudo /usr/sbin/chilli_query list | cut -d\" \" -f5 | grep \"1\" | wc -l");
107
	if (filtrageTest("/usr/local/bin/alcasar-iptables.sh", "/^FILTERING=\"yes\"/")){
108
	if (filtrageTest("/usr/local/bin/alcasar-iptables.sh", "/^FILTERING=\"yes\"/")){
108
		$network_filter_status = $text['enable'];}
109
		$network_filter_status = $text['enable'];}
109
	else {	$network_filter_status = $text['disable'];}
110
	else {	$network_filter_status = $text['disable'];}
110
	if (filtrageTest("/etc/dansguardian/dansguardian.conf","/^reportinglevel = 3/")){
111
	if (filtrageTest("/etc/dansguardian/dansguardian.conf","/^reportinglevel = 3/")){
111
		$web_filter_status = $text['enable'];}
112
		$web_filter_status = $text['enable'];}
112
	else {	$web_filter_status = $text['disable'];}
113
	else {	$web_filter_status = $text['disable'];}
113
	if (InternetTest()){
114
	if (InternetTest()){
114
		$internet_status =  "<img src='/images/state_ok.gif'>".$text['enable'];
115
		$internet_status =  "<img src='/images/state_ok.gif'>".$text['enable'];
115
		$version = dns_get_record("version.alcasar.info",DNS_TXT);
116
		$version = dns_get_record("version.alcasar.info",DNS_TXT);
116
		$AVAILABLEDVERSION = $version[0]['txt'];
117
		$AVAILABLEDVERSION = $version[0]['txt'];
117
	} else {
118
	} else {
118
		$internet_status =  "<img src='/images/state_error.gif'>".$text['disable'];
119
		$internet_status =  "<img src='/images/state_error.gif'>".$text['disable'];
119
		$AVAILABLEDVERSION = "-";
120
		$AVAILABLEDVERSION = "-";
120
	}
121
	}
121
	$_text = "<table border=\"0\" width=\"100%\" align=\"center\">\n"
122
	$_text = "<table border=\"0\" width=\"100%\" align=\"center\">\n"
122
		. "  <tr>\n"
123
		. "  <tr>\n"
123
		. "    <td valign=\"top\"><font size=\"-1\">" . $text['portail-version'] . "</font></td>\n"
124
		. "    <td valign=\"top\"><font size=\"-1\">" . $text['portail-version'] . "</font></td>\n"
124
		. "    <td><font size=\"-1\">" . $INSTALLEDVERSION . "</font></td>\n"
125
		. "    <td><font size=\"-1\">" . $INSTALLEDVERSION . "</font></td>\n"
125
		. "  </tr>\n"
126
		. "  </tr>\n"
126
		. "  <tr>\n"
127
		. "  <tr>\n"
127
		. "    <td valign=\"top\"><font size=\"-1\">" . $text['portail-disp'] . "</font></td>\n"
128
		. "    <td valign=\"top\"><font size=\"-1\">" . $text['portail-disp'] . "</font></td>\n"
128
		. "    <td><font size=\"-1\">" . $AVAILABLEDVERSION . "</font></td>\n"
129
		. "    <td><font size=\"-1\">" . $AVAILABLEDVERSION . "</font></td>\n"
129
		. "  </tr>\n"
130
		. "  </tr>\n"
130
		. "  <tr>\n"
131
		. "  <tr>\n"
131
		. "    <td valign=\"top\"><font size=\"-1\">" . $text['utilisateur'] . "</font></td>\n"
132
		. "    <td valign=\"top\"><font size=\"-1\">" . $text['utilisateur'] . "</font></td>\n"
132
		. "    <td><font size=\"-1\">" . $nbr_user_online . " / " . $nbr_user . "</font></td>\n"
133
		. "    <td><font size=\"-1\">" . $nbr_user_online . " / " . $nbr_user . "</font></td>\n"
133
		. "  </tr>\n"
134
		. "  </tr>\n"
134
		. "  <tr>\n"
135
		. "  <tr>\n"
135
		. "    <td valign=\"top\"><font size=\"-1\">" . $text['groupe'] . "</font></td>\n"
136
		. "    <td valign=\"top\"><font size=\"-1\">" . $text['groupe'] . "</font></td>\n"
136
		. "    <td><font size=\"-1\">" . $nbr_grp . "</font></td>\n"
137
		. "    <td><font size=\"-1\">" . $nbr_grp . "</font></td>\n"
137
		. "  </tr>\n"
138
		. "  </tr>\n"
138
		. "  <tr>\n"
139
		. "  <tr>\n"
139
		. "    <td valign=\"top\"><font size=\"-1\">" . $text['bl-version'] . "</font></td>\n"
140
		. "    <td valign=\"top\"><font size=\"-1\">" . $text['bl-version'] . "</font></td>\n"
140
		. "    <td><font size=\"-1\">" . $VERSIONBL . "</font></td>\n"
141
		. "    <td><font size=\"-1\">" . $VERSIONBL . "</font></td>\n"
141
		. "  </tr>\n"
142
		. "  </tr>\n"
142
		. "  <tr>\n"
143
		. "  <tr>\n"
143
		. "    <td valign=\"top\"><font size=\"-1\">" . $text['filter'] . "</font></td>\n"
144
		. "    <td valign=\"top\"><font size=\"-1\">" . $text['filter'] . "</font></td>\n"
144
		. "    <td><font size=\"-1\">web : " . $web_filter_status . ", " . $text['network'] . " : " . $network_filter_status . "</font></td>\n"
145
		. "    <td><font size=\"-1\">web : " . $web_filter_status . ", " . $text['network'] . " : " . $network_filter_status . "</font></td>\n"
145
		. "  </tr>\n"
146
		. "  </tr>\n"
146
		. "  <tr>\n"
147
		. "  <tr>\n"
147
		. "    <td valign=\"top\"><font size=\"-1\">" . $text['internet_link'] . "</font></td>\n"
148
		. "    <td valign=\"top\"><font size=\"-1\">" . $text['internet_link'] . "</font></td>\n"
148
		. "    <td><font size=\"-1\">" . $internet_status . "</font></td>\n"
149
		. "    <td><font size=\"-1\">" . $internet_status . "</font></td>\n"
149
		. "  </tr>\n"
150
		. "  </tr>\n"
150
		. "</table>\n";
151
		. "</table>\n";
151
	return $_text;
152
	return $_text;
152
} 
153
} 
153
 
154
 
154
function wml_portail () {
155
function wml_portail () {
155
	global $XPath;
156
	global $XPath;
156
	global $text;
157
	global $text;
157
	
158
	
158
	$_text = "<card id=\"vitals\" title=\"" . $text['vitals']  . "\">\n"
159
	$_text = "<card id=\"vitals\" title=\"" . $text['vitals']  . "\">\n"
159
		. "<p>" . $text['hostname'] . ":<br/>\n"
160
		. "<p>" . $text['hostname'] . ":<br/>\n"
160
		. "-&nbsp;" . $XPath->getData( "/phpsysinfo/Vitals/Hostname" ) . "</p>\n"
161
		. "-&nbsp;" . $XPath->getData( "/phpsysinfo/Vitals/Hostname" ) . "</p>\n"
161
		. "<p>" . $text['ip'] . ":<br/>\n"
162
		. "<p>" . $text['ip'] . ":<br/>\n"
162
		. "-&nbsp;" . $XPath->getData( "/phpsysinfo/Vitals/IPAddr" ) . "</p>\n"
163
		. "-&nbsp;" . $XPath->getData( "/phpsysinfo/Vitals/IPAddr" ) . "</p>\n"
163
		. "<p>" . $text['kversion'] . ":<br/>\n"
164
		. "<p>" . $text['kversion'] . ":<br/>\n"
164
		. "-&nbsp;" . $XPath->getData( "/phpsysinfo/Vitals/Kernel" ) . "</p>\n"
165
		. "-&nbsp;" . $XPath->getData( "/phpsysinfo/Vitals/Kernel" ) . "</p>\n"
165
		. "<p>" . $text['uptime'] . ":<br/>\n"
166
		. "<p>" . $text['uptime'] . ":<br/>\n"
166
		. "-&nbsp;" . uptime( $XPath->getData( "/phpsysinfo/Vitals/Uptime" ) ) . "</p>\n"
167
		. "-&nbsp;" . uptime( $XPath->getData( "/phpsysinfo/Vitals/Uptime" ) ) . "</p>\n"
167
		. "<p>" . $text['users'] . ":<br/>"
168
		. "<p>" . $text['users'] . ":<br/>"
168
		. "-&nbsp;" . $XPath->getData( "/phpsysinfo/Vitals/Users" ) . "</p>\n"
169
		. "-&nbsp;" . $XPath->getData( "/phpsysinfo/Vitals/Users" ) . "</p>\n"
169
		. "<p>" . $text['loadavg'] . ":<br/>"
170
		. "<p>" . $text['loadavg'] . ":<br/>"
170
		. "-&nbsp;" . $XPath->getData( "/phpsysinfo/Vitals/LoadAvg" ) . "</p>\n"
171
		. "-&nbsp;" . $XPath->getData( "/phpsysinfo/Vitals/LoadAvg" ) . "</p>\n"
171
		. "</card>\n";
172
		. "</card>\n";
172
	
173
	
173
	return $_text;
174
	return $_text;
174
}
175
}
175
?>
176
?>
176
 
177