diff options
author | Igor Duarte <igor.ribeiro.duarte@gmail.com> | 2020-10-27 04:45:09 -0300 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-10-27 08:45:09 +0100 |
commit | ba6a48c9fec64b0e3617f7f7f1f6afeedd8b6437 (patch) | |
tree | 68c123f94207df21f306fe3bbfc5bc95e5704582 /src/lib/protocols/skype.c | |
parent | 48d640583a58de62ed1a500e2e98b19a9ffce1ef (diff) |
Improve skype detection (#1039)
* Add new skype pcap
PCAP extracted from SkypeIRC.cap (available in https://wiki.wireshark.org/SampleCaptures?action=AttachFile&do=get&target=SkypeIRC.cap)
* Improve skype detection
Diffstat (limited to 'src/lib/protocols/skype.c')
-rw-r--r-- | src/lib/protocols/skype.c | 45 |
1 files changed, 45 insertions, 0 deletions
diff --git a/src/lib/protocols/skype.c b/src/lib/protocols/skype.c index 01d93bda7..22d94c021 100644 --- a/src/lib/protocols/skype.c +++ b/src/lib/protocols/skype.c @@ -27,6 +27,36 @@ static int is_port(u_int16_t a, u_int16_t b, u_int16_t c) { return(((a == c) || (b == c)) ? 1 : 0); } +static int ndpi_check_skype_udp_again(struct ndpi_detection_module_struct *ndpi_struct, struct ndpi_flow_struct *flow) { + struct ndpi_packet_struct *packet = &flow->packet; + u_int32_t payload_len = packet->payload_packet_len; + + const uint8_t id_flags_iv_crc_len = 11; + const uint8_t crc_len = sizeof(flow->l4.udp.skype_crc); + const uint8_t crc_offset = id_flags_iv_crc_len - crc_len; + + if ((payload_len >= id_flags_iv_crc_len) && (packet->payload[2] == 0x02 /* Payload flag */ )) { + u_int8_t detected = 1; + + /* Check if both packets have the same CRC */ + for (int i = 0; i < crc_len && detected; i++) { + if (packet->payload[crc_offset + i] != flow->l4.udp.skype_crc[i]) + detected = 0; + } + + if (detected) { + ndpi_set_detected_protocol(ndpi_struct, flow, NDPI_PROTOCOL_SKYPE, NDPI_PROTOCOL_UNKNOWN); + flow->extra_packets_func = NULL; + + /* Stop checking extra packets */ + return 0; + } + } + + /* Check more packets */ + return 1; +} + static void ndpi_check_skype(struct ndpi_detection_module_struct *ndpi_struct, struct ndpi_flow_struct *flow) { struct ndpi_packet_struct *packet = &flow->packet; // const u_int8_t *packet_payload = packet->payload; @@ -73,6 +103,21 @@ static void ndpi_check_skype(struct ndpi_detection_module_struct *ndpi_struct, s ndpi_set_detected_protocol(ndpi_struct, flow, NDPI_PROTOCOL_SKYPE_CALL, NDPI_PROTOCOL_SKYPE); } } + + if (flow->detected_protocol_stack[0] == NDPI_PROTOCOL_UNKNOWN) { + const uint8_t id_flags_iv_crc_len = 11; + const uint8_t crc_len = sizeof(flow->l4.udp.skype_crc); + const uint8_t crc_offset = id_flags_iv_crc_len - crc_len; + if ((payload_len >= id_flags_iv_crc_len) && (packet->payload[2] == 0x02 /* Payload flag */ ) && !flow->extra_packets_func) { + flow->check_extra_packets = 1; + flow->max_extra_packets_to_check = 5; + flow->extra_packets_func = ndpi_check_skype_udp_again; + + memcpy(flow->l4.udp.skype_crc, &packet->payload[crc_offset], crc_len); + return; + } + } + } // return; |