1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86
|
#!/usr/bin/tclsh
#
# Copyright (C) 2001 by USC/ISI
# All rights reserved.
#
# Redistribution and use in source and binary forms are permitted
# provided that the above copyright notice and this paragraph are
# duplicated in all such forms and that any documentation, advertising
# materials, and other materials related to such distribution and use
# acknowledge that the software was developed by the University of
# Southern California, Information Sciences Institute. The name of the
# University may not be used to endorse or promote products derived from
# this software without specific prior written permission.
#
# THIS SOFTWARE IS PROVIDED "AS IS" AND WITHOUT ANY EXPRESS OR IMPLIED
# WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF
# MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
#
# An tcl script that find and pair SYN and SYN-ACK packets for each tcp
# connection, used by SAMAN ModelGen
#
# This work is supported by DARPA through SAMAN Project
# (http://www.isi.edu/saman/), administered by the Space and Naval
# Warfare System Center San Diego under Contract No. N66001-00-C-8066
if { $argc != 2} {
puts "usage: pair.tcl <tcpdump ASCII file> <prefix>"
exit
} else {
set arg [split $argv " " ]
set tfile [lindex $arg 0]
set prefix [lindex $arg 1]
}
set arg1 [split $prefix "." ]
set netPrefix [format "%s.%s" [lindex $arg1 0] [lindex $arg1 1]]
set prevClnt ""
set prevSvr ""
set fi [open $tfile r ]
while {[gets $fi line] >= 0} {
set client [lindex $line 0]
set server [lindex $line 1]
set time [lindex $line 2]
set c [split $client ".:" ]
set s [split $server ".:" ]
set Sequence [split [lindex $line 3] ":"]
set seq [lindex $Sequence 0]
set Client [format "%s.%s.%s.%s.%s" [lindex $c 0] [lindex $c 1] [lindex $c 2] [lindex $c 3] [lindex $c 4]]
set Server [format "%s.%s.%s.%s.%s" [lindex $s 0] [lindex $s 1] [lindex $s 2] [lindex $s 3] [lindex $s 4]]
set Client1 [format "%s.%s.%s.%s" [lindex $c 0] [lindex $c 1] [lindex $c 2] [lindex $c 3]]
set Server1 [format "%s.%s.%s.%s" [lindex $s 0] [lindex $s 1] [lindex $s 2] [lindex $s 3]]
set ClientD [format "%s.%s" [lindex $c 0] [lindex $c 1]]
set ack [lindex $line 4]
if { [lindex $line 5] != "win"} {
set seq1 [expr [lindex $line 5] - 1]
if { $Client == $prevClnt} {
if { $Server == $prevSvr} {
if { $ack == "ack"} {
if { $ClientD == $netPrefix} {
if { $seq1 == $prevSeq} {
puts "$Client1 $Server1 [expr $time - $prevTime]"
}
}
}
}
}
}
set prev $line
set prevClnt $Client
set prevSvr $Server
set prevSeq $seq
set prevTime $time
}
close $fi
|