Project

General

Profile

Download (16.8 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
		if ($retval == 0) {
74
			clear_subsystem_dirty('natconf');
75
			clear_subsystem_dirty('filter');
76
		}
77

    
78
	}
79
}
80

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

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

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

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

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

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

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

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

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

    
166
?>
167
<body link="#000000" vlink="#000000" alink="#000000">
168
<?php include("fbegin.inc"); ?>
169
<form action="firewall_nat.php" method="post" name="iform">
170
<script type="text/javascript" language="javascript" src="/javascript/row_toggle.js"></script>
171
<?php if ($savemsg) print_info_box($savemsg); ?>
172
<?php if (is_subsystem_dirty('natconf')): ?><p>
173
<?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>
174
<?php endif; ?>
175
<table width="100%" border="0" cellpadding="0" cellspacing="0">
176
  <tr><td>
177
<?php
178
	$tab_array = array();
179
	$tab_array[] = array(gettext("Port Forward"), true, "firewall_nat.php");
180
	$tab_array[] = array(gettext("1:1"), false, "firewall_nat_1to1.php");
181
	$tab_array[] = array(gettext("Outbound"), false, "firewall_nat_out.php");
182
	display_top_tabs($tab_array);
183
?>
184
 </td></tr>
185
  <tr>
186
    <td>
187
	<div id="mainarea">
188
              <table class="tabcont" width="100%" border="0" cellpadding="0" cellspacing="0">
189
                <tr id="frheader">
190
		  <td width="3%" class="list">&nbsp;</td>
191
                  <td width="3%" class="list">&nbsp;</td>
192
		  <td width="5%" class="listhdrr"><?=gettext("If");?></td>
193
		  <td width="5%" class="listhdrr"><?=gettext("Proto");?></td>
194
		  <td width="11%" class="listhdrr"><nobr><?=gettext("Src. addr");?></nobr></td>
195
		  <td width="11%" class="listhdrr"><nobr><?=gettext("Src. ports");?></nobr></td>
196
		  <td width="11%" class="listhdrr"><nobr><?=gettext("Dest. addr");?></nobr></td>
197
		  <td width="11%" class="listhdrr"><nobr><?=gettext("Dest. ports");?></nobr></td>
198
		  <td width="11%" class="listhdrr"><nobr><?=gettext("NAT IP");?></nobr></td>
199
		  <td width="11%" class="listhdrr"><nobr><?=gettext("NAT Ports");?></nobr></td>
200
		  <td width="11%" class="listhdr"><?=gettext("Description");?></td>
201
                  <td width="5%" class="list">
202
                    <table border="0" cellspacing="0" cellpadding="1">
203
                      <tr>
204
			<td width="17">
205
			<?php if (count($a_nat) == 0): ?>
206
				<img src="./themes/<?= $g['theme']; ?>/images/icons/icon_x_d.gif" width="17" height="17" title="<?=gettext("delete selected rules");?>" border="0">
207
			<?php else: ?>
208
				<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?");?>')">
209
			<?php endif; ?>
210
			</td>
211
                        <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>
212
                      </tr>
213
                    </table>
214
		  </td>
215
		</tr>
216
	<?php $nnats = $i = 0; foreach ($a_nat as $natent): ?>
217
	<?php 
218
	
219
		//build Alias popup box
220
		$span_end = "</U></span>";
221

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

    
224
		$alias_src_span_begin      = $alias_popup["src"];
225
		$alias_src_port_span_begin = $alias_popup["srcport"];
226
		$alias_dst_span_begin      = $alias_popup["dst"];
227
		$alias_dst_port_span_begin = $alias_popup["dstport"];
228

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

    
231
		$alias_target_span_begin     = $alias_popup["dst"];
232
		$alias_local_port_span_begin = $alias_popup["dstport"];
233

    
234
		if (isset($natent['disabled']))
235
			$textss = "<span class=\"gray\">";
236
		else
237
			$textss = "<span>";
238

    
239
		$textse = "</span>";
240
	
241
		/* if user does not have access to edit an interface skip on to the next record */
242
		if(!have_natpfruleint_access($natent['interface'])) 
243
			continue;
244
	?>
245
                <tr valign="top" id="fr<?=$nnats;?>">
246
                  <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>
247
                  <td class="listt" align="center">
248
					<?php if($natent['associated-rule-id'] == "pass"): ?>
249
					<img src="./themes/<?= $g['theme']; ?>/images/icons/icon_pass.gif" title="<?=gettext("All traffic matching this NAT entry is passed"); ?>" border="0">
