Project

General

Profile

Download (16.9 KB) Statistics
| Branch: | Tag: | Revision:
1
<?php
2
/* $Id$ */
3
/*
4
	firewall_nat.php
5
	Copyright (C) 2004 Scott Ullrich
6
	All rights reserved.
7

    
8
	originally part of m0n0wall (http://m0n0.ch/wall)
9
	Copyright (C) 2003-2004 Manuel Kasper <mk@neon1.net>.
10
	All rights reserved.
11

    
12
	Redistribution and use in source and binary forms, with or without
13
	modification, are permitted provided that the following conditions are met:
14

    
15
	1. Redistributions of source code must retain the above copyright notice,
16
	   this list of conditions and the following disclaimer.
17

    
18
	2. Redistributions in binary form must reproduce the above copyright
19
	   notice, this list of conditions and the following disclaimer in the
20
	   documentation and/or other materials provided with the distribution.
21

    
22
	THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES,
23
	INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY
24
	AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
25
	AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY,
26
	OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
27
	SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
28
	INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
29
	CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
30
	ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
31
	POSSIBILITY OF SUCH DAMAGE.
32
*/
33
/*
34
	pfSense_MODULE:	nat
35
*/
36

    
37
##|+PRIV
38
##|*IDENT=page-firewall-nat-portforward
39
##|*NAME=Firewall: NAT: Port Forward page
40
##|*DESCR=Allow access to the 'Firewall: NAT: Port Forward' page.
41
##|*MATCH=firewall_nat.php*
42
##|-PRIV
43

    
44
require("guiconfig.inc");
45
require_once("functions.inc");
46
require_once("filter.inc");
47
require_once("shaper.inc");
48
require_once("itemid.inc");
49

    
50
if (!is_array($config['nat']['rule']))
51
	$config['nat']['rule'] = array();
52

    
53
$a_nat = &$config['nat']['rule'];
54

    
55
/* if a custom message has been passed along, lets process it */
56
if ($_GET['savemsg'])
57
	$savemsg = $_GET['savemsg'];
