aboutsummaryrefslogtreecommitdiff
path: root/src/lib/protocols/tencent_games.c
diff options
context:
space:
mode:
authorToni Uhlig <matzeton@googlemail.com>2024-04-02 04:42:06 +0200
committerToni Uhlig <matzeton@googlemail.com>2024-04-02 04:42:06 +0200
commitf25e290be0b6bd40553c33bd0e3fb8ec3234ba91 (patch)
treecfc5f796cb9212feb77f0666a5111bd5a4e7910a /src/lib/protocols/tencent_games.c
parent21572635ab15a993600c4efd1246ac0691968a75 (diff)
parent599cc0f4b83a96c247a92aaaa3f39acfec9e1dbe (diff)
Merge remote-tracking branch 'origin/dev' into fix/unused-params-and-fnsfix/unused-params-and-fns
Diffstat (limited to 'src/lib/protocols/tencent_games.c')
-rw-r--r--src/lib/protocols/tencent_games.c41
1 files changed, 38 insertions, 3 deletions
diff --git a/src/lib/protocols/tencent_games.c b/src/lib/protocols/tencent_games.c
index df40f5f8d..12bde1b37 100644
--- a/src/lib/protocols/tencent_games.c
+++ b/src/lib/protocols/tencent_games.c
@@ -29,6 +29,14 @@
#include "ndpi_api.h"
#include "ndpi_private.h"
+static void ndpi_int_tencent_games_add_connection(struct ndpi_detection_module_struct *ndpi_struct,
+ struct ndpi_flow_struct *flow)
+{
+ NDPI_LOG_INFO(ndpi_struct, "found Tencent Games\n");
+ ndpi_set_detected_protocol(ndpi_struct, flow, NDPI_PROTOCOL_TENCENTGAMES,
+ NDPI_PROTOCOL_UNKNOWN, NDPI_CONFIDENCE_DPI);
+}
+
static void ndpi_search_tencent_games(struct ndpi_detection_module_struct *ndpi_struct,
struct ndpi_flow_struct *flow)
{
@@ -40,9 +48,36 @@ static void ndpi_search_tencent_games(struct ndpi_detection_module_struct *ndpi_
if (ntohl(get_u_int32_t(packet->payload, 0)) == 0x3366000B &&
ntohs(get_u_int16_t(packet->payload, 4)) == 0xB)
{
- NDPI_LOG_INFO(ndpi_struct, "found Tencent Games\n");
- ndpi_set_detected_protocol(ndpi_struct, flow, NDPI_PROTOCOL_TENCENTGAMES,
- NDPI_PROTOCOL_UNKNOWN, NDPI_CONFIDENCE_DPI);
+ ndpi_int_tencent_games_add_connection(ndpi_struct, flow);
+ return;
+ }
+
+ if (ntohl(get_u_int32_t(packet->payload, 0)) == 0x4366AA00 &&
+ ntohl(get_u_int32_t(packet->payload, 12)) == 0x10E68601)
+ {
+ ndpi_int_tencent_games_add_connection(ndpi_struct, flow);
+ return;
+ }
+
+ if (ntohl(get_u_int32_t(packet->payload, 0)) == 0xAA000000 &&
+ ntohl(get_u_int32_t(packet->payload, 10)) == 0x10E68601)
+ {
+ ndpi_int_tencent_games_add_connection(ndpi_struct, flow);
+ return;
+ }
+
+ if (get_u_int16_t(packet->payload, 0) == 0 &&
+ ntohs(get_u_int16_t(packet->payload, 2)) == (u_int16_t)(packet->payload_packet_len-4) &&
+ ntohs(get_u_int16_t(packet->payload, 4)) == 0x7801)
+ {
+ ndpi_int_tencent_games_add_connection(ndpi_struct, flow);
+ return;
+ }
+
+ if (ntohl(get_u_int32_t(packet->payload, 0)) == 0x4215F787 &&
+ get_u_int16_t(packet->payload, 6) == 0)
+ {
+ ndpi_int_tencent_games_add_connection(ndpi_struct, flow);
return;
}
}