250
					<?php elseif (!empty($natent['associated-rule-id'])): ?>
251
					<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">
252
					<?php endif; ?>
253
				  </td>
254
                  <td class="listlr" onClick="fr_toggle(<?=$nnats;?>)" id="frd<?=$nnats;?>" ondblclick="document.location='firewall_nat_edit.php?id=<?=$nnats;?>';">
255
                    <?=$textss;?>
256
		    <?php
257
			if (!$natent['interface'])
258
				echo htmlspecialchars(convert_friendly_interface_to_friendly_descr("wan"));
259
			else
260
				echo htmlspecialchars(convert_friendly_interface_to_friendly_descr($natent['interface']));
261
		    ?>
262
                    <?=$textse;?>
263
                  </td>
264

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

    
269
                  <td class="listr" onClick="fr_toggle(<?=$nnats;?>)" id="frd<?=$nnats;?>" ondblclick="document.location='firewall_nat_edit.php?id=<?=$nnats;?>';">
270
				    <?=$textss;?><?php echo $alias_src_span_begin;?><?php echo htmlspecialchars(pprint_address($natent['source']));?><?php echo $alias_src_span_end;?><?=$textse;?>
271
                  </td>
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_port_span_begin;?><?php echo htmlspecialchars(pprint_port($natent['source']['port']));?><?php echo $alias_src_port_span_end;?><?=$textse;?>
274
                  </td>
275

    
276
                  <td class="listr" onClick="fr_toggle(<?=$nnats;?>)" id="frd<?=$nnats;?>" ondblclick="document.location='firewall_nat_edit.php?id=<?=$nnats;?>';">
277
				    <?=$textss;?><?php echo $alias_dst_span_begin;?><?php echo htmlspecialchars(pprint_address($natent['destination']));?><?php echo $alias_dst_span_end;?><?=$textse;?>
278
                  </td>
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_port_span_begin;?><?php echo htmlspecialchars(pprint_port($natent['destination']['port']));?><?php echo $alias_dst_port_span_end;?><?=$textse;?>
281
                  </td>
282

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

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

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

    
300
                  <td class="listbg" onClick="fr_toggle(<?=$nnats;?>)" ondblclick="document.location='firewall_nat_edit.php?id=<?=$nnats;?>';">
301
				  <?=$textss;?><?=htmlspecialchars($natent['descr']);?>&nbsp;<?=$textse;?>
302
                  </td>
303
                  <td valign="middle" class="list" nowrap>
304
                    <table border="0" cellspacing="0" cellpadding="1">
305
                      <tr>
306
			<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>
307
                        <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>
308
                      </tr>
309
                      <tr>
310
					    <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>
311
			<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>
312
                      </tr>
313
                    </table>
314
		</tr>
315
  	     <?php $i++; $nnats++; endforeach; ?>
316
                <tr>
317
                  <td class="list" colspan="8"></td>
318
                  <td>&nbsp;</td>
319
                  <td>&nbsp;</td>
320
                  <td>&nbsp;</td>
321
                  <td class="list" valign="middle" nowrap>
322
                    <table border="0" cellspacing="0" cellpadding="1">
323
                      <tr>
324
			<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>
325
                      </tr>
326
                      <tr>
327
			<td width="17">
328
			<?php if (count($a_nat) == 0): ?>
329
				<img src="./themes/<?= $g['theme']; ?>/images/icons/icon_x_d.gif" width="17" height="17" title="<?=gettext("delete selected rules");?>" border="0">
330
			<?php else: ?>
331
				<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?");?>')">
332
			<?php endif; ?>
333
			</td>
334
                        <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>
335
                      </tr>
336
                    </table>
337
		  </td>
338
		</tr>
339
		<tr><td>&nbsp;</td></tr>
340
          <tr>
341
            <td width="16"><img src="./themes/<?= $g['theme']; ?>/images/icons/icon_pass.gif" width="11" height="11"></td>
342
            <td colspan="3"><?=gettext("pass"); ?></td>
343
			</tr>
344
		   <tr>
345
            <td width="14"><img src="./themes/<?= $g['theme']; ?>/images/icons/icon_chain.png" width="11" height="11"></td>
346
	    <td colspan="3"><?=gettext("linked rule");?></td>
347
          </tr>
348
    </table>
349
	</div>
350
	</td>
351
  </tr>
352
</table>
353

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

    
360
</form>
361
<?php include("fend.inc"); ?>
362
</body>
363
</html>
(53-53/224)