58

    
59
if ($_POST) {
60

    
61
	$pconfig = $_POST;
62

    
63
	if ($_POST['apply']) {
64

    
65
		write_config();
66

    
67
		$retval = 0;
68

    
69
		unlink_if_exists("/tmp/config.cache");
70
		$retval |= filter_configure();
71
		$savemsg = get_std_save_message($retval);
72

    
73
		pfSense_handle_custom_code("/usr/local/pkg/firewall_nat/apply");
74

    
75
		if ($retval == 0) {
76
			clear_subsystem_dirty('natconf');
77
			clear_subsystem_dirty('filter');
78
		}
79

    
80
	}
81
}
82

    
83
if ($_GET['act'] == "del") {
84
	if ($a_nat[$_GET['id']]) {
85
		if (isset($a_nat[$_GET['id']]['associated-rule-id'])) {
86
			delete_id($a_nat[$_GET['id']]['associated-rule-id'], $config['filter']['rule']);
87
			mark_subsystem_dirty('filter');
88
		}
89
		unset($a_nat[$_GET['id']]);
90
		write_config();
91
		mark_subsystem_dirty('natconf');
92
		header("Location: firewall_nat.php");
93
		exit;
94
	}
95
}
96

    
97
if (isset($_POST['del_x'])) {
98
    /* delete selected rules */
99
    if (is_array($_POST['rule']) && count($_POST['rule'])) {
100
	    foreach ($_POST['rule'] as $rulei) {
101
		$target = $rule['target'];
102
			// Check for filter rule associations
103
			if (isset($a_nat[$rulei]['associated-rule-id'])){
104
				delete_id($a_nat[$rulei]['associated-rule-id'], $config['filter']['rule']);
105
				
106
				mark_subsystem_dirty('filter');
107
			}
108
	        unset($a_nat[$rulei]);
109
	    }
110
	    write_config();
111
	    mark_subsystem_dirty('natconf');
112
	    header("Location: firewall_nat.php");
113
	    exit;
114
	}
115

    
116
} else {
117
        /* yuck - IE won't send value attributes for image buttons, while Mozilla does - so we use .x/.y to find move button clicks instead... */
118
        unset($movebtn);
119
        foreach ($_POST as $pn => $pd) {
120
                if (preg_match("/move_(\d+)_x/", $pn, $matches)) {
121
                        $movebtn = $matches[1];
122
                        break;
123
                }
124
        }
125
        /* move selected rules before this rule */
126
        if (isset($movebtn) && is_array($_POST['rule']) && count($_POST['rule'])) {
127
                $a_nat_new = array();
128

    
129
                /* copy all rules < $movebtn and not selected */
130
                for ($i = 0; $i < $movebtn; $i++) {
131
                        if (!in_array($i, $_POST['rule']))
132
                                $a_nat_new[] = $a_nat[$i];
133
                }
134

    
135
                /* copy all selected rules */
136
                for ($i = 0; $i < count($a_nat); $i++) {
137
                        if ($i == $movebtn)
138
                                continue;
139
                        if (in_array($i, $_POST['rule']))
140
                                $a_nat_new[] = $a_nat[$i];
141
                }
142

    
143
                /* copy $movebtn rule */
144
                if ($movebtn < count($a_nat))
145
                        $a_nat_new[] = $a_nat[$movebtn];
146

    
147
                /* copy all rules > $movebtn and not selected */
148
                for ($i = $movebtn+1; $i < count($a_nat); $i++) {
149
                        if (!in_array($i, $_POST['rule']))
150
                                $a_nat_new[] = $a_nat[$i];
151
                }
152
                $a_nat = $a_nat_new;
153
                write_config();
154
		mark_subsystem_dirty('natconf');
155
                header("Location: firewall_nat.php");
156
                exit;
157
        }
158
}
159

    
160
$pgtitle = array(gettext("Firewall"),gettext("NAT"),gettext("Port Forward"));
161
include("head.inc");
162

    
163
echo "<script type=\"text/javascript\" language=\"javascript\" src=\"/javascript/domTT/domLib.js\"></script>";
164
echo "<script type=\"text/javascript\" language=\"javascript\" src=\"/javascript/domTT/domTT.js\"></script>";
165
echo "<script type=\"text/javascript\" language=\"javascript\" src=\"/javascript/domTT/behaviour.js\"></script>";
166
echo "<script type=\"text/javascript\" language=\"javascript\" src=\"/javascript/domTT/fadomatic.js\"></script>";
167

    
168
?>
169
<link rel="stylesheet" href="/javascript/chosen/chosen.css" />
170
<body link="#000000" vlink="#000000" alink="#000000">
171
<?php include("fbegin.inc"); ?>
172
<form action="firewall_nat.php" method="post" name="iform">
173
<script type="text/javascript" language="javascript" src="/javascript/row_toggle.js"></script>
174
<?php if ($savemsg) print_info_box($savemsg); ?>
175
<?php if (is_subsystem_dirty('natconf')): ?><p>
176
<?php print_info_box_np(gettext("The NAT configuration has been changed") . ".<br>" . gettext("You must apply the changes in order for them to take effect."));?><br>
177
<?php endif; ?>
178
<table width="100%" border="0" cellpadding="0" cellspacing="0">
179
  <tr><td>
180
<?php
181
	$tab_array = array();
182
	$tab_array[] = array(gettext("Port Forward"), true, "firewall_nat.php");
183
	$tab_array[] = array(gettext("1:1"), false, "firewall_nat_1to1.php");
184
	$tab_array[] = array(gettext("Outbound"), false, "firewall_nat_out.php");
185
	display_top_tabs($tab_array);
186
?>
187
 </td></tr>
188
  <tr>
189
    <td>
190
	<div id="mainarea">
191
              <table class="tabcont" width="100%" border="0" cellpadding="0" cellspacing="0">
192
                <tr id="frheader">
193
		  <td width="3%" class="list">&nbsp;</td>
194
                  <td width="3%" class="list">&nbsp;</td>
195
		  <td width="5%" class="listhdrr"><?=gettext("If");?></td>
196
		  <td width="5%" class="listhdrr"><?=gettext("Proto");?></td>
197
		  <td width="11%" class="listhdrr"><nobr><?=gettext("Src. addr");?></nobr></td>
198
		  <td width="11%" class="listhdrr"><nobr><?=gettext("Src. ports");?></nobr></td>
