aboutsummaryrefslogtreecommitdiff
path: root/src/lib/protocols/dnscrypt.c
diff options
context:
space:
mode:
authorToni <matzeton@googlemail.com>2021-07-14 11:09:58 +0200
committerGitHub <noreply@github.com>2021-07-14 11:09:58 +0200
commit62bae30a4a8622ff831e49f252e7b16115788ee8 (patch)
tree5639fa0fc48925d4a2ab0976cf9d4de2aa8f0792 /src/lib/protocols/dnscrypt.c
parente4453938d5329daaa0ea682bba55d354759c077e (diff)
Improved Steam detection (Steam Datagram Relay - SDR). (#1243)
* improved DNSCrypt midstream detection again (sufficient for all tested use-cases) Signed-off-by: Toni Uhlig <matzeton@googlemail.com>
Diffstat (limited to 'src/lib/protocols/dnscrypt.c')
-rw-r--r--src/lib/protocols/dnscrypt.c19
1 files changed, 14 insertions, 5 deletions
diff --git a/src/lib/protocols/dnscrypt.c b/src/lib/protocols/dnscrypt.c
index af147614a..a5bbd0c0e 100644
--- a/src/lib/protocols/dnscrypt.c
+++ b/src/lib/protocols/dnscrypt.c
@@ -38,22 +38,31 @@ void ndpi_search_dnscrypt(struct ndpi_detection_module_struct *ndpi_struct,
NDPI_LOG_DBG(ndpi_struct, "search dnscrypt\n");
- if (flow->packet_counter > 3)
- {
- NDPI_EXCLUDE_PROTO(ndpi_struct, flow);
- }
-
/* dnscrypt protocol version 1: check magic */
if (packet->payload_packet_len >= 64 &&
strncmp((char*)packet->payload, "r6fnvWj8", strlen("r6fnvWj8")) == 0)
{
ndpi_int_dnscrypt_add_connection(ndpi_struct, flow);
+ return;
}
/* dnscrypt protocol version 1 and 2: resolver ping */
if (packet->payload_packet_len > 13 + strlen(dnscrypt_initial) &&
strncasecmp((char*)packet->payload + 13, dnscrypt_initial, strlen(dnscrypt_initial)) == 0)
{
ndpi_int_dnscrypt_add_connection(ndpi_struct, flow);
+ return;
+ }
+
+ if ((flow->packet_direction_counter[packet->packet_direction] >= 1 &&
+ flow->packet_direction_counter[1 - packet->packet_direction] >= 1) ||
+ flow->packet_counter >= 10)
+ {
+ /*
+ * Wait for at least one packet per direction, but not more then 10 packets.
+ * Required as we need to wait for the server response which contains the ASCII pattern below.
+ */
+ NDPI_EXCLUDE_PROTO(ndpi_struct, flow);
+ return;
}
}