]>
Commit | Line | Data |
---|---|---|
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 | ||
18 | require '/var/ipfire/general-functions.pl'; | |
19 | require "${General::swroot}/lang.pl"; | |
20 | require "${General::swroot}/header.pl"; | |
21 | ||
22 | ||
23 | my %checked =(); # Checkbox manipulations | |
5595bc03 | 24 | our %settings=(); |
3b2ad4a1 AM |
25 | my %fwdfwsettings=(); |
26 | my %configfwdfw=(); | |
27 | my %configoutgoingfw=(); | |
28 | ||
6d8eb5de AM |
29 | my $configfwdfw = "${General::swroot}/firewall/config"; |
30 | my $configoutgoing = "${General::swroot}/firewall/outgoing"; | |
5595bc03 CS |
31 | my $errormessage = ''; |
32 | my $warnmessage = ''; | |
34f30c5f | 33 | my $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 | 40 | if ($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 |
67 | if ($errormessage) { |
68 | &Header::openbox('100%', 'left', $Lang::tr{'warning messages'}); | |
69 | print "<font color='red'>$errormessage </font>"; | |
70 | &Header::closebox(); | |
71 | } | |
72 | ||
83ef9c40 MT |
73 | # Set new defaults |
74 | if (!$settings{'MASQUERADE_GREEN'}) { | |
75 | $settings{'MASQUERADE_GREEN'} = 'on'; | |
76 | } | |
77 | if (!$settings{'MASQUERADE_ORANGE'}) { | |
78 | $settings{'MASQUERADE_ORANGE'} = 'on'; | |
79 | } | |
80 | if (!$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 |
137 | print "<form method='post' action='$ENV{'SCRIPT_NAME'}'>"; |
138 | ||
83ef9c40 | 139 | print <<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> | |
154 | END | |
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> | |
167 | END | |
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> | |
181 | END | |
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> | |
251 | END | |
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'} = ''; } | |
260 | print <<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> | |
270 | END | |
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> | |
283 | END | |
284 | print "</tr></table></form>"; | |
285 | &Header::closebox(); | |
286 | ||
5595bc03 CS |
287 | &Header::closebigbox(); |
288 | &Header::closepage(); |