199
		  <td width="11%" class="listhdrr"><nobr><?=gettext("Dest. addr");?></nobr></td>
200
		  <td width="11%" class="listhdrr"><nobr><?=gettext("Dest. ports");?></nobr></td>
201
		  <td width="11%" class="listhdrr"><nobr><?=gettext("NAT IP");?></nobr></td>
202
		  <td width="11%" class="listhdrr"><nobr><?=gettext("NAT Ports");?></nobr></td>
203
		  <td width="11%" class="listhdr"><?=gettext("Description");?></td>
204
                  <td width="5%" class="list">
205
                    <table border="0" cellspacing="0" cellpadding="1">
206
                      <tr>
207
			<td width="17">
208
			<?php if (count($a_nat) == 0): ?>
209
				<img src="./themes/<?= $g['theme']; ?>/images/icons/icon_x_d.gif" width="17" height="17" title="<?=gettext("delete selected rules");?>" border="0">
210
			<?php else: ?>
211
				<input name="del" type="image" src="./themes/<?= $g['theme']; ?>/images/icons/icon_x.gif" width="17" height="17" title="<?=gettext("delete selected rules"); ?>" onclick="return confirm('<?=gettext("Do you really want to delete the selected rules?");?>')">
212
			<?php endif; ?>
213
			</td>
214
                        <td><a href="firewall_nat_edit.php"><img src="/themes/<?= $g['theme']; ?>/images/icons/icon_plus.gif" width="17" height="17" border="0"></a></td>
215
                      </tr>
216
                    </table>
217
		  </td>
218
		</tr>
219
	<?php $nnats = $i = 0; foreach ($a_nat as $natent): ?>
220
	<?php 
221
	
222
		//build Alias popup box
223
		$span_end = "</U></span>";
224

    
225
		$alias_popup = rule_popup($natent['source']['address'], pprint_port($natent['source']['port']), $natent['destination']['address'], pprint_port($natent['destination']['port']));
226

    
227
		$alias_src_span_begin      = $alias_popup["src"];
228
		$alias_src_port_span_begin = $alias_popup["srcport"];
229
		$alias_dst_span_begin      = $alias_popup["dst"];
230
		$alias_dst_port_span_begin = $alias_popup["dstport"];
231

    
232
		$alias_popup = rule_popup("","",$natent['target'], pprint_port($natent['local-port']));
233

    
234
		$alias_target_span_begin     = $alias_popup["dst"];
235
		$alias_local_port_span_begin = $alias_popup["dstport"];
236

    
237
		if (isset($natent['disabled']))
238
			$textss = "<span class=\"gray\">";
239
		else
240
			$textss = "<span>";
241

    
242
		$textse = "</span>";
243
	
244
		/* if user does not have access to edit an interface skip on to the next record */
245
		if(!have_natpfruleint_access($natent['interface'])) 
246
			continue;
247
	?>
248
                <tr valign="top" id="fr<?=$nnats;?>">
249
                  <td class="listt"><input type="checkbox" id="frc<?=$nnats;?>" name="rule[]" value="<?=$i;?>" onClick="fr_bgcolor('<?=$nnats;?>')" style="margin: 0; padding: 0; width: 15px; height: 15px;"></td>
250
                  <td class="listt" align="center">
251
					<?php if($natent['associated-rule-id'] == "pass"): ?>
252
					<img src="./themes/<?= $g['theme']; ?>/images/icons/icon_pass.gif" title="<?=gettext("All traffic matching this NAT entry is passed"); ?>" border="0">
253
					<?php elseif (!empty($natent['associated-rule-id'])): ?>
254
					<img src="./themes/<?= $g['theme']; ?>/images/icons/icon_chain.png" width="17" height="17" title="<?=gettext("Firewall rule ID"); ?> <?=htmlspecialchars($nnatid); ?> <?=gettext("is managed with this rule"); ?>" border="0">
255
					<?php endif; ?>
256
				  </td>
257
                  <td class="listlr" onClick="fr_toggle(<?=$nnats;?>)" id="frd<?=$nnats;?>" ondblclick="document.location='firewall_nat_edit.php?id=<?=$nnats;?>';">
