Project

General

Profile

Actions

Bug #1190

closed

http_header keyword not matching when SYN|ACK and ACK missing

Added by Matt Carothers over 10 years ago. Updated about 10 years ago.

Status:
Closed
Priority:
Normal
Assignee:
Target version:
Affected Versions:
Effort:
Difficulty:
Label:

Description

When using async-oneside and midstream, the http_header keyword does not function in some cases. Example rules:

alert http any any -> any any (msg:"Test 1 Sinkhole HTTP Response - Content only"; content:"X-Sinkhole|3a| "; sid:1;)
alert http any any -> any any (msg:"Test 2 Sinkhole HTTP Response - Content and http_header"; content:"X-Sinkhole|3a| "; http_header; sid:2;)

Test cases:

  • Full TCP handshake + HTTP GET + HTTP response - both rules trigger

    1 0.000000 192.168.0.33 -> 10.0.0.77 TCP 74 33382 > 80 [SYN] Seq=0 Win=29200 Len=0 MSS=1460 SACK_PERM=1 TSval=1250203509 TSecr=0 WS=128
    2 0.022648 10.0.0.77 -> 192.168.0.33 TCP 74 80 > 33382 [SYN, ACK] Seq=0 Ack=1 Win=14480 Len=0 MSS=1440 SACK_PERM=1 TSval=622145469 TSecr=1250203509 WS=256
    3 0.022680 192.168.0.33 -> 10.0.0.77 TCP 66 33382 > 80 [ACK] Seq=1 Ack=1 Win=29312 Len=0 TSval=1250203515 TSecr=622145469
    4 0.022831 192.168.0.33 -> 10.0.0.77 HTTP 178 GET / HTTP/1.1
    5 0.045884 10.0.0.77 -> 192.168.0.33 TCP 66 80 > 33382 [ACK] Seq=1 Ack=113 Win=14592 Len=0 TSval=622145474 TSecr=1250203515
    6 0.047133 10.0.0.77 -> 192.168.0.33 HTTP 365 HTTP/1.1 302 Found

  • SYN|ACK from server missing - both rules trigger

    1 0.000000 192.168.0.33 -> 10.0.0.77 TCP 74 33382 > 80 [SYN] Seq=0 Win=29200 Len=0 MSS=1460 SACK_PERM=1 TSval=1250203509 TSecr=0 WS=128
    2 0.022680 192.168.0.33 -> 10.0.0.77 TCP 66 33382 > 80 [ACK] Seq=1 Ack=1 Win=29312 Len=0 TSval=1250203515 TSecr=622145469
    3 0.022831 192.168.0.33 -> 10.0.0.77 HTTP 178 GET / HTTP/1.1
    4 0.045884 10.0.0.77 -> 192.168.0.33 TCP 66 80 > 33382 [ACK] Seq=1 Ack=113 Win=57 Len=0 TSval=622145474 TSecr=1250203515
    5 0.047133 10.0.0.77 -> 192.168.0.33 HTTP 365 HTTP/1.1 302 Found

  • SYN|ACK from server and ACK from client missing - the content rule triggers, but the http_header rule does not trigger

    1 0.000000 192.168.0.33 -> 10.0.0.77 TCP 74 33382 > 80 [SYN] Seq=0 Win=29200 Len=0 MSS=1460 SACK_PERM=1 TSval=1250203509 TSecr=0 WS=128
    2 0.022831 192.168.0.33 -> 10.0.0.77 HTTP 178 GET / HTTP/1.1
    3 0.045884 10.0.0.77 -> 192.168.0.33 TCP 66 80 > 33382 [ACK] Seq=1 Ack=113 Win=57 Len=0 TSval=622145474 TSecr=1250203515
    4 0.047133 10.0.0.77 -> 192.168.0.33 HTTP 365 HTTP/1.1 302 Found

  • Full handshake missing - both rules trigger

    1 0.000000 192.168.0.33 -> 10.0.0.77 HTTP 178 GET / HTTP/1.1
    2 0.023053 10.0.0.77 -> 192.168.0.33 TCP 66 80 > 33382 [ACK] Seq=1 Ack=113 Win=57 Len=0 TSval=622145474 TSecr=1250203515
    3 0.024302 10.0.0.77 -> 192.168.0.33 HTTP 365 HTTP/1.1 302 Found

  • SYN missing - neither rule triggers - this is perhaps a second bug

    1 0.000000 10.0.0.77 -> 192.168.0.33 TCP 74 80 > 33382 [SYN, ACK] Seq=0 Ack=1 Win=14480 Len=0 MSS=1440 SACK_PERM=1 TSval=622145469 TSecr=1250203509 WS=256
    2 0.000032 192.168.0.33 -> 10.0.0.77 TCP 66 33382 > 80 [ACK] Seq=1 Ack=1 Win=229 Len=0 TSval=1250203515 TSecr=622145469
    3 0.000183 192.168.0.33 -> 10.0.0.77 HTTP 178 GET / HTTP/1.1
    4 0.023236 10.0.0.77 -> 192.168.0.33 TCP 66 80 > 33382 [ACK] Seq=1 Ack=113 Win=14592 Len=0 TSval=622145474 TSecr=1250203515
    5 0.024485 10.0.0.77 -> 192.168.0.33 HTTP 365 HTTP/1.1 302 Found

