aboutsummaryrefslogtreecommitdiffstats
path: root/packages/diag_states_pt
diff options
context:
space:
mode:
Diffstat (limited to 'packages/diag_states_pt')
-rw-r--r--packages/diag_states_pt/diag_new_states.php381
-rw-r--r--packages/diag_states_pt/diag_new_states.xml65
2 files changed, 0 insertions, 446 deletions
diff --git a/packages/diag_states_pt/diag_new_states.php b/packages/diag_states_pt/diag_new_states.php
deleted file mode 100644
index e0f1abec..00000000
--- a/packages/diag_states_pt/diag_new_states.php
+++ /dev/null
@@ -1,381 +0,0 @@
-<?php
-/*
- diag_new_staes.php
- Copyright (C) 2002 Paul Taylor
- All rights reserved.
-
- Redistribution and use in source and binary forms, with or without
- modification, are permitted provided that the following conditions are met:
-
- 1. Redistributions of source code must retain the above copyright notice,
- this list of conditions and the following disclaimer.
-
- 2. Redistributions in binary form must reproduce the above copyright
- notice, this list of conditions and the following disclaimer in the
- documentation and/or other materials provided with the distribution.
-
- THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES,
- INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY
- AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
- AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY,
- OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
- SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
- INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
- CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
- ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
- POSSIBILITY OF SUCH DAMAGE.
-*/
-
-require_once("guiconfig.inc");
-
-$pgtitle = "Diagnostics: Show States";
-
-
-/* put your custom HTML head content here */
-/* using some of the $pfSenseHead function calls */
-
-function displayIP($ip, $col) {
-
- global $viewPassThru;
-
- switch ($col) {
- case 'srcip':
- if ($_GET['sfilter']) {
- if ($_GET['sfilter'] == $ip)
- return $ip;
- }
- else {
- return '<a href="?sfilter='.$ip.$viewPassThru.'">'. $ip .'</a>';
- }
- break;
-
- case 'dstip':
- if ($_GET['dfilter']) {
- if ($_GET['dfilter'] == $ip)
- return $ip;
- }
- else {
- return '<a href="?dfilter='.$ip.$viewPassThru.'">'. $ip .'</a>';
- }
- break;
- }
-
-}
-
-function sortOrder($column) {
-
- if ($_GET['order'] == $column) {
- if ($_GET['sort'] == 'des')
- return "&sort=asc";
- return "&sort=des";
- }
- else
- return "&sort=asc";
-}
-
-function stripPort($ip, $showPort = false) {
- if (!$showPort) {
- if (strpos($ip,':') > 0)
- return substr($ip,0,strpos($ip,":"));
- else
- return ($ip);
- }
- else {
- if (strpos($ip,':') > 0) {
- return substr($ip,(strpos($ip,":")+1));
- }
- else
- return "&nbsp;";
- }
-}
-
-// sfilter and dfilter allow setting of source and dest IP filters
-// on the output. $filterPassThru allows these source and dest
-// filters to be passed on in the column sorting links.
-if (($_GET['sfilter']) or ($_GET['dfilter'])) {
-
- $filter = '';
- if ($_GET['sfilter']) {
- if (is_ipaddr($_GET['sfilter'])) {
- $sfilter = $_GET['sfilter'];
- $filterPassThru = '&sfilter=' . $_GET['sfilter'];
- }
- else
- unset ($_GET['sfilter']);
- }
- if ($_GET['dfilter']) {
- if (is_ipaddr($_GET['dfilter'])) {
- $dfilter = $_GET['dfilter'];
- $filterPassThru = '&dfilter=' . $_GET['dfilter'];
- }
- else
- unset ($_GET['dfilter']);
- }
-}
-
-$dataRows = 300;
-
-$rawdata = array();
-
-/* get our states */
-// 1 2 3 4 5 6 7 8
-//12345678901234567890123456789012345678901234567890123456789012345678901234567890
-// [3] => PR D SRC DEST STATE AGE EXP PKTS BYTES
-// [4] => icmp O 192.168.112.94:16734 192.168.112.1:0 0:0 12 2 10 840
-// [5] => tcp I 192.168.111.99:61221 192.168.111.150:22 4:4 710 86399 726 242K
-// -w 132 sets width of data to 132
-// $dataRows defaults to 300 for embedded hardware
-exec("echo q | /usr/local/sbin/pftop -w 132 $dataRows",$rawdata);
-
-// exporting TERM set to nothing gets you a "dumb" term. echo q to pftop makes it
-// quit out after displaying the first page of data.
-
-// Get top line with total state data
-$topDataLine = $rawdata[2];
-//pfTop: Up State 1-5/5, View: default, Order: none
-$slashPos = strpos($topDataLine,'/') + 1;
-$commaPos = strpos($topDataLine,',');
-if (($slashPos > 1) and ($commaPos > 1)) {
- $totalStates = substr($topDataLine,$slashPos,($commaPos - $slashPos));
-} else $totalStates = 0;
-
-// Get rid of the header data
-unset($rawdata[0],$rawdata[1],$rawdata[2],$rawdata[3]);
-
-if (isset($rawdata)) {
- $count = 0;
- foreach ($rawdata as $line) {
- if (!strlen(trim($line)) < 70)
- {
-//PR DIR SRC DEST STATE AGE EXP PKTS BYTES
-//tcp Out 192.168.111.99:62831 66.84.12.81:110 FIN_WAIT_2:FIN_WAIT_2 00:01:20 00:00:11 28 1933
-// 0 1 2 3 4 5 6 7 8
- $split = preg_split("/\s+/", trim($line));
-
- $data[$count]['protocol'] = $split[0];
- $data[$count]['dir'] = strtolower($split[1]);
- $srcTmp = $split[2];
- $data[$count]['srcip'] = stripPort($srcTmp);
- $data[$count]['srcport'] = stripPort($srcTmp,true);
- $dstTmp = $split[3];
- $data[$count]['expire'] = $split[6];
- $data[$count]['dstip'] = stripPort($dstTmp);
- $data[$count]['dstport'] = stripPort($dstTmp,true);
- $data[$count]['packets'] = $split[7];
- $data[$count]['bytes'] = $split[8];
- $count++;
- }
- }
- // Clear the statistics snapshot files, which track the packets and bytes of connections
- if (isset($_GET['clear']))
- {
- if (file_exists('/tmp/packets'))
- unlink('/tmp/packets');
- if (file_exists('/tmp/bytes'))
- unlink('/tmp/bytes');
-
- // Redirect so we don't hit "clear" every time we refresh the screen.
- header("Location: diag_new_states.php?".$filterPassThru);
- exit;
- }
-
- // Create a new set of stats snapshot files
- if (isset($_GET['new']))
- {
- $packets = array();
- $bytes = array();
-
- // Create variables to let us later quickly access this data
- if (is_array($data)) {
- foreach ($data as $row) {
- $packets[$row['srcip']][$row['srcport']][$row['dstip']][$row['dstport']][$row['protocol']] = $row['packets'];
- $bytes[$row['srcip']][$row['srcport']][$row['dstip']][$row['dstport']][$row['protocol']] = $row['bytes'];
- }
- }
-
- // Write the files out
- writeStats("packets",$packets);
- writeStats("bytes",$bytes);
-
- // If we're in view mode, pass that on.
- if (isset($_GET['view']))
- $filterPassThru .= "&view=1";
-
- // Redirect so we don't hit "new" every time we refresh the screen.
- header("Location: diag_new_states.php?&order=bytes&sort=des".$filterPassThru);
- exit;
- }
-
- // View the delta from the last snapshot against the current data.
- if (isset($_GET['view']))
- {
-
- // Read the stats data files
- readStats("packets",$packets);
- readStats("bytes",$bytes);
-
- if (is_array($data)) {
- foreach ($data as $key => $row) {
- if (isset($packets[$row['srcip']][$row['srcport']][$row['dstip']][$row['dstport']][$row['protocol']]))
- {
- if (isset($bytes[$row['srcip']][$row['srcport']][$row['dstip']][$row['dstport']][$row['protocol']]))
- {
- $tempPackets = $data[$key]['packets'] - $packets[$row['srcip']][$row['srcport']][$row['dstip']][$row['dstport']][$row['protocol']];
- $tempBytes = $data[$key]['bytes'] - $bytes[$row['srcip']][$row['srcport']][$row['dstip']][$row['dstport']][$row['protocol']];
- if (($tempPackets > -1) && ($tempBytes > -1))
- {
- $data[$key]['packets'] = $tempPackets;
- $data[$key]['bytes'] = $tempBytes;
- }
- }
- }
-
- }
- }
-
- $filterPassThru .= "&view=1";
- $viewPassThru = "&view=1";
- }
-
- // Sort it by the selected order
- if ($_GET['order']) {
- natsort2d($data,$_GET['order']);
- if ($_GET['sort'])
- {
- if ($_GET['sort'] == "des")
- $data = array_reverse($data);
- }
- }
-}
-
-function natsort2d( &$arrIn, $index = null )
-{
-
- $arrTemp = array();
- $arrOut = array();
-
- if (is_array($arrIn)) {
- foreach ( $arrIn as $key=>$value ) {
-
- reset($value);
- $arrTemp[$key] = is_null($index)
- ? current($value)
- : $value[$index];
- }
- }
-
- natsort($arrTemp);
-
- foreach ( $arrTemp as $key=>$value ) {
- $arrOut[$key] = $arrIn[$key];
- }
-
- $arrIn = $arrOut;
-
-}
-
-function writeStats($fname, &$data) {
- $fname = "/tmp/" . $fname;
- if (file_exists($fname))
- unlink($fname);
- $file = fopen($fname, 'a');
- fwrite($file, serialize($data));
- fclose($file);
-}
-
-function readStats($fname, &$data) {
- $fname = "/tmp/" . $fname;
- if (file_exists($fname))
- {
- $file = fopen($fname,'r');
- $data = unserialize(fread($file, filesize($fname)));
- fclose($file);
- }
-}
-
-// Get timestamp of snapshot file, if it exists, for display later.
-if (!(file_exists('/tmp/packets'))) {
- $lastSnapshot = "Never";
-}
-else {
- $lastSnapshot = strftime("%m/%d/%y %H:%M:%S",filectime('/tmp/packets'));
-}
-// The next include must be here because we use redirection above
-include("head.inc");
-?>
-
-<body link="#0000CC" vlink="#0000CC" alink="#0000CC">
-<script src="/javascript/scriptaculous/prototype.js" type="text/javascript"></script>
-<script src="/javascript/scriptaculous/scriptaculous.js" type="text/javascript"></script>
-<script src="/javascript/sorttable.js" type="text/javascript"></script>
-
-<?php include("fbegin.inc"); ?>
-<p class="pgtitle"><?=$pgtitle?></p>
-<table width="100%" border="0" cellpadding="0" cellspacing="0">
- <tr>
- <td class="listhdrr" colspan="9">Statistics snapshot control</td>
- </tr>
- <tr>
- <?php if (($lastSnapshot!='Never') && (!isset($_GET['view']))) :?>
- <td class="listlr"><a href="?view=1&order=bytes&sort=des<?=$filterPassThru;?>">View delta</a></td>
- <td class="listr"><a href="?new=1<?=$filterPassThru;?>">Start new</a></td>
- <td class="listr"><a href="?clear=1">Clear snapshot</a></td>
- <td class="listr" colspan="6" align="right">Last statistics snapshot: <?=$lastSnapshot;?></td>
- <?php endif; ?>
- <?php if (($lastSnapshot!='Never') && (isset($_GET['view']))) :?>
- <td class="listlr"><a href="?new=1<?=$filterPassThru;?>">Start new</a></td>
- <td class="listr"><a href="?clear=1">Clear</a></td>
- <td class="listr" colspan="7" align="right"><span class="red">Viewing delta of statistics snapshot: <?=$lastSnapshot;?></span></td>
- <?php endif; ?>
- <?php if ($lastSnapshot=='Never') :?>
- <td class="listlr"><a href="?new=1<?=$filterPassThru;?>">Start new</a></td>
- <td class="listr" colspan="8" align="right">Last statistics snapshot: <?=$lastSnapshot;?></td>
- <?php endif; ?>
- </tr>
- <tr>
- <td colspan="8">&nbsp;</td>
- </tr>
- <tr>
- <td class="listhdrr"><a href="?order=srcip<?=sortOrder('srcip');echo $filterPassThru;?>">Source</a></td>
- <td class="listhdrr"><a href="?order=srcport<?=sortOrder('srcport');echo $filterPassThru;?>">Port</a></td>
- <td class="listhdrr"><a href="?order=dir<?=sortOrder('dir');echo $filterPassThru;?>">Dir</a></td>
- <td class="listhdrr"><a href="?order=dstip<?=sortOrder('dstip');echo $filterPassThru;?>">Destination</a></td>
- <td class="listhdrr"><a href="?order=dstport<?=sortOrder('dstport');echo $filterPassThru;?>">Port</a></td>
- <td class="listhdrr"><a href="?order=protocol<?=sortOrder('protocol');echo $filterPassThru;?>">Protocol</a></td>
- <td class="listhdrr" align="right"><a href="?order=packets<?=sortOrder('packets');echo $filterPassThru;?>">Packets</a></td>
- <td class="listhdrr" align="right"><a href="?order=bytes<?=sortOrder('bytes');echo $filterPassThru;?>">Bytes</a></td>
- <td class="listhdr" align="right"><a href="?order=expire<?=sortOrder('expire');echo $filterPassThru;?>">Expires</a></td>
- <td class="list"></td>
- </tr>
-<?php $count = 0;
-if (is_array($data)): foreach ($data as $entry):
- if ((!isset($sfilter) and (!isset($dfilter))) or
- ((isset($sfilter)) and ($entry['srcip']==$sfilter)) or
- ((isset($dfilter)) and ($entry['dstip']==$dfilter))):
- ?>
- <tr>
- <td class="listlr"><?=displayIP($entry['srcip'],'srcip');?></td>
- <td class="listr"><?=$entry['srcport'];?></td>
- <td class="listr"><img src="/themes/<?= $g['theme']; ?>/images/icons/icon_<?=$entry['dir'];?>.gif" width="11" height="11" style="margin-top: 2px"></td>
- <td class="listr"><?=displayIP($entry['dstip'],'dstip');?></td>
- <td class="listr"><?=$entry['dstport'];?></td>
- <td class="listr"><?=$entry['protocol'];?></td>
- <td class="listr" align="right"><?=$entry['packets'];?></td>
- <td class="listr" align="right"><?=$entry['bytes'];?></td>
- <td class="listr" align="right"><?=$entry['expire'];?></td>
- </tr>
-<?php $count++; endif; endforeach; endif; ?>
-</table>
-<br><strong>Firewall connection states displayed: <?=$count;?>/<?=$totalStates;?></strong>
-<?php if ($filterPassThru): ?>
-<p>
-<form action="diag_new_states.php" method="GET">
-<input type="hidden" name="order" value="bytes">
-<input type="hidden" name="sort" value="des">
-<input type="submit" class="formbtn" value="Unfilter View">
-</form>
-</p>
-<?php endif; ?>
-<?php include("fend.inc"); ?>
-</body>
-</html> \ No newline at end of file
diff --git a/packages/diag_states_pt/diag_new_states.xml b/packages/diag_states_pt/diag_new_states.xml
deleted file mode 100644
index b8ea9dc3..00000000
--- a/packages/diag_states_pt/diag_new_states.xml
+++ /dev/null
@@ -1,65 +0,0 @@
-<?xml version="1.0" encoding="utf-8" ?>
-<!DOCTYPE packagegui SYSTEM "../schema/packages.dtd">
-<?xml-stylesheet type="text/xsl" href="../xsl/package.xsl"?>
-<packagegui>
- <copyright>
- <![CDATA[
-/* $Id$ */
-/* ========================================================================== */
-/*
- authng.xml
- part of pfSense (http://www.pfSense.com)
- Copyright (C) 2007 to whom it may belong
- All rights reserved.
-
- Based on m0n0wall (http://m0n0.ch/wall)
- Copyright (C) 2003-2006 Manuel Kasper <mk@neon1.net>.
- All rights reserved.
- */
-/* ========================================================================== */
-/*
- Redistribution and use in source and binary forms, with or without
- modification, are permitted provided that the following conditions are met:
-
- 1. Redistributions of source code must retain the above copyright notice,
- this list of conditions and the following disclaimer.
-
- 2. Redistributions in binary form must reproduce the above copyright
- notice, this list of conditions and the following disclaimer in the
- documentation and/or other materials provided with the distribution.
-
- THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES,
- INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY
- AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
- AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY,
- OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
- SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
- INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
- CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
- ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
- POSSIBILITY OF SUCH DAMAGE.
- */
-/* ========================================================================== */
- ]]>
- </copyright>
- <description>Describe your package here</description>
- <requirements>Describe your package requirements here</requirements>
- <faq>Currently there are no FAQ items provided.</faq>
- <name>diag_new_states</name>
- <version>0.2</version>
- <title>Diagnostics: States New</title>
- <menu>
- <name>States New</name>
- <tooltiptext>States by Paul Taylor</tooltiptext>
- <section>Diagnostics</section>
- <url>diag_new_states.php</url>
- </menu>
- <additional_files_needed>
- <prefix>/usr/local/www/</prefix>
- <chmod>0755</chmod>
- <item>http://www.pfsense.org/packages/config/diag_states_pt/diag_new_states.php</item>
- </additional_files_needed>
- <custom_php_deinstall_command>
- mwexec("rm /usr/local/www/diag_new_states.php");
- </custom_php_deinstall_command>
-</packagegui>