258
                    <?=$textss;?>
259
		    <?php
260
			if (!$natent['interface'])
261
				echo htmlspecialchars(convert_friendly_interface_to_friendly_descr("wan"));
262
			else
263
				echo htmlspecialchars(convert_friendly_interface_to_friendly_descr($natent['interface']));
264
		    ?>
265
                    <?=$textse;?>
266
                  </td>
267

    
268
                  <td class="listr" onClick="fr_toggle(<?=$nnats;?>)" id="frd<?=$nnats;?>" ondblclick="document.location='firewall_nat_edit.php?id=<?=$nnats;?>';">
269
					<?=$textss;?><?=strtoupper($natent['protocol']);?><?=$textse;?>
270
                  </td>
271

    
272
                  <td class="listr" onClick="fr_toggle(<?=$nnats;?>)" id="frd<?=$nnats;?>" ondblclick="document.location='firewall_nat_edit.php?id=<?=$nnats;?>';">
273
				    <?=$textss;?><?php echo $alias_src_span_begin;?><?php echo htmlspecialchars(pprint_address($natent['source']));?><?php echo $alias_src_span_end;?><?=$textse;?>
274
                  </td>
275
                  <td class="listr" onClick="fr_toggle(<?=$nnats;?>)" id="frd<?=$nnats;?>" ondblclick="document.location='firewall_nat_edit.php?id=<?=$nnats;?>';">
276
				    <?=$textss;?><?php echo $alias_src_port_span_begin;?><?php echo htmlspecialchars(pprint_port($natent['source']['port']));?><?php echo $alias_src_port_span_end;?><?=$textse;?>
277
                  </td>
278

    
279
                  <td class="listr" onClick="fr_toggle(<?=$nnats;?>)" id="frd<?=$nnats;?>" ondblclick="document.location='firewall_nat_edit.php?id=<?=$nnats;?>';">
280
				    <?=$textss;?><?php echo $alias_dst_span_begin;?><?php echo htmlspecialchars(pprint_address($natent['destination']));?><?php echo $alias_dst_span_end;?><?=$textse;?>
281
                  </td>
282
                  <td class="listr" onClick="fr_toggle(<?=$nnats;?>)" id="frd<?=$nnats;?>" ondblclick="document.location='firewall_nat_edit.php?id=<?=$nnats;?>';">
283
				    <?=$textss;?><?php echo $alias_dst_port_span_begin;?><?php echo htmlspecialchars(pprint_port($natent['destination']['port']));?><?php echo $alias_dst_port_span_end;?><?=$textse;?>
284
                  </td>
285

    
286
                  <td class="listr" onClick="fr_toggle(<?=$nnats;?>)" id="frd<?=$nnats;?>" ondblclick="document.location='firewall_nat_edit.php?id=<?=$nnats;?>';">
287
				    <?=$textss;?><?php echo $alias_target_span_begin;?><?php echo htmlspecialchars($natent['target']);?><?php echo $alias_target_span_end;?><?=$textse;?>
288
                  </td>
289
                  <td class="listr" onClick="fr_toggle(<?=$nnats;?>)" id="frd<?=$nnats;?>" ondblclick="document.location='firewall_nat_edit.php?id=<?=$nnats;?>';">
290
					<?php
291
						$localport = $natent['local-port'];
292

    
293
						list($dstbeginport, $dstendport) = split("-", $natent['destination']['port']);
294

    
295
						if ($dstendport) {
296
							$localendport = $natent['local-port'] + $dstendport - $dstbeginport;
297
							$localport   .= '-' . $localendport;
298
						}
299
					?>
300
				    <?=$textss;?><?php echo $alias_local_port_span_begin;?><?php echo htmlspecialchars(pprint_port($localport));?><?php echo $alias_local_port_span_end;?><?=$textse;?>
301
                  </td>
302

    
303
                  <td class="listbg" onClick="fr_toggle(<?=$nnats;?>)" ondblclick="document.location='firewall_nat_edit.php?id=<?=$nnats;?>';">
304
				  <?=$textss;?><?=htmlspecialchars($natent['descr']);?>&nbsp;<?=$textse;?>
305
                  </td>
306
                  <td valign="middle" class="list" nowrap>
