Toni Uhlig
5e313f43f9
Small CI/CD/nDPIsrvd.py improvements.
...
* Updated examples/js-rt-analyzer and examples/js-rt-analyzer-frontend
Signed-off-by: Toni Uhlig <matzeton@googlemail.com >
2023-01-17 21:01:47 +01:00
Toni Uhlig
a3d20c17d1
Improved collectd risk processing to be in sync with libnDPI risks.
...
Signed-off-by: Toni Uhlig <matzeton@googlemail.com >
2023-01-11 06:28:10 +01:00
Toni Uhlig
470ed99eaf
Added https://gitlab.com/verzulli/ndpid-rt-analyzer-frontend.git example.
...
Signed-off-by: Toni Uhlig <matzeton@googlemail.com >
2023-01-11 06:13:51 +01:00
Toni Uhlig
655393e953
nDPid: Fixed base64encode bug which lead to invalid base64 strings.
...
* py-semantic-validation: Decode base64 raw packet data as well
* nDPIsrvd.py: Added PACKETS_PLEN_MAX
* nDPIsrvd.py: Improved JSON parse error/exception handling
Signed-off-by: Toni Uhlig <matzeton@googlemail.com >
2023-01-09 01:43:24 +01:00
Toni Uhlig
4e19ab929c
py-machine-learning / sklearn-random-forest: Quality Of Life improvments
...
* fixed libnDPI submodule build on some platforms
Signed-off-by: Toni Uhlig <matzeton@googlemail.com >
2022-12-22 22:13:08 +01:00
Toni Uhlig
c5930e3510
Add collectd statistics diff test.
...
Signed-off-by: Toni Uhlig <matzeton@googlemail.com >
2022-12-06 19:51:53 +01:00
Toni Uhlig
ced5f5d4b4
py-flow-info: ignore certain json lines that match various criteria
...
Signed-off-by: Toni Uhlig <matzeton@googlemail.com >
2022-12-03 01:23:26 +01:00
Toni Uhlig
9b78939096
Updated README's.
...
Signed-off-by: Toni Uhlig <matzeton@googlemail.com >
2022-11-20 22:25:18 +01:00
Toni Uhlig
57c5d8532b
Test for diff's in flow-analyse CSV generator daemon.
...
Signed-off-by: Toni Uhlig <matzeton@googlemail.com >
2022-11-16 23:06:37 +01:00
Toni Uhlig
36e428fc89
Sync unit tests.
...
Signed-off-by: Toni Uhlig <matzeton@googlemail.com >
2022-11-13 16:19:07 +01:00
Toni Uhlig
ea1698504c
nDPIsrvd: Provide workaround for change user/group.
...
* nDPId/nDPIsrvd/c-examples: Parameter parsing needs to be improved
if `strdup()` in combination with static strings is used.
* Other non-critical fixes.
Signed-off-by: Toni Uhlig <matzeton@googlemail.com >
2022-11-13 11:21:55 +01:00
Toni Uhlig
e629dd59cd
nDPIsrvd.h: Provide two additional convenient API functions.
...
* nDPIsrvd_json_buffer_string
* nDPIsrvd_json_buffer_length
Signed-off-by: Toni Uhlig <matzeton@googlemail.com >
2022-11-06 13:19:29 +01:00
Toni Uhlig
25f4ef74ac
Improved examples.
...
Signed-off-by: Toni Uhlig <matzeton@googlemail.com >
2022-11-02 00:01:57 +01:00
Toni Uhlig
d55e397929
bump libnDPI to db9f6ec1b4018164e5bff05f115dc60711bb711b
...
Signed-off-by: Toni Uhlig <matzeton@googlemail.com >
2022-10-31 13:53:02 +01:00
Toni Uhlig
c63cbec26d
Improved nDPIsrvd-collectd statistics.
...
* Improved RRD-Graph generation script and static WWW html files.
Signed-off-by: Toni Uhlig <matzeton@googlemail.com >
2022-10-31 12:45:15 +01:00
Toni Uhlig
805aef5de8
Increased network buffer size to 33792 bytes.
...
Signed-off-by: Toni Uhlig <matzeton@googlemail.com >
2022-10-30 22:13:07 +01:00
Toni Uhlig
2d14509f04
nDPid-test: add buffer test
...
Signed-off-by: Toni Uhlig <matzeton@googlemail.com >
2022-10-30 20:12:17 +01:00
Toni Uhlig
49352698a0
nDPId: Added error event threshold to prevent event spamming which may be abused.
...
Signed-off-by: Toni Uhlig <matzeton@googlemail.com >
2022-10-17 06:36:30 +02:00
Toni Uhlig
6292102f93
py-machine-learning: load and save trained models
...
* added link to a pre-trained model
Signed-off-by: Toni Uhlig <matzeton@googlemail.com >
2022-10-15 11:59:39 +02:00
Toni Uhlig
80f8448834
Removed discontinued examples from the ReadMe.
...
Signed-off-by: Toni Uhlig <matzeton@googlemail.com >
2022-10-13 16:47:03 +02:00
Toni Uhlig
9bf4f31418
Removed example py-ja3-checker.
...
* renamed sklearn-ml.py to sklearn-random-forest.py (there is more to come!)
* force all protocol classes to lower case
Signed-off-by: Toni Uhlig <matzeton@googlemail.com >
2022-10-13 00:12:22 +02:00
Toni Uhlig
4069816d69
Improved py-machine-learning example.
...
* colorize/prettify output
* added sklearn controls/tuning options
* disable IAT/Packet-Length features as default
Signed-off-by: Toni Uhlig <matzeton@googlemail.com >
2022-10-11 20:20:01 +02:00
Toni Uhlig
20fc74f527
Improved py-machine-learning example.
...
Signed-off-by: Toni Uhlig <matzeton@googlemail.com >
2022-10-10 16:44:12 +02:00
Toni Uhlig
4654faf381
Improved py-machine-learning example.
...
* c-analysed: fixed quoting bug
* nDPId: fixed invalid iat storing/serialisation
* nDPId: free data analysis after event was sent
Signed-off-by: Toni Uhlig <matzeton@googlemail.com >
Signed-off-by: lns <matzeton@googlemail.com >
2022-10-09 18:31:45 +02:00
Toni Uhlig
b7a17d62c7
Improved OpenWrt UCI/Initscript
...
* c-analysed: chuser()/chgroup()
Signed-off-by: Toni Uhlig <matzeton@googlemail.com >
2022-10-06 06:54:01 +02:00
lns
49ea4f8474
Small fixes.
...
Signed-off-by: lns <matzeton@googlemail.com >
2022-10-01 22:37:25 +02:00
Toni Uhlig
b6060b897e
c-analysed: improved feature extraction from "analyse" events
...
* c-captured: update detected risks on "detection-update" events
* c-collectd: added missing flow breed
* c-collectd: PUTVAL macros are more flexible now
Signed-off-by: Toni Uhlig <matzeton@googlemail.com >
2022-10-01 18:01:56 +02:00
Toni Uhlig
14f6b87551
Added nDPIsrvd-analysed to generate CSV files from analyse events.
...
* nDPIsrvd.h: iterate over JSON arrays
* nDPId: calculate l3 payload packet entropies for analysis
Signed-off-by: Toni Uhlig <matzeton@googlemail.com >
2022-09-30 19:28:49 +02:00
Toni Uhlig
74f71643da
nDPId-test: Force collector blocking mode.
...
Signed-off-by: Toni Uhlig <matzeton@googlemail.com >
2022-09-25 16:24:05 +02:00
Toni Uhlig
2103ee0811
Refactored client distributor C API.
...
* Still not perfect, but the code before was not even able to deal with JSON arrays.
Use common "speaking" function names for all functions in nDPIsrvd.h
* Provide a more or less generic and easy extendable JSON walk function.
* Modified C examples to align with the changed C API.
* c-collectd: Reduced lot's of code duplication by providing mapping tables.
* nDPId: IAT array requires one slot less (first packet has always an IAT of 0).
Signed-off-by: Toni Uhlig <matzeton@googlemail.com >
2022-09-25 00:54:39 +02:00
Toni Uhlig
36f1786bde
nDPIsrvd.h: Fixed bug during token parsing/hashing. Do not hash array contents.
...
Signed-off-by: Toni Uhlig <matzeton@googlemail.com >
2022-09-23 00:13:19 +02:00
Toni Uhlig
9a28475bba
Improved flown analyse event:
...
* store packet directions
* merged direction based IATs
* merged direction based PKTLENs
Signed-off-by: Toni Uhlig <matzeton@googlemail.com >
2022-09-22 19:07:08 +02:00
Toni Uhlig
28971cd764
flow-info.py: Command line arguments --no-color, --no-statusbar (both useful for tests/CI) and --print-analyse-results.
...
* run_tests.sh: Use flow-info.py for additional DIFF tests.
Signed-off-by: Toni Uhlig <matzeton@googlemail.com >
2022-09-22 08:00:21 +02:00
Toni Uhlig
08f263e409
nDPId: Reduced flow-updates for TCP flows to 1/4 of the timeout value.
...
* nDPId: Fixed broken validation tests.
* nDPId: Removed TICK_RESOLUTION, not required anymore.
* c-collectd: Improved total layer4 payload calculation/update handling.
* c-collectd: Updated RRD Graph script according to total layer4 payload changes.
* py-flow-info.py: Fixed several bugs and syntax errors.
* Python scripts: Added dirname(argv[0]) as search path for nDPIsrvd.py.
* nDPIsrvd&nDPId-test: Fixed missing EPOLLERR check.
Signed-off-by: Toni Uhlig <matzeton@googlemail.com >
2022-09-19 19:39:49 +02:00
Toni Uhlig
d4633c1192
New flow event: 'analysis'.
...
* The goal was to provide a separate event for extracted feature that are not required
and only useful for a few (e.g. someone who wants do ML).
* Increased network buffer size to 32kB (8192 * 4).
* Switched timestamp precision from ms to us for *ALL* timestamps.
Signed-off-by: Toni Uhlig <matzeton@googlemail.com >
2022-09-13 22:05:08 +02:00
Toni Uhlig
94aa02b298
nDPIsrvd-collectd: Stdout should be unbuffered.
...
Signed-off-by: Toni Uhlig <matzeton@googlemail.com >
2022-09-12 13:32:50 +02:00
Toni Uhlig
20ced3e636
nDPIsrvd-collectd: RRD Graph generation script and a basic static HTML5 website for viewing the generated image files.
...
Signed-off-by: Toni Uhlig <matzeton@googlemail.com >
2022-09-12 13:23:50 +02:00
Toni Uhlig
c5c7d83c97
Added https://gitlab.com/verzulli/ndpid-rt-analyzer.git to examples.
...
Signed-off-by: Toni Uhlig <matzeton@googlemail.com >
2022-09-06 11:08:01 +02:00
Toni Uhlig
dcf78ad3ed
Disable timestamp generation in nDPIsrvd-collectd as default.
...
* collectd's rrdtool write plugin does silently fail with those ones (dunno why)
Signed-off-by: Toni Uhlig <matzeton@googlemail.com >
2022-09-04 17:24:10 +02:00
Toni Uhlig
0fd59f060e
Split *_l4_payload_len' into *_src_l4_payload_len' and `*_dst_l4_payload_len'.
...
Signed-off-by: Toni Uhlig <matzeton@googlemail.com >
2022-08-15 22:55:19 +02:00
Toni Uhlig
2cb2c86cb5
c-collectd: fixed incorrect PUTVAL
...
* get rid of types.db
Signed-off-by: Toni Uhlig <matzeton@googlemail.com >
2022-08-15 16:42:59 +02:00
Damiano Verzulli
96b9129918
Improve README
...
- slightly improve the README to better enhance the streaming
capability of `nDPId`, regardless of `nDPIsrvd`
- add a screencast showing the install step and the
`nDPId` usage, alone (with ncat as unix-socket listener)
- add "build" to .gitignore
2022-08-12 11:10:45 +02:00
Toni Uhlig
fc442180da
c-collectd: fixed possible undefined behavior
...
Signed-off-by: Toni Uhlig <matzeton@googlemail.com >
2022-07-14 03:48:57 +02:00
Toni Uhlig
28602ca095
README update
...
Signed-off-by: Toni Uhlig <matzeton@googlemail.com >
2022-07-12 16:03:51 +02:00
lns
cdaeb1632e
py-flow-dashboard: Improved graph axis scaling.
...
Signed-off-by: lns <matzeton@googlemail.com >
2022-06-16 11:37:33 +02:00
lns
2a8883a96e
CMake: do not add /usr/include/ndpi to include dirs if BUILD_NDPI or STATIC_LIBNDPI_INSTALLDIR used.
...
* c-collectd: fixed memory leak on failure
* py-flow-info.py: fancy spinners and stats counting improved
Signed-off-by: lns <matzeton@googlemail.com >
2022-06-10 14:34:30 +02:00
Toni Uhlig
664a8a077d
Merge branch 'master' of github.com:lnslbrty/nDPId
2022-06-07 18:01:40 +02:00
Toni Uhlig
77a87254b6
nDPIsrvd.py: Throw SocketTimeout Exception to catch both timeout exceptions different Python versions can throw.
...
Signed-off-by: Toni Uhlig <matzeton@googlemail.com >
2022-06-07 17:59:47 +02:00
lns
f5b0021413
README update
...
Signed-off-by: lns <matzeton@googlemail.com >
2022-05-31 23:57:22 +02:00
lns
4fde63b5c2
Small fixes.
...
Signed-off-by: lns <matzeton@googlemail.com >
2022-04-26 11:44:31 +02:00