Find a file
Ivan Nardi afc2b641eb
Fix writes to flow->protos union fields (#1354)
We can write to `flow->protos` only after a proper classification.

This issue has been found in Kerberos, DHCP, HTTP, STUN, IMO, FTP,
SMTP, IMAP and POP code.
There are two kinds of fixes:
 * write to `flow->protos` only if a final protocol has been detected
 * move protocol state out of `flow->protos`
The hard part is to find, for each protocol, the right tradeoff between
memory usage and code complexity.

Handle Kerberos like DNS: if we find a request, we set the protocol
and an extra callback to further parsing the reply.

For all the other protocols, move the state out of `flow->protos`. This
is an issue only for the FTP/MAIL stuff.

Add DHCP Class Identification value to the output of ndpiReader and to
the Jason serialization.

Extend code coverage of fuzz tests.

Close #1343
Close #1342
2021-11-15 16:20:57 +01:00
.github TLS: fix two warnings (#1365) 2021-11-02 22:08:15 +01:00
.lgtm/cpp-queries ql query to identify suspicious use of network sourced integers 2020-04-02 17:14:49 -04:00
doc Detect invalid characters in text and set a risk. Fixes #1347. (#1363) 2021-10-26 21:34:01 +02:00
example Fix writes to flow->protos union fields (#1354) 2021-11-15 16:20:57 +01:00
fuzz Fix writes to flow->protos union fields (#1354) 2021-11-15 16:20:57 +01:00
m4 Allow -fsanitize for LLVM as well as for GCC. 2020-06-23 00:22:33 +02:00
packages Additional fix related to cf931fda6b. (#1332) 2021-10-10 14:14:02 +02:00
python Fix writes to flow->protos union fields (#1354) 2021-11-15 16:20:57 +01:00
src Fix writes to flow->protos union fields (#1354) 2021-11-15 16:20:57 +01:00
tests Fix writes to flow->protos union fields (#1354) 2021-11-15 16:20:57 +01:00
utils Added bootstrap ethereum nodes 2020-01-08 22:44:30 +01:00
windows Fixed Mingw64 build, SonerCloud-CI and more. (#1273) 2021-08-18 11:34:16 +02:00
wireshark Detect invalid characters in text and set a risk. Fixes #1347. (#1363) 2021-10-26 21:34:01 +02:00
.gitattributes Add .gitattributes 2019-12-16 01:09:09 +01:00
.gitignore Fix QUIC log and remove SoulSeek leftovers after b97dc6ba (#1351) 2021-10-19 21:42:55 +02:00
autogen.sh Get rid of configure.seed as it comes with some disadvantages. (#1328) 2021-10-10 13:13:52 +02:00
CHANGELOG.md Update changelog 2021-07-24 17:54:32 +02:00
configure.ac Get rid of configure.seed as it comes with some disadvantages. (#1328) 2021-10-10 13:13:52 +02:00
CONTRIBUTING.md Create CONTRIBUTING.md 2019-07-23 10:47:25 +01:00
COPYING Initial import from SVN 2015-04-19 07:25:59 +02:00
INSTALL Initial import from SVN 2015-04-19 07:25:59 +02:00
libndpi.pc.in Fixed broken pkg-config file which did not care about gcrypt/pcre. 2020-08-24 18:12:49 +02:00
Makefile.am Removed README.protocols because: (#1333) 2021-10-11 23:07:36 +02:00
README.md Improve CI (#1303) 2021-09-22 12:10:52 +02:00
README.nDPI Added QUIC dependency 2020-08-22 17:02:11 +02:00
sonar-project.properties Changes for sonarcloud integration 2021-05-11 21:36:25 +02:00

ntop ntop

nDPI

Build Status Code Quality: Cpp Total Alerts Fuzzing Status

What is nDPI ?

nDPI® is an open source LGPLv3 library for deep-packet inspection. Based on OpenDPI it includes ntop extensions. We have tried to push them into the OpenDPI source tree but nobody answered emails so we have decided to create our own source tree

How To Compile nDPI

In order to compile this library do

  • ./autogen.sh
  • ./configure
  • make

To run tests do additionally:

  • cd tests; ./do.sh

Please note that the pre-requisites for compilation include:

  • GNU tools (autogen, automake, autoconf, libtool)
  • GNU C compiler (gcc)

On Debian/Ubuntu systems do:

  • sudo apt-get install build-essential git bison flex libpcap-dev libtool libtool-bin autoconf pkg-config automake autogen libjson-c-dev libnuma-dev libgcrypt20-dev libpcre2-dev

FreeBSD

  • sudo pkg install gcc git autoconf automake libtool devel/pkgconf json-c gmake

Remember to use gmake and not make on FreeBSD

How To Add A New Protocol Dissector

The entire procedure of adding new protocols in detail:

  1. Add new protocol together with its unique ID to: src/include/ndpi_protocol_ids.h
  2. Create a new protocol in: src/lib/protocols/
  3. Variables to be kept for the duration of the entire flow (as state variables) need to be placed in: src/include/ndpi_typedefs.h in ndpi_flow_tcp_struct (for TCP only), ndpi_flow_udp_struct (for UDP only), or ndpi_flow_struct (for both).
  4. Add a new entry for the search function for the new protocol in: src/include/ndpi_protocols.h
  5. Choose (do not change anything) a selection bitmask from: src/include/ndpi_define.h
  6. Add a new entry in ndpi_set_protocol_detection_bitmask2 in: src/lib/ndpi_main.c
  7. Set protocol default ports in ndpi_init_protocol_defaults in: src/lib/ndpi_main.c
  8. ./autogen.sh
  9. make
  10. make check

How to use nDPI to Block Selected Traffic

You can use nDPI to selectively block selected Internet traffic by embedding it onto an application (remember that nDPI is just a library). Both ntopng and nProbe cento can do this.

nDPI Paper Citation

DISCLAIMER

While we do our best to detect network protocols, we cannot guarantee that our software is error free and 100% accurate in protocol detection. Please make sure that you respect the privacy of users and you have proper authorization to listen, capture and inspect network traffic.

nDPI is a registered trademark in the US and EU.