307
                    <table border="0" cellspacing="0" cellpadding="1">
308
                      <tr>
309
			<td><input onmouseover="fr_insline(<?=$nnats;?>, true)" onmouseout="fr_insline(<?=$nnats;?>, false)" name="move_<?=$i;?>" src="/themes/<?= $g['theme']; ?>/images/icons/icon_left.gif" title="<?=gettext("move selected rules before this rule");?>" height="17" type="image" width="17" border="0"></td>
310
                        <td><a href="firewall_nat_edit.php?id=<?=$i;?>"><img src="/themes/<?= $g['theme']; ?>/images/icons/icon_e.gif" width="17" height="17" border="0" title="<?=gettext("edit rule"); ?>"></a></td>
311
                      </tr>
312
                      <tr>
313
					    <td align="center" valign="middle"><a href="firewall_nat.php?act=del&id=<?=$i;?>" onclick="return confirm('<?=gettext("Do you really want to delete this rule?");?>')"><img src="./themes/<?= $g['theme']; ?>/images/icons/icon_x.gif" width="17" height="17" border="0" title="<?=gettext("delete rule");?>"></a></td>
314
			<td><a href="firewall_nat_edit.php?dup=<?=$i;?>"><img src="/themes/<?= $g['theme']; ?>/images/icons/icon_plus.gif" title="<?=gettext("add a new nat based on this one");?>" width="17" height="17" border="0"></a></td>
315
                      </tr>
316
                    </table>
317
		</tr>
318
  	     <?php $i++; $nnats++; endforeach; ?>
319
                <tr>
320
                  <td class="list" colspan="8"></td>
321
                  <td>&nbsp;</td>
322
                  <td>&nbsp;</td>
323
                  <td>&nbsp;</td>
324
                  <td class="list" valign="middle" nowrap>
325
                    <table border="0" cellspacing="0" cellpadding="1">
326
                      <tr>
327
			<td><?php if ($nnats == 0): ?><img src="/themes/<?= $g['theme']; ?>/images/icons/icon_left_d.gif" width="17" height="17" title="<?=gettext("move selected rules to end"); ?>" border="0"><?php else: ?><input name="move_<?=$i;?>" type="image" src="/themes/<?= $g['theme']; ?>/images/icons/icon_left.gif" width="17" height="17" title="<?=gettext("move selected rules to end");?>" border="0"><?php endif; ?></td>
328
                      </tr>
329
                      <tr>
330
			<td width="17">
331
			<?php if (count($a_nat) == 0): ?>
332
				<img src="./themes/<?= $g['theme']; ?>/images/icons/icon_x_d.gif" width="17" height="17" title="<?=gettext("delete selected rules");?>" border="0">
333
			<?php else: ?>
334
				<input name="del" type="image" src="./themes/<?= $g['theme']; ?>/images/icons/icon_x.gif" width="17" height="17" title="<?=gettext("delete selected rules"); ?>" onclick="return confirm('<?=gettext("Do you really want to delete the selected rules?");?>')">
335
			<?php endif; ?>
336
			</td>
337
                        <td><a href="firewall_nat_edit.php"><img src="/themes/<?= $g['theme']; ?>/images/icons/icon_plus.gif" width="17" height="17" border="0"></a></td>
338
                      </tr>
339
                    </table>
340
		  </td>
341
		</tr>
342
		<tr><td>&nbsp;</td></tr>
343
          <tr>
344
            <td width="16"><img src="./themes/<?= $g['theme']; ?>/images/icons/icon_pass.gif" width="11" height="11"></td>
345
            <td colspan="3"><?=gettext("pass"); ?></td>
346
			</tr>
347
		   <tr>
348
            <td width="14"><img src="./themes/<?= $g['theme']; ?>/images/icons/icon_chain.png" width="11" height="11"></td>
349
	    <td colspan="3"><?=gettext("linked rule");?></td>
350
          </tr>
351
    </table>
352
	</div>
353
	</td>
354
  </tr>
355
</table>
356

    
357
<?php
358
if ($pkg['tabs'] <> "") {
359
    echo "</td></tr></table>";
360
}
361
?>
362

    
363
</form>
364
<?php include("fend.inc"); ?>
365
</body>
366
</html>
(54-54/226)