add intercept-capture script
This commit is contained in:
parent
890bffb510
commit
9f4e77cdac
4 changed files with 76 additions and 5 deletions
3
Changes
3
Changes
|
|
@ -1,3 +1,6 @@
|
|||
* Wed Oct 12 2005 Brendan O'Dea <bod@optus.net> 2.1.10
|
||||
- Add scripts/l2tpns-capture.
|
||||
|
||||
* Tue Oct 11 2005 Brendan O'Dea <bod@optus.net> 2.1.9
|
||||
- Fix Calling-Station-Id in RADIUS accounting records (Slobodan Tomic).
|
||||
- Fix RADIUS authentication on DAE responses.
|
||||
|
|
|
|||
4
l2tpns.h
4
l2tpns.h
|
|
@ -1,5 +1,5 @@
|
|||
// L2TPNS Global Stuff
|
||||
// $Id: l2tpns.h,v 1.94 2005-10-11 07:06:56 bodea Exp $
|
||||
// $Id: l2tpns.h,v 1.95 2005-10-12 07:16:13 bodea Exp $
|
||||
|
||||
#ifndef __L2TPNS_H__
|
||||
#define __L2TPNS_H__
|
||||
|
|
@ -15,7 +15,7 @@
|
|||
#include <sys/types.h>
|
||||
#include <libcli.h>
|
||||
|
||||
#define VERSION "2.1.9"
|
||||
#define VERSION "2.1.10"
|
||||
|
||||
// Limits
|
||||
#define MAXTUNNEL 500 // could be up to 65535
|
||||
|
|
|
|||
|
|
@ -1,6 +1,6 @@
|
|||
Summary: A high-speed clustered L2TP LNS
|
||||
Name: l2tpns
|
||||
Version: 2.1.9
|
||||
Version: 2.1.10
|
||||
Release: 1
|
||||
Copyright: GPL
|
||||
Group: System Environment/Daemons
|
||||
|
|
@ -43,5 +43,5 @@ rm -rf %{buildroot}
|
|||
%attr(644,root,root) /usr/share/man/man[58]/*
|
||||
|
||||
%changelog
|
||||
* Tue Oct 11 2005 Brendan O'Dea <bod@optus.net> 2.1.9-1
|
||||
- 2.1.9 release, see /usr/share/doc/l2tpns-2.1.9/Changes
|
||||
* Wed Oct 12 2005 Brendan O'Dea <bod@optus.net> 2.1.10-1
|
||||
- 2.1.10 release, see /usr/share/doc/l2tpns-2.1.10/Changes
|
||||
|
|
|
|||
68
scripts/l2tpns-capture
Normal file
68
scripts/l2tpns-capture
Normal file
|
|
@ -0,0 +1,68 @@
|
|||
#! /usr/bin/perl -w
|
||||
|
||||
#
|
||||
# Accept intercept data from l2tpns, write to a file in pcap format
|
||||
# (http://wiki.ethereal.com/Development/LibpcapFileFormat) suffixed
|
||||
# with timestamp. Killing the process with SIGHUP causes a new file
|
||||
# to be opened.
|
||||
#
|
||||
|
||||
use strict;
|
||||
use IO::File;
|
||||
use IO::Socket;
|
||||
use Time::HiRes 'gettimeofday';
|
||||
|
||||
(my $cmd = $0) =~ s!.*//!!;
|
||||
|
||||
die "Usage: $cmd PREFIX PORT\n" unless @ARGV == 2 and $ARGV[1] =~ /^\d+$/;
|
||||
|
||||
my ($prefix, $port) = @ARGV;
|
||||
my $sock = IO::Socket::INET->new(
|
||||
LocalPort => $port,
|
||||
Proto => 'udp',
|
||||
Type => SOCK_DGRAM,
|
||||
) or die "$cmd: can't bind to port $port ($!)\n";
|
||||
|
||||
my $restart = 0;
|
||||
$SIG{HUP} = sub { $restart++ };
|
||||
|
||||
my $header = pack LSSlLLL =>
|
||||
0xa1b2c3d4, # magic no
|
||||
2, # version maj
|
||||
4, # version min
|
||||
0, # timezone offset (GMT)
|
||||
0, # timestamp accuracy
|
||||
65536, # snaplen
|
||||
12; # link type (RAW_IP)
|
||||
|
||||
my $cap;
|
||||
my $buf;
|
||||
my $file;
|
||||
for (;;)
|
||||
{
|
||||
unless ($cap)
|
||||
{
|
||||
$file = $prefix . time;
|
||||
$cap = IO::File->new("> $file")
|
||||
or die "$0: can't create capture file $file ($!)\n";
|
||||
|
||||
$cap->print($header)
|
||||
or die "$0: error writing to $file ($!)\n";
|
||||
}
|
||||
|
||||
while ($sock->recv($buf, 1600))
|
||||
{
|
||||
$cap->print(
|
||||
# packet header: sec, usec, included size, original size
|
||||
(pack LLLL => (gettimeofday), (length $buf) x 2),
|
||||
$buf
|
||||
) or die "$0: error writing to $file ($!)\n";
|
||||
}
|
||||
|
||||
if ($restart)
|
||||
{
|
||||
$restart = 0;
|
||||
$cap->close;
|
||||
undef $cap;
|
||||
}
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue