Subversion Repositories ALCASAR

Rev

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

Rev 876 Rev 1240
1
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
1
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
2
<HTML><!-- written by Rexy -->
2
<HTML><!-- written by Rexy -->
3
<HEAD>
3
<HEAD>
4
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
4
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
5
<TITLE>ALCASAR Filter Exceptions</TITLE>
5
<TITLE>ALCASAR Filter Exceptions</TITLE>
6
<link rel="stylesheet" href="/css/style.css" type="text/css">
6
<link rel="stylesheet" href="/css/style.css" type="text/css">
7
</HEAD>
7
</HEAD>
8
<body>
8
<body>
9
<?
9
<?
10
# Choice of language
10
# Choice of language
11
$Language = 'en';
11
$Language = 'en';
12
if(isset($_SERVER['HTTP_ACCEPT_LANGUAGE'])){
12
if(isset($_SERVER['HTTP_ACCEPT_LANGUAGE'])){
13
  $Langue = explode(",",$_SERVER['HTTP_ACCEPT_LANGUAGE']);
13
  $Langue = explode(",",$_SERVER['HTTP_ACCEPT_LANGUAGE']);
14
  $Language = strtolower(substr(chop($Langue[0]),0,2)); }
14
  $Language = strtolower(substr(chop($Langue[0]),0,2)); }
15
if($Language == 'fr'){
15
if($Language == 'fr'){
16
  $l_error_open_file="Erreur d'ouverture du fichier";
16
  $l_error_open_file="Erreur d'ouverture du fichier";
17
  $l_exception_IP = "Exception au filtrage";
17
  $l_exception_IP = "Exception au filtrage";
18
  $l_exception_txt="Entrez ici les adresses IP des stations du réseau de consultation ne subissant ni filtrage de domaine ni filtrage réseau<BR>Entrez une adresse IP par ligne";
18
  $l_exception_txt="Entrez ici les adresses IP des stations du réseau de consultation ne subissant ni filtrage de domaine ni filtrage réseau<BR>Entrez une adresse IP par ligne";
19
  $l_submit = "Enregistrer";
19
  $l_submit = "Enregistrer";
20
}
20
}
21
else {
21
else {
22
  $l_error_open_file="Error opening the file";
22
  $l_error_open_file="Error opening the file";
23
  $l_exception_IP = "Network filtering exceptions";
23
  $l_exception_IP = "Network filtering exceptions";
24
  $l_exception_txt="Put here the stations IP address that won't be neither domain filtered nor network filtered<BR>Put one IP per row";
24
  $l_exception_txt="Put here the stations IP address that won't be neither domain filtered nor network filtered<BR>Put one IP per row";
25
  $l_submit = "Submit";
25
  $l_submit = "Submit";
26
}
26
}
27
$conf_file="/usr/local/etc/alcasar.conf";
27
$conf_file="/usr/local/etc/alcasar.conf";
28
if (isset($_POST['choix'])){ 
28
if (isset($_POST['choix'])){ 
29
	switch ($_POST['choix'])
29
	switch ($_POST['choix'])
30
	{
30
	{
31
	case 'IP_exceptions' :
31
	case 'IP_exceptions' :
32
		// ISO encode + unix format 
32
		// ISO encode + unix format 
33
		$ip_list = str_replace("\r\n", "\n", utf8_decode($_POST['exception_list']));
33
		$ip_list = str_replace("\r\n", "\n", utf8_decode($_POST['exception_list']));
34
		unset($_POST['exception_list']);
34
		unset($_POST['exception_list']);
35
		// write exception IP for Dansguardian (URL filter)
35
		// write exception IP for Dansguardian (URL filter)
36
		$fichier=fopen("/etc/dansguardian/lists/exceptioniplist", "w+");
36
		$fichier=fopen("/etc/dansguardian/lists/exceptioniplist", "w+");
37
		if (strlen($ip_list) > 7) { fputs($fichier,$ip_list);} //only if not empty
37
		if (strlen($ip_list) > 7) { fputs($fichier,$ip_list);} //only if not empty
38
		fclose($fichier);
38
		fclose($fichier);
39
		// write exception IP for DnsMasq (DNS blackholl)
39
		// write exception IP for DnsMasq (DNS blackholl)
40
		$fichier=fopen("/usr/local/etc/alcasar-filter-exceptions", "w+");
40
		$fichier=fopen("/usr/local/etc/alcasar-filter-exceptions", "w+");
41
		if (strlen($ip_list) > 7) { fputs($fichier, $ip_list);} // only if not empty
41
		if (strlen($ip_list) > 7) { fputs($fichier, $ip_list);} // only if not empty
42
		fclose($fichier);
42
		fclose($fichier);
43
		// test if Dansguardian filter is enabled
43
		// test if Dansguardian filter is enabled
44
		if (is_file ($conf_file))
44
		if (is_file ($conf_file))
45
			{
45
			{
46
			$tab=file($conf_file);
46
			$tab=file($conf_file);
47
			if ($tab)
47
			if ($tab)
48
				{
48
				{
49
				foreach ($tab as $line)
49
				foreach ($tab as $line)
50
					{
50
					{
51
					$field=explode("=", $line);
51
					$field=explode("=", $line);
52
					if ($field[0] == "DNS_FILTERING")	{$DNS_FILTERING=trim($field[1]);}
52
					if ($field[0] == "DNS_FILTERING")	{$DNS_FILTERING=trim($field[1]);}
53
					if ($field[0] == "PROTOCOLS_FILTERING")	{$PROTOCOLS_FILTERING=trim($field[1]);}
53
					if ($field[0] == "PROTOCOLS_FILTERING")	{$PROTOCOLS_FILTERING=trim($field[1]);}
54
					}
54
					}
55
				}
55
				}
56
			}
56
			}
57
		else { echo "$l_error_open_file $conf_file";}
57
		else { echo "$l_error_open_file $conf_file";}
58
		if ($DNS_FILTERING == "on")
58
		if ($DNS_FILTERING == "on")
59
			{
59
			{
60
			exec ("sudo service dansguardian restart");
60
			exec ("sudo service dansguardian restart");
61
			}
61
			}
62
		if (($DNS_FILTERING == "on")||($PROTOCOLS_FILTERING == "on"))
62
		if (($DNS_FILTERING == "on")||($PROTOCOLS_FILTERING == "on"))
63
			{
63
			{
64
			exec ("sudo /usr/local/bin/alcasar-iptables.sh"); 
64
			exec ("sudo /usr/local/bin/alcasar-iptables.sh"); 
65
			}
65
			}
66
	break;
66
	break;
67
	}	
67
	}	
68
}
68
}
69
?>
69
?>
70
<TABLE width="100%" border="0" cellspacing="0" cellpadding="0">
70
<TABLE width="100%" border="0" cellspacing="0" cellpadding="0">
71
	<tr><th><?php echo $l_exception_IP ;?></th></tr>
71
	<tr><th><?php echo $l_exception_IP ;?></th></tr>
72
	<tr bgcolor="#FFCC66"><td><img src="/images/pix.gif" width="1" height="2"></td></tr>
72
	<tr bgcolor="#FFCC66"><td><img src="/images/pix.gif" width="1" height="2"></td></tr>
73
</TABLE>
73
</TABLE>
74
<TABLE width="100%" border=1 cellspacing=0 cellpadding=1>
74
<TABLE width="100%" border=1 cellspacing=0 cellpadding=1>
75
<tr><td valign="middle" align="left">
75
<tr><td valign="middle" align="left">
76
<TABLE width=70% border=0>
76
<TABLE width=70% border=0>
77
<?php
77
<?php
78
echo "<form action='$_SERVER[PHP_SELF]' method='POST'>";
78
echo "<form action='$_SERVER[PHP_SELF]' method='POST'>";
79
echo " $l_exception_txt";
79
echo " $l_exception_txt";
80
echo "<BR><textarea name='exception_list' rows=5 cols=40>";
80
echo "<BR><textarea name='exception_list' rows=5 cols=40>";
81
$filename="/usr/local/etc/alcasar-filter-exceptions";
81
$filename="/usr/local/etc/alcasar-filter-exceptions";
82
if (file_exists($filename))
82
if (file_exists($filename))
83
	{
83
	{
84
	if (filesize($filename) != 0)
84
	if (filesize($filename) != 0)
85
		{
85
		{
86
		$pointeur=fopen($filename,"r");
86
		$pointeur=fopen($filename,"r");
87
		$tampon = fread($pointeur, filesize($filename));
87
		$tampon = fread($pointeur, filesize($filename));
88
		fclose($pointeur);
88
		fclose($pointeur);
89
		echo $tampon;
89
		echo $tampon;
90
		}
90
		}
91
	}
91
	}
92
	else
92
	else
93
	{
93
	{
94
	echo "erreur d'ouverture du fichier $filename";
94
	echo "erreur d'ouverture du fichier $filename";
95
	}
95
	}
96
echo "</textarea><BR>";
96
echo "</textarea><BR>";
97
?>
97
?>
98
<input type='hidden' name='choix' value='IP_exceptions'>
98
<input type='hidden' name='choix' value='IP_exceptions'>
99
<input type='submit' value='Enregistrer les modifications'></CENTER>
99
<input type='submit' value='<?php echo $l_submit ;?>'></CENTER>
100
</FORM>
100
</FORM>
101
</td></tr>
101
</td></tr>
102
</TABLE>
102
</TABLE>
103
</BODY>
103
</BODY>
104
</HTML>
104
</HTML>
105
 
105