Re: ipsec & tcp connection stalled

From
Eugene Grosbein (2:5006/1)
To
Auster (2:5054/37.63)
Date
2006-09-08T23:59:42Z
Area
RU.UNIX.BSD
Reply-To: eugen@grosbein.pp.ru

08 сен 2006, пятница, в 16:33 KRAST, Auster написал(а):

 >> 1. Как заставить tcpdump декодировать IPSEC-трафик, прошу работающий
 >> пример строки запуска tcpdump.
 A>   % racoonctl ss esp
 A>   A.B.C.D E.F.G.K
 A> 	esp mode=transport spi=dadadada(0xAAAAAAAA) reqid=0(0x00000000)
 A> 	E: 3des-cbc <KEY1>
 A>   ...
 A>   E.F.G.K A.B.C.D
 A> 	esp mode=transport spi=adadadad(0xDDDDDDDD) reqid=0(0x00000000)
 A> 	E: 3des-cbc <KEY2>
 A>   ...
 A>   // убирая с KEY1 и KEY2 пробелы - вписываешь в файлик keys.txt:
 A>   0xAAAAAAA@E.F.G.K 3des-cbc-hmac96:0xKEY1
 A>   0xDDDDDDD@A.B.C.D 3des-cbc-hmac96:0xKEY2
 A>   // затем смотришь на интерфейсе
 A>   % tcpdump -i iface -s0 -E 'file keys.txt' 'esp && ...'
 A>   // или с сохраненного pcap'а

Огромное спасибо.

Так как у меня нет racoonctl, на FreeBSD 6.1 (с адресом IP2) сделал так:

setkey -D | awk '
  /^[1-9]/  { ip=$2; }
  $1=="esp" {
                sub(/spi=[^(]+\(/, "", $3);
                sub(/\)/, "", $3);
                printf"%s@%s ",$3,ip;
            }
  $1=="E:"  { printf "%s:0x%s%s%s%s\n", $2, $3, $4, $5, $6; }
' > /tmp/keys.txt

Получил в /tmp/keys.txt тот формат, что ты описал:

0x000007d7@IP1 blowfish-cbc:0x................................
0x000003ef@IP2 blowfish-cbc:0x................................

Запускаю tcpdump, как ты сказал, получаю странную вещь:

00:51:49.268607 IP IP1 > IP2: ESP(spi=0x000003ef,seq=0x25386), length 112:
ESP(spi=0x000003ef,seq=0x25385), length 88
00:51:49.268680 IP IP2 > IP1: ESP(spi=0x000007d7,seq=0x42a4), length 88: ICMP
echo reply, id 57344, seq 0, length 64

Это был входящий ping и он был успешным. Но tcpdump декодировал только
ответный echo reply, а во входящем пакете якобы был ESP внутри ESP??
Что я делаю не так?

Вот /etc/ipsec.conf на этой машине:

add IP1 IP2 esp 1007 -m transport -E blowfish-cbc "...";
add IP2 IP1 esp 2007 -m transport -E blowfish-cbc "...";

spdadd IP1/32 IP2/32 any -P in  ipsec esp/transport/IP1-IP2/require;
spdadd IP2/32 IP1/32 any -P out ipsec esp/transport/IP2-IP1/require;

Eugene
-- 
Устав от вечных упований,
Устав от радостных пиров
--- slrn/0.9.8.0 (FreeBSD)
 * Origin: Svyaz Service JSC (2:5006/1@fidonet)
SEEN-BY: 50/12 203 400/814 450/159 186 1024 451/30 461/43 132 640 469/999
SEEN-BY: 550/196 4616/3 4625/8 4635/4 4641/444 5000/76 5000 5006/1 8 9 10 14
SEEN-BY: 5006/15 16 17 5007/1 5010/70 352 5011/13 5012/46 5015/28 5019/31
SEEN-BY: 5020/18 154 175 194 400 545 549 715 758 982 1057 1523 1604 1630 1909
SEEN-BY: 5020/1922 2142 2238 2395 2450 2590 2871 4441 5021/3 29 5022/128
SEEN-BY: 5025/3 750 5026/45 5027/12 5029/32 5030/49 500 556 966 1063 1080 1900
SEEN-BY: 5030/1957 2828 5031/47 70 5034/10 13 5035/3 38 5036/1 5040/47 5042/13
SEEN-BY: 5045/7 5049/1 50 97 5051/15 5054/1 4 8 9 11 28 35 36 37 45 63 66 67
SEEN-BY: 5054/70 75 84 85 5055/95 5057/1 5059/9 5060/88 5061/15 5062/1 10
SEEN-BY: 5063/3 5064/7 5066/18 5074/9 5075/5 5077/70 5080/80 1003 5082/6
SEEN-BY: 5083/21 5085/13 5090/108 5094/4 5095/20 5096/18 5099/11 6001/3 10
PATH: 5006/1 5020/400 4441 545 5054/1 37