use strict; # # extract DIAMETER chunks into separate rows in a file for analysis # this version for TCP based DIAMETER interfaces (SWx, STa, Gx, Gxa, S6b # my %columns = ( # frame 0=>"frame.time", 1=>"frame.number", 2=>"frame.len", 3=>"ip.src", 4=>"tcp.srcport", 5=>"ip.dst", 6=>"tcp.dstport", # data 7=>"diameter.applicationId", 8=>"diameter.Session-Id", 9=>"diameter.Origin-Host", 10=>"diameter.Destination-Host", 11=>"diameter.User-Name", 12=>"diameter.cmd.code", 13=>"diameter.flags.request", 14=>"diameter.flags.T", 15=>"diameter.Result-Code", ); print "Start: ", time(), "\n"; my $et = time(); my $framecounter; my $chunkcounter; # input and output files my $input = $ARGV[0]; my $output = $input . ".txt"; my $tsharkcmd = q[c:/progra~1/wireshark/tshark.exe -n -2 -t e -T fields]; foreach (sort {$a <=> $b} keys %columns) { $tsharkcmd .= " -e $columns{$_}"; } $tsharkcmd .= " -r $input |"; print "\n", $tsharkcmd, "\n\n"; # open filehandles open OUT, ">$output" or die "cannot open $output: $!\n"; open TSHARK, $tsharkcmd or die "cannot open tshark: $!\n"; # dechunking starts here # print "\nFinished: ", time(), "\n"; $et = time() - $et; print "elapsed time: $et\n"; my $fps = $framecounter / $et; my $cps = $chunkcounter / $et; print "frames processed: $framecounter ($fps/sec)\n"; print "chunks processed: $chunkcounter ($cps/sec)\n";