With only the SYN missing, two stream event rules trigger:

05/07/2014-11:26:55.414347 [**] [1:2210029:2] SURICATA STREAM ESTABLISHED invalid ack [**] [Classification: Generic Protocol Command Decode] [Priority: 3] {TCP} 10.0.0.77:80 -> 192.168.0.33:33382
05/07/2014-11:26:55.414347 [**] [1:2210045:2] SURICATA STREAM Packet with invalid ack [**] [Classification: Generic Protocol Command Decode] [Priority: 3] {TCP} 10.0.0.77:80 -> 192.168.0.33:33382


Files

x-sinkhole-full-anon-missing-syn-ack-and-ack.pcap (1.15 KB) x-sinkhole-full-anon-missing-syn-ack-and-ack.pcap HTTP request missing SYN and SYN|ACK Matt Carothers, 10/23/2014 07:20 PM
test-matrix.png (5.62 KB) test-matrix.png Matt Carothers, 10/29/2014 02:59 PM
test-SYN_ACK.pcap (1.52 KB) test-SYN_ACK.pcap Pcap with only SYN|ACK present Matt Carothers, 10/29/2014 02:59 PM
test-SYN_ACK-ACK.pcap (1.64 KB) test-SYN_ACK-ACK.pcap Pcap with only SYN|ACK and ACK present Matt Carothers, 10/29/2014 02:59 PM
Actions #1

Updated by Victor Julien over 10 years ago

Did you try the git master? I did some fixes in there after the 2.0 release.

Actions #2

Updated by Matt Carothers about 10 years ago

Sorry Victor, I totally missed your reply. I tested again today from git, and the bug still exists.

Actions #3

Updated by Matt Carothers about 10 years ago

I could have sworn I attached a pcap to the original report. This pcap should trigger both rules, but it only triggers the first.

Actions #4

Updated by Victor Julien about 10 years ago

  • Status changed from New to Assigned
  • Assignee set to Victor Julien
  • Target version set to 2.0.5
Actions #5

Updated by Victor Julien about 10 years ago

  • Status changed from Assigned to Closed
  • % Done changed from 0 to 100

Updated by Matt Carothers about 10 years ago

Thanks, Victor. The latest version from git now functions correctly for the case of the missing SYN|ACK and ACK. The missing SYN case still doesn't work, however. I went ahead and tested all 8 permutations. I've attached the test matrix and two pcap files that don't generate any hits with the two rules above.

Actions #7

Updated by Victor Julien about 10 years ago

Both those cases now also work in https://github.com/inliniac/suricata/pull/1194

Actions

Also available in: Atom PDF