diff --git a/CHANGELOG.md b/CHANGELOG.md index b53b78781fc..816e36bcf18 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,279 @@ # CHANGELOG +#### nDPI 4.8 (Oct 2023) + +## Major Changes +- Reworked lists implementation that decreased memory usage of orders of magnitude +- Improved code robustness via extensive code fuzzing +- Various improvements to overall library performance +- Extended IPv6 support + +## New Supported Protocols and Services + + - Add "Heroes of the Storm" video game signature detection. (#1949) + - Add Apache Thrift protocol dissector. (#2007) + - Add Remote Management Control Protocol (RMCP). + - Add Service Location Protocol dissector. (#2036) + - Add VK detection (#1880) + - Add Yandex services detection (#1882) + - Add a new protocol id for generic Adult Content traffic (#1906) + - Add a new protocol id for generic advertisement/analytics/tracking stuff (#1904) + - Add bitcoing protocol dissector. (#1992) + - Add detection of Roblox games (#2054) + - Add support for (un-encrypted) HTTP/2 (#2087) + - Add support for Epic Games and GeForceNow/Nvidia (#1990) + - Add support for SRTP (#1977) + - Added BACnet dissector. (#1940) + - Added HAProxy protocol. (#2088) + - Added OICQ dissector. (#1950) + - Added OperaVPN detection +- ProtonVPN: add basic detection (#2006) + - Added detection of Facebook Reels and Stories + - Add an heuristic to detect fully encrypted flows (#2058) + - Added NDPI_MALWARE_HOST_CONTACTED flow risk + - Added NDPI_TLS_ALPN_SNI_MISMATCH flow risk + +## Improvements + + - Improve protocol detection for: + - FreeBSD compilation fix (C) update + - Gnutella: improve detection (#2019) + - H323: fix false positives (#1916) + - HTTP: fix another memory access error (#2049) + - HTTP: fix extraction of filename (#2046) + - HTTP: fix heap-buffer-overflow (#2044) + - HTTP: improve extraction of metadata and of flow risks (#1959) + - HTTP: remove useless code about XBOX (#1958) + - HTTP: rework state machine (#1966) + - Hangout: detect Hangout/Duo/GoogleMeet/... in the STUN code (#2025) + - Enhance DNS risk for long hostnames (> 32) + - Enhanced MS teams STUN/Azure detection + - Enhanced custom port definition and improved error reporting in case of duplications + - Improve detection of Alibaba flows (#1991) + - Improve detection of crawler/bot traffic (#1956) + - Improve detection of crawlers/bots (#1968) + - Improved MGCP detection by allowing '\r' as line feed. + - Improved MS Teams detection with heuristic + - Improved Steam detection by adding steamdiscover pattern. (#2105) + - Improved Wireguard detection + - Improved checks for duplicated entries in protocols file + - Improved classification further reducing memory used + - Improved detection of invalid chars in DNS names + - Improved domain search tet unit + - Improved helper scripts. (#1986) + - MS Teams enhancement + - MySql: improve detection (#1928) + - zabbix: improve detection (#2055) + +## Tools + + - ndpiReader: allow to configure LRU caches TTL and size (#2004) + - ndpiReader: fix VXLAN de-tunneling (#1913) + - ndpiReader: fix export of DNS/BitTorrent attributes (#1985) + - ndpiReader: fix export of HTTP attributes (#1982) + - ndpiReader: fix flow stats (#1943) + - ndpiReader: fix print of flow payload (#1960) + - ndpiReader: improve printing of payload statistics (#1989) + - ndpiReader: print how many packets (per flow) were needed to perform full DPI (#1891) + - ndpireader: fix detection of DoH traffic based on packet distributions (#2045) + +## Misc + - ARM compilation fix + - Add `ndpi_domain_classify_finalize()` function (#2084) + - Add a configuration knob to enable/disable loading of gambling list (#2047) + - Add a new flow risk about literal IP addresses used as SNI (#1892) + - Add an heuristic to detect/ignore some anomalous TCP ACK packets (#1948) + - Add another example of custom rules (#1923) + - Add support for multiline json + - Add support for roaring_bitmap_xor_inplace (#1983) + - Add support for vxlan decapsulation (#1441) (#1900) + - Added Source Engine dissector. (#1937) + - Added `lists/gambling.list` to extra dist. + - Added `slackb.com` SNI. (#2067) + - Added ability to define an unlimited number of custom rules IP:port for the same IP (it used tobe limited to 2) + - Added check to avoid skype heuristic false positives + - Added comment + - Added coverage targets to `Makefile.am` for convenience. (#2039) + - Added fix for better handling exceptions rollback in case of later match + - Added hyperlink + - Added ndpi_binary_bitmap data structure + - Added ndpi_bitmap64 support + - Added ndpi_bitmap_andnot API call + - Added ndpi_bitmap_copy() API call + - Added ndpi_bitmap_is_empty() and ndpi_bitmap_optimize() API calls + - Added ndpi_domain_classify_XXX(0 API + - Added ndpi_filter_add_multi() API call + - Added ndpi_murmur_hash to the nDPI API + - Added new API calls for implementing Bloom-filter like data structures + - Added printf/fprintf replacement for some internal modules. (#1974) + - Added scripts to auto generate hostname/SNI *.inc files. (#1984) + - Added sub-domain classification fix + - Added the ability to define custom protocols with arbitrary Ids in proto.txt + - Added vlan_id in ndpi_flow2json() prototype + - Adds new pcap for testing "funny" HTTP servers + - All protocols should be excluded sooner or later (#1969) + - Allow init of app protocols w/o any hostnames set. (#2057) + - Avoid calling `ndpi_reconcile_protocols()` twice in `ndpi_detection_giveup()` (#1996) + - Boundary check + - CI: fix `Performance` job (#1936) + - Centos7 fixes + - Changed logging callback function sig. (#2000) + - Changes for supporting more efficient sub-string matching + - Classification fixes + - DNS: extract geolocation information, if available (#2065) + - Debian 12 fixes + - Disabled query string validation in MDNS in order to avoid zapping chars that in DNS (instead) are not permitted + - DisneyPlus/Hulu ip lists should be auto-generated (#1905) + - Extend content list of Microsoft protocols (#1930) + - Extend content-match list (#1967) + - Fix LRU/Patricia/Automa stats in `ndpiReader` with multiple threads (#1934) + - Fix MS Teams detection with heuristic (#1972) + - Fix access to packet/flow information (#2013) + - Fix an heap-buffer-overflow (#1994) + - Fix classification-by-ip in `ndpi_detection_giveup` (#1981) + - Fix compilation (#2011) + - Fix compilation in CI jobs (#2048) + - Fix compilation on Windows (#2072) + - Fix compilation with GCC-7 and latest RoaringBitmap code (#1886) + - Fix detection of packet direction and NDPI_UNIDIRECTIONAL_TRAFFIC risk (#1883) + - Fix export/serialization of `flow->risk` (#1885) + - Fix for buffer overflow in serialization + - Fix insert of ip addresses into patricia tree(s) (#1895) + - Fix missing u_char, u_short and u_int typedefs for some platforms e.g.: (#2009) + - Fix packet counters (#1884) + - Fix some errors found by fuzzers (#2078) + - Fix some memory errors triggered by allocation failures (#1995) + - Fix some prototypes (#2085) + - Fix string truncation. (#2056) + - Fixed OpenWRT arm related build issues. (#2104) + - Fixed heap-buffer-overflow issue + - Fixed heap-overflow if compiled with `--enable-tls-sigs`. (#2038) + - Fixed invalid use of ndpi_free(). Sorry, my fault. (#1988) + - Fixed missing AS_HELP_STRING in configure.ac. (#1893) + - Fixed two OpenWRT arm related build issues. (#2103) + - Fixes matches with domain name strings that start with a dot + - Fixes risk mask exception handling while improving the overall performance + - Implemented Count-Min Sketch [count how many times a value has been observed] + - Implemented Zoom/Teams stream type detection + - Implemented ndpi_XXX_reset() API calls whre XXX is ses, des, hw + - Implemented ndpi_predict_linear() for predicting a timeseries value overtime + - Improved debug output. (#1951) + - Improved invalid logging via printf(). + - Improved line protocol dissection with heuristic + - Improved missing usage of nDPIs malloc wrapper. Fixes #1978. (#1979) + - Improved protocol detection exploiting IP-based guess Reworked ndpi_reconcile_protocols() that is now called only in front of a match (less overhead) + - Improvement for reducing false positives + - Included Gambling website data from the Polish `hazard.mf.gov.pl` list (#2041) + - Keep master protocol in `ndpi_reconcile_protocols` + - Leak fix + - Language fix + - Line: fix heap-buffer-overflow error (#2015) + - Made VK protocol detection more strict + - Make Bittorrent LRU cache IPv6 aware. (#1909) + - Merged new and old version of ndpi_domain_classify.c code + - Mullvad VPN service added (based on entry node IP addresses) (#2062) + - Numeric truncation at `ndpi_analyze.c` at lines 101, 104, 107, 110 (#1999) + - Numeric truncation at `tls.c:1010` (#2005) + - Ookla: rework detection (#1922) + - Optimizes and fixes possible out0of0boundary write in ndpi_fill_prefix_v4() + - ProtonVPN: split the ip list (#2060) + - QUIC: add support for QUIC version 2 + - QUIC: export QUIC version as metadata + - QUIC: fix a memory access error + - QUIC: fix dissection of packets forcing VN + - RDP: improve detection over UDP (#2043) + - RTP: remove dead-code (#1953) + - RTP: rework code (#2021) + - Refreshed ASN lists Enhanced the Line IP list with https://ipinfo.io/AS23576/125.209.252.0/24 used by line + - Remove some useless checks (#1993) + - Remove special handling of some TCP flows without SYN (#1965) + - Removed overlapping port + - Renamed HTTP/2 to HTTP2 as the '/' can have side effects with applications sitting on top of nDPI + - Replaces free() with ndpi_free() + - Rework CI jobs to try reducing CI duration (#1903) + - Reworked domain classification based on binary filters + - Reworked initialization + - Reworked ndpi_filter_xxx implementation using compressed bitmaps + - Reworked teams handling + - RiotGames: add detection of flows (#1935) + - STUN: add dissection of DTLS handshake (#2018) + - STUN: avoid FacebookVoip false positives (#2029) + - STUN: fix Skype/MsTeams detection and monitoring logic (#2028) + - STUN: fix detection of Google Voip apps (#2031) + - STUN: fix detection over TCP + - STUN: improve WhatsappCall detection + - STUN: keep monitoring/processing STUN flows (#2012) + - STUN: tell RTP from RTCP while in monitoring state (#2027) + - Serialization fix + - Set _DEFAULT_SOURCE and _GNU_SOURCE globally. (#2010) + - Simplify `ndpi_internal_guess_undetected_protocol()` (#1941) + - Simplify the report of streaming multimedia info (#2026) + - SoftEther: fix invalid memory access + - Swap from Aho-Corasick to an experimental/home-grown algorithm that uses a probabilistic approach for handling Internet domain names. + - Sync unit tests results + - Sync unit tests results + - Sync unit tests results (#1962) + - Sync utests results (#1887) + - TLS: add basic, basic, detection of Encrypted ClientHello (#2053) + - TLS: fix another interger overflow in certificate processing (#1915) + - TLS: fix parsing of certificate elements (#1910) + - Test files for riit games + - Test multiple `ndpiReader` configurations (#1931) + - Thrift: fix heap-buffer-overflow (#2024) + - Update GitHub runners versions (#1889) + - Update every ip lists (#2079) + - Update libinjection code (#1918) + - Update protocols documentation (#2081) + - Update roaring bitmap code + - Updated line test result + - Updated pcap detection results after Facebook Reel/Stories support + - Updated results + - Updated results after the latest changes + - Win include change + - Windows code rework + - Windows compilation fixes + - Windows warning checks + - add 2 ns from fdn.fr to DoH section (#1964) + - add support for gre decapsulation (#1442) (#1921) + - added bimap and/or with allocation + - added feature to extract filename from http attachment (#2037) + - added new domain names (#2002) + - configure: add an option to enable debug build, i.e `-g` (#1929) + - fix Stack overflow caused by invalid write in ndpi_automa_match_strin… (#2035) + - fixed numeric truncation error + - fixed numeric truncation error in diameter.c (#2034) + - fixed numeric truncation error in kerberos.c (#2032) + - fixed numeric truncation error in ndpi_main.c:6837 (#1998) + - fixed numeric truncation error in rtcp.c (#2033) + - fuzz: add a new fuzzer to test TLS certificates (#1901) + - fuzz: add a new fuzzer triggering the payload analyzer function(s) (#1926) + - fuzz: add fuzzer for DGA detection code (#2042) + - fuzz: add fuzzer to test internal gcrypt code (#1920) + - fuzz: add fuzzers to test bitmap64 and domain_classify data structures (#2082) + - fuzz: add fuzzers to test reader_util code (#2080) + - fuzz: extend coverage (#2073) + - fuzz: extend fuzz coverage (#1888) + - fuzz: extend fuzzers coverage (#1952) + - fuzz: extend fuzzing coverage (#2040) + - fuzz: extend fuzzing coverage (#2052) + - fuzz: extend fuzzing coverage (#2083) + - fuzz: simplify fuzzers dependencies in CIFuzz (#1896) + - fuzz: some improvements and add two new fuzzers (#1881) + - fuzzing: extend fuzzing coverage + - in case of failure, failing result files are not listed + - minor fixes (#2023) + - oss-fuzz: sync build script with upstream + - remove redefinition to vxlanhdr struct in vxlan dissector (#1911) + - removed useless call of ndpi_set_risk func (#2022) + - tests: add an option to force the overwrite of the unit tests results (#2001) + - tests: restore some old paths as symbolic links (#2050) + - tftp: check for Option Acknowledgements + - tftp: check incrementation for DATA and ACK packets + - tftp: rework request checking to account for options + - tftp: update pcap results + - version of dirent.c that is liked by both VC++ and MinGW + + #### nDPI 4.6 (Feb 2023) ## New Features