summaryrefslogtreecommitdiff
path: root/scripts/vyatta-tshark-interface-port.pl
diff options
context:
space:
mode:
authorMohit Mehta <mohit.mehta@vyatta.com>2008-04-03 21:59:25 +0000
committerMohit Mehta <mohit.mehta@vyatta.com>2008-04-03 21:59:25 +0000
commit5612efdef70dca2c8f02578cc1b119be4b794d08 (patch)
treebb4893de453981d6b7dcf22ec966379c54199a5f /scripts/vyatta-tshark-interface-port.pl
parentd14dee306fe9a8f497e20d9fa58bd199615569c3 (diff)
downloadvyatta-op-5612efdef70dca2c8f02578cc1b119be4b794d08.tar.gz
vyatta-op-5612efdef70dca2c8f02578cc1b119be4b794d08.zip
Fix Bug 1059 Feature Request: integrate 'tcpdump' and 'tethereal' into Vyatta CLI
- 'show interfaces ethernet <> capture' captures traffic at specified interface - 'show interfaces ethernet <> capture port <>' captures traffic at specified interface port - 'show interfaces ethernet <> capture not port <>' captures traffic at specified interface excluding specified port
Diffstat (limited to 'scripts/vyatta-tshark-interface-port.pl')
-rw-r--r--scripts/vyatta-tshark-interface-port.pl62
1 files changed, 62 insertions, 0 deletions
diff --git a/scripts/vyatta-tshark-interface-port.pl b/scripts/vyatta-tshark-interface-port.pl
new file mode 100644
index 0000000..4eff322
--- /dev/null
+++ b/scripts/vyatta-tshark-interface-port.pl
@@ -0,0 +1,62 @@
+#!/usr/bin/perl
+#
+# Module: vyatta-tshark-interface-port.pl
+#
+# **** License ****
+# This program is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License version 2 as
+# published by the Free Software Foundation.
+#
+# This program is distributed in the hope that it will be useful, but
+# WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+# General Public License for more details.
+#
+# This code was originally developed by Vyatta, Inc.
+# Portions created by Vyatta are Copyright (C) 2006, 2007, 2008 Vyatta, Inc.
+# All Rights Reserved.
+#
+# Author: Mohit Mehta
+# Date: April 2008
+# Description: tshark on a given port for a given interface from vyatta cli
+#
+# **** End License ****
+#
+
+use lib "/opt/vyatta/share/perl5/";
+
+use strict;
+use warnings;
+
+#
+# main
+#
+
+my $intf = $ARGV[0];
+
+if ($#ARGV > 0){
+ my $port = $ARGV[1];
+ my $not_port = $ARGV[2];
+ if ($port =~ /[a-zA-Z]/){
+ print "Port number has to be numeric. Allowed values: <1-65535>\n";
+ exit 1;
+ } else {
+ if (($port > 0) and ($port < 65536)){
+ if ($not_port == 0){
+ exec "sudo /usr/bin/tshark -n -i $intf port $port";
+ } else {
+ exec "sudo /usr/bin/tshark -n -i $intf not port $port";
+ }
+ } else {
+ print "Invalid port number. Allowed values: <1-65535>\n";
+ exit 1;
+ }
+
+ }
+} else {
+ exec "sudo /usr/bin/tshark -n -i $intf";
+}
+
+exit 0;
+
+#end of file