+* 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.
// 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__
#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
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
%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
--- /dev/null
+#! /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;
+ }
+}