]> git.ipfire.org Git - people/pmueller/ipfire-2.x.git/blame - html/cgi-bin/optionsfw.cgi
firewall: Allow to disable masquerading.
[people/pmueller/ipfire-2.x.git] / html / cgi-bin / optionsfw.cgi
CommitLineData
5595bc03
CS
1#!/usr/bin/perl
2#
3# SmoothWall CGIs
4#
5# This code is distributed under the terms of the GPL
6#
7# (c) The SmoothWall Team
8#
9# Copyright (C) 01-02-2002 Graham Smith <grhm@grhm.co.uk>
10#
11# $Id: optionsfw.cgi,v 1.1.2.10 2005/10/03 00:34:10 gespinasse Exp $
12#
13#
5595bc03
CS
14# enable only the following on debugging purpose
15#use warnings;
16#use CGI::Carp 'fatalsToBrowser';
17
18require '/var/ipfire/general-functions.pl';
19require "${General::swroot}/lang.pl";
20require "${General::swroot}/header.pl";
21
22
23my %checked =(); # Checkbox manipulations
5595bc03 24our %settings=();
3b2ad4a1
AM
25my %fwdfwsettings=();
26my %configfwdfw=();
27my %configoutgoingfw=();
28
6d8eb5de
AM
29my $configfwdfw = "${General::swroot}/firewall/config";
30my $configoutgoing = "${General::swroot}/firewall/outgoing";
5595bc03
CS
31my $errormessage = '';
32my $warnmessage = '';
34f30c5f 33my $filename = "${General::swroot}/optionsfw/settings";
5595bc03 34
6d8eb5de 35&General::readhash("${General::swroot}/firewall/settings", \%fwdfwsettings);
5595bc03
CS
36&Header::showhttpheaders();
37
38#Get GUI values
39&Header::getcgihash(\%settings);
5595bc03 40if ($settings{'ACTION'} eq $Lang::tr{'save'}) {
3b2ad4a1 41 if ($settings{'defpol'} ne '1'){
34f30c5f 42 $errormessage .= $Lang::tr{'new optionsfw later'};
3b2ad4a1 43 &General::writehash($filename, \%settings); # Save good settings
8039a710 44 system("/usr/local/bin/firewallctrl");
3b2ad4a1
AM
45 }else{
46 if ($settings{'POLICY'} ne ''){
47 $fwdfwsettings{'POLICY'} = $settings{'POLICY'};
48 }
49 if ($settings{'POLICY1'} ne ''){
50 $fwdfwsettings{'POLICY1'} = $settings{'POLICY1'};
51 }
52 my $MODE = $fwdfwsettings{'POLICY'};
53 my $MODE1 = $fwdfwsettings{'POLICY1'};
54 %fwdfwsettings = ();
55 $fwdfwsettings{'POLICY'} = "$MODE";
56 $fwdfwsettings{'POLICY1'} = "$MODE1";
6d8eb5de
AM
57 &General::writehash("${General::swroot}/firewall/settings", \%fwdfwsettings);
58 &General::readhash("${General::swroot}/firewall/settings", \%fwdfwsettings);
8039a710 59 system("/usr/local/bin/firewallctrl");
3b2ad4a1 60 }
34f30c5f 61 &General::readhash($filename, \%settings); # Load good settings
3b2ad4a1
AM
62}
63
5595bc03
CS
64&Header::openpage($Lang::tr{'options fw'}, 1, '');
65&Header::openbigbox('100%', 'left', '', $errormessage);
34f30c5f 66&General::readhash($filename, \%settings);
5595bc03
CS
67if ($errormessage) {
68 &Header::openbox('100%', 'left', $Lang::tr{'warning messages'});
69 print "<font color='red'>$errormessage&nbsp;</font>";
70 &Header::closebox();
71}
72
83ef9c40
MT
73# Set new defaults
74if (!$settings{'MASQUERADE_GREEN'}) {
75 $settings{'MASQUERADE_GREEN'} = 'on';
76}
77if (!$settings{'MASQUERADE_ORANGE'}) {
78 $settings{'MASQUERADE_ORANGE'} = 'on';
79}
80if (!$settings{'MASQUERADE_BLUE'}) {
81 $settings{'MASQUERADE_BLUE'} = 'on';
82}
83
5595bc03
CS
84$checked{'DROPNEWNOTSYN'}{'off'} = '';
85$checked{'DROPNEWNOTSYN'}{'on'} = '';
86$checked{'DROPNEWNOTSYN'}{$settings{'DROPNEWNOTSYN'}} = "checked='checked'";
87$checked{'DROPINPUT'}{'off'} = '';
88$checked{'DROPINPUT'}{'on'} = '';
89$checked{'DROPINPUT'}{$settings{'DROPINPUT'}} = "checked='checked'";
6be0579b
AM
90$checked{'DROPFORWARD'}{'off'} = '';
91$checked{'DROPFORWARD'}{'on'} = '';
92$checked{'DROPFORWARD'}{$settings{'DROPFORWARD'}} = "checked='checked'";
5d7faa45
AM
93$checked{'DROPOUTGOING'}{'off'} = '';
94$checked{'DROPOUTGOING'}{'on'} = '';
95$checked{'DROPOUTGOING'}{$settings{'DROPOUTGOING'}} = "checked='checked'";
5595bc03
CS
96$checked{'DROPPORTSCAN'}{'off'} = '';
97$checked{'DROPPORTSCAN'}{'on'} = '';
98$checked{'DROPPORTSCAN'}{$settings{'DROPPORTSCAN'}} = "checked='checked'";
42dc0090
CS
99$checked{'DROPWIRELESSINPUT'}{'off'} = '';
100$checked{'DROPWIRELESSINPUT'}{'on'} = '';
101$checked{'DROPWIRELESSINPUT'}{$settings{'DROPWIRELESSINPUT'}} = "checked='checked'";
102$checked{'DROPWIRELESSFORWARD'}{'off'} = '';
103$checked{'DROPWIRELESSFORWARD'}{'on'} = '';
104$checked{'DROPWIRELESSFORWARD'}{$settings{'DROPWIRELESSFORWARD'}} = "checked='checked'";
0aaef8e9
CS
105$checked{'DROPPROXY'}{'off'} = '';
106$checked{'DROPPROXY'}{'on'} = '';
107$checked{'DROPPROXY'}{$settings{'DROPPROXY'}} = "checked='checked'";
108$checked{'DROPSAMBA'}{'off'} = '';
109$checked{'DROPSAMBA'}{'on'} = '';
110$checked{'DROPSAMBA'}{$settings{'DROPSAMBA'}} = "checked='checked'";
15add1c8
AM
111$checked{'SHOWCOLORS'}{'off'} = '';
112$checked{'SHOWCOLORS'}{'on'} = '';
113$checked{'SHOWCOLORS'}{$settings{'SHOWCOLORS'}} = "checked='checked'";
96502a5a
AM
114$checked{'SHOWREMARK'}{'off'} = '';
115$checked{'SHOWREMARK'}{'on'} = '';
116$checked{'SHOWREMARK'}{$settings{'SHOWREMARK'}} = "checked='checked'";
770140a7
AM
117$checked{'SHOWTABLES'}{'off'} = '';
118$checked{'SHOWTABLES'}{'on'} = '';
119$checked{'SHOWTABLES'}{$settings{'SHOWTABLES'}} = "checked='checked'";
d9987841
AM
120$checked{'SHOWDROPDOWN'}{'off'} = '';
121$checked{'SHOWDROPDOWN'}{'on'} = '';
122$checked{'SHOWDROPDOWN'}{$settings{'SHOWDROPDOWN'}} = "checked='checked'";
123$selected{'FWPOLICY'}{$settings{'FWPOLICY'}}= 'selected';
124$selected{'FWPOLICY1'}{$settings{'FWPOLICY1'}}= 'selected';
d47bb8a1 125$selected{'FWPOLICY2'}{$settings{'FWPOLICY2'}}= 'selected';
83ef9c40
MT
126$selected{'MASQUERADE_GREEN'}{'off'} = '';
127$selected{'MASQUERADE_GREEN'}{'on'} = '';
128$selected{'MASQUERADE_GREEN'}{$settings{'MASQUERADE_GREEN'}} = 'selected="selected"';
129$selected{'MASQUERADE_ORANGE'}{'off'} = '';
130$selected{'MASQUERADE_ORANGE'}{'on'} = '';
131$selected{'MASQUERADE_ORANGE'}{$settings{'MASQUERADE_ORANGE'}} = 'selected="selected"';
132$selected{'MASQUERADE_BLUE'}{'off'} = '';
133$selected{'MASQUERADE_BLUE'}{'on'} = '';
134$selected{'MASQUERADE_BLUE'}{$settings{'MASQUERADE_BLUE'}} = 'selected="selected"';
35fb9164 135
d00b3548 136&Header::openbox('100%', 'center',);
5595bc03
CS
137print "<form method='post' action='$ENV{'SCRIPT_NAME'}'>";
138
83ef9c40 139print <<END;
5595bc03 140<form method='post' action='$ENV{'SCRIPT_NAME'}'>
83ef9c40
MT
141 <table width='95%' cellspacing='0'>
142 <tr bgcolor='$color{'color20'}'>
143 <td colspan='2' align='left'><b>$Lang::tr{'masquerading'}</b></td>
144 </tr>
145 <tr>
146 <td align='left' width='60%'>$Lang::tr{'masquerade green'}</td>
147 <td>
148 <select name='MASQUERADE_GREEN'>
149 <option value='on' $selected{'MASQUERADE_GREEN'}{'on'}>$Lang::tr{'masquerading enabled'}</option>
150 <option value='off' $selected{'MASQUERADE_GREEN'}{'off'}>$Lang::tr{'masquerading disabled'}</option>
151 </select>
152 </td>
153 </tr>
154END
155
156 if (&Header::orange_used()) {
157 print <<END;
158 <tr>
159 <td align='left' width='60%'>$Lang::tr{'masquerade orange'}</td>
160 <td>
161 <select name='MASQUERADE_ORANGE'>
162 <option value='on' $selected{'MASQUERADE_ORANGE'}{'on'}>$Lang::tr{'masquerading enabled'}</option>
163 <option value='off' $selected{'MASQUERADE_ORANGE'}{'off'}>$Lang::tr{'masquerading disabled'}</option>
164 </select>
165 </td>
166 </tr>
167END
168 }
169
170 if (&Header::blue_used()) {
171 print <<END;
172 <tr>
173 <td align='left' width='60%'>$Lang::tr{'masquerade blue'}</td>
174 <td>
175 <select name='MASQUERADE_BLUE'>
176 <option value='on' $selected{'MASQUERADE_BLUE'}{'on'}>$Lang::tr{'masquerading enabled'}</option>
177 <option value='off' $selected{'MASQUERADE_BLUE'}{'off'}>$Lang::tr{'masquerading disabled'}</option>
178 </select>
179 </td>
180 </tr>
181END
182 }
183
184 print <<END
185 </table>
186
187 <br>
188
5595bc03
CS
189<table width='95%' cellspacing='0'>
190<tr bgcolor='$color{'color20'}'><td colspan='2' align='left'><b>$Lang::tr{'fw logging'}</b></td></tr>
0b06ad05 191<tr><td align='left' width='60%'>$Lang::tr{'drop newnotsyn'}</td><td align='left'>on <input type='radio' name='DROPNEWNOTSYN' value='on' $checked{'DROPNEWNOTSYN'}{'on'} />/
5595bc03 192 <input type='radio' name='DROPNEWNOTSYN' value='off' $checked{'DROPNEWNOTSYN'}{'off'} /> off</td></tr>
0b06ad05 193<tr><td align='left' width='60%'>$Lang::tr{'drop input'}</td><td align='left'>on <input type='radio' name='DROPINPUT' value='on' $checked{'DROPINPUT'}{'on'} />/
5595bc03 194 <input type='radio' name='DROPINPUT' value='off' $checked{'DROPINPUT'}{'off'} /> off</td></tr>
6be0579b
AM
195<tr><td align='left' width='60%'>$Lang::tr{'drop forward'}</td><td align='left'>on <input type='radio' name='DROPFORWARD' value='on' $checked{'DROPFORWARD'}{'on'} />/
196 <input type='radio' name='DROPFORWARD' value='off' $checked{'DROPFORWARD'}{'off'} /> off</td></tr>
5d7faa45
AM
197<tr><td align='left' width='60%'>$Lang::tr{'drop outgoing'}</td><td align='left'>on <input type='radio' name='DROPOUTGOING' value='on' $checked{'DROPOUTGOING'}{'on'} />/
198 <input type='radio' name='DROPOUTGOING' value='off' $checked{'DROPOUTGOING'}{'off'} /> off</td></tr>
0b06ad05 199<tr><td align='left' width='60%'>$Lang::tr{'drop portscan'}</td><td align='left'>on <input type='radio' name='DROPPORTSCAN' value='on' $checked{'DROPPORTSCAN'}{'on'} />/
5595bc03 200 <input type='radio' name='DROPPORTSCAN' value='off' $checked{'DROPPORTSCAN'}{'off'} /> off</td></tr>
0b06ad05 201<tr><td align='left' width='60%'>$Lang::tr{'drop wirelessinput'}</td><td align='left'>on <input type='radio' name='DROPWIRELESSINPUT' value='on' $checked{'DROPWIRELESSINPUT'}{'on'} />/
42dc0090 202 <input type='radio' name='DROPWIRELESSINPUT' value='off' $checked{'DROPWIRELESSINPUT'}{'off'} /> off</td></tr>
0b06ad05 203<tr><td align='left' width='60%'>$Lang::tr{'drop wirelessforward'}</td><td align='left'>on <input type='radio' name='DROPWIRELESSFORWARD' value='on' $checked{'DROPWIRELESSFORWARD'}{'on'} />/
42dc0090 204 <input type='radio' name='DROPWIRELESSFORWARD' value='off' $checked{'DROPWIRELESSFORWARD'}{'off'} /> off</td></tr>
5595bc03 205</table>
15add1c8
AM
206<br/>
207
0aaef8e9
CS
208<table width='95%' cellspacing='0'>
209<tr bgcolor='$color{'color20'}'><td colspan='2' align='left'><b>$Lang::tr{'fw blue'}</b></td></tr>
0b06ad05 210<tr><td align='left' width='60%'>$Lang::tr{'drop proxy'}</td><td align='left'>on <input type='radio' name='DROPPROXY' value='on' $checked{'DROPPROXY'}{'on'} />/
0aaef8e9 211 <input type='radio' name='DROPPROXY' value='off' $checked{'DROPPROXY'}{'off'} /> off</td></tr>
0b06ad05 212<tr><td align='left' width='60%'>$Lang::tr{'drop samba'}</td><td align='left'>on <input type='radio' name='DROPSAMBA' value='on' $checked{'DROPSAMBA'}{'on'} />/
0aaef8e9
CS
213 <input type='radio' name='DROPSAMBA' value='off' $checked{'DROPSAMBA'}{'off'} /> off</td></tr>
214</table>
15add1c8
AM
215<br>
216<table width='95%' cellspacing='0'>
217<tr bgcolor='$color{'color20'}'><td colspan='2' align='left'><b>$Lang::tr{'fw settings'}</b></td></tr>
218<tr><td align='left' width='60%'>$Lang::tr{'fw settings color'}</td><td align='left'>on <input type='radio' name='SHOWCOLORS' value='on' $checked{'SHOWCOLORS'}{'on'} />/
219 <input type='radio' name='SHOWCOLORS' value='off' $checked{'SHOWCOLORS'}{'off'} /> off</td></tr>
96502a5a 220<tr><td align='left' width='60%'>$Lang::tr{'fw settings remark'}</td><td align='left'>on <input type='radio' name='SHOWREMARK' value='on' $checked{'SHOWREMARK'}{'on'} />/
d9987841 221 <input type='radio' name='SHOWREMARK' value='off' $checked{'SHOWREMARK'}{'off'} /> off</td></tr>
e2619c15 222<tr><td align='left' width='60%'>$Lang::tr{'fw settings ruletable'}</td><td align='left'>on <input type='radio' name='SHOWTABLES' value='on' $checked{'SHOWTABLES'}{'on'} />/
770140a7 223 <input type='radio' name='SHOWTABLES' value='off' $checked{'SHOWTABLES'}{'off'} /> off</td></tr>
d9987841
AM
224<tr><td align='left' width='60%'>$Lang::tr{'fw settings dropdown'}</td><td align='left'>on <input type='radio' name='SHOWDROPDOWN' value='on' $checked{'SHOWDROPDOWN'}{'on'} />/
225 <input type='radio' name='SHOWDROPDOWN' value='off' $checked{'SHOWDROPDOWN'}{'off'} /> off</td></tr>
226</table>
62fc8511
AM
227<br />
228<table width='95%' cellspacing='0'>
229<tr bgcolor='$color{'color20'}'><td colspan='2' align='left'><b>$Lang::tr{'fw default drop'}</b></td></tr>
d9987841
AM
230<tr><td align='left' width='60%'>$Lang::tr{'drop action'}</td><td><select name='FWPOLICY'>
231<option value='DROP' $selected{'FWPOLICY'}{'DROP'}>DROP</option>
232<option value='REJECT' $selected{'FWPOLICY'}{'REJECT'}>REJECT</option></select>
233</td></tr>
234<tr><td align='left' width='60%'>$Lang::tr{'drop action1'}</td><td><select name='FWPOLICY1'>
235<option value='DROP' $selected{'FWPOLICY1'}{'DROP'}>DROP</option>
236<option value='REJECT' $selected{'FWPOLICY1'}{'REJECT'}>REJECT</option></select>
237</td></tr>
d47bb8a1
AM
238<tr><td align='left' width='60%'>$Lang::tr{'drop action2'}</td><td><select name='FWPOLICY2'>
239<option value='DROP' $selected{'FWPOLICY2'}{'DROP'}>DROP</option>
240<option value='REJECT' $selected{'FWPOLICY2'}{'REJECT'}>REJECT</option></select>
241</td></tr>
62fc8511
AM
242</table>
243
0aaef8e9 244<br />
f9a3c1c8
AM
245<table width='100%' cellspacing='0'>
246<tr><td align='right'><form method='post' action='$ENV{'SCRIPT_NAME'}'>
62fc8511
AM
247<input type='submit' name='ACTION' value=$Lang::tr{'save'} />
248</form></td></tr>
5595bc03
CS
249</table>
250</form>
251END
252;
253&Header::closebox();
3b2ad4a1
AM
254
255&Header::openbox('100%', 'center', $Lang::tr{'fwdfw pol title'});
256 if ($fwdfwsettings{'POLICY'} eq 'MODE1'){ $selected{'POLICY'}{'MODE1'} = 'selected'; } else { $selected{'POLICY'}{'MODE1'} = ''; }
257 if ($fwdfwsettings{'POLICY'} eq 'MODE2'){ $selected{'POLICY'}{'MODE2'} = 'selected'; } else { $selected{'POLICY'}{'MODE2'} = ''; }
258 if ($fwdfwsettings{'POLICY1'} eq 'MODE1'){ $selected{'POLICY1'}{'MODE1'} = 'selected'; } else { $selected{'POLICY1'}{'MODE1'} = ''; }
259 if ($fwdfwsettings{'POLICY1'} eq 'MODE2'){ $selected{'POLICY1'}{'MODE2'} = 'selected'; } else { $selected{'POLICY1'}{'MODE2'} = ''; }
260print <<END;
261 <form method='post' action='$ENV{'SCRIPT_NAME'}'>
262 <table width='100%' border='0'>
263 <tr><td colspan='3' style='font-weight:bold;color:red;' align='left'>FORWARD </td></tr>
264 <tr><td colspan='3' align='left'>$Lang::tr{'fwdfw pol text'}</td></tr>
265 <tr><td colspan='3'><hr /></td></tr>
266 <tr><td width='15%' align='left'> <select name='POLICY' style="width: 100px">
267 <option value='MODE1' $selected{'POLICY'}{'MODE1'}>$Lang::tr{'fwdfw pol block'}</option>
268 <option value='MODE2' $selected{'POLICY'}{'MODE2'}>$Lang::tr{'fwdfw pol allow'}</option></select>
269 <input type='submit' name='ACTION' value=$Lang::tr{'save'} /><input type='hidden' name='defpol' value='1'></td>
270END
271 print "</tr></table></form>";
272 print"<br><br>";
273 print <<END;
274 <form method='post' action='$ENV{'SCRIPT_NAME'}'>
275 <table width='100%' border='0'>
276 <tr><td colspan='3' style='font-weight:bold;color:red;' align='left'>OUTGOING </td></tr>
277 <tr><td colspan='3' align='left'>$Lang::tr{'fwdfw pol text1'}</td></tr>
278 <tr><td colspan='3'><hr /></td></tr>
279 <tr><td width='15%' align='left'> <select name='POLICY1' style="width: 100px">
280 <option value='MODE1' $selected{'POLICY1'}{'MODE1'}>$Lang::tr{'fwdfw pol block'}</option>
281 <option value='MODE2' $selected{'POLICY1'}{'MODE2'}>$Lang::tr{'fwdfw pol allow'}</option></select>
282 <input type='submit' name='ACTION' value='$Lang::tr{'save'}' /><input type='hidden' name='defpol' value='1'></td>
283END
284 print "</tr></table></form>";
285 &Header::closebox();
286
5595bc03
CS
287&Header::closebigbox();
288&Header::closepage();