Commit graph

164 commits

Author SHA1 Message Date
Alfredo Cardigliano
6991858b99 Do not compile CH on community only 2025-11-28 10:47:15 +01:00
Luca Deri
92fb3e2c3a Implemented clickhouse-cpp caching 2025-11-04 19:13:56 +01:00
Alfredo Cardigliano
bdbb5b95d7 Build clickhouse-cpp with SSL support (required by ClickHouse Cloud) 2025-10-14 12:00:26 +02:00
Luca Deri
b44092959a Fixed platform detection 2025-10-02 11:47:42 +02:00
Luca Deri
b12ce08ab4 Added comment 2025-07-25 09:45:04 +02:00
Alfredo Cardigliano
3873920bea Remove mysql/maria dependencies. Update docs. 2025-06-09 16:50:09 +02:00
Alfredo Cardigliano
6f9d7cd14f Major code rework to fully use the clickhouse API in place of Mysql 2025-06-09 15:33:57 +02:00
Luca Deri
7920590bd9 Enabled native clockhouse support for non Linux distributions 2025-06-04 16:45:03 +02:00
Matteo Biscosi
4e31f600f6 Revert "Added Vite to frontend builds"
This reverts commit 2b5d2d7949.
2025-05-22 15:32:21 +02:00
Matteo Biscosi
2b5d2d7949 Added Vite to frontend builds 2025-05-22 13:09:57 +02:00
Alfredo Cardigliano
6fd4975f09 Enable clickhouse-cpp on linux only 2025-05-16 12:38:10 +02:00
Alfredo Cardigliano
be61782f57 Move clickhouse-cpp compilation to Makefile 2025-05-16 11:37:34 +02:00
Alfredo Cardigliano
bb810adeff Add native clickhouse support for queries 2025-05-16 11:14:18 +02:00
Luca Deri
896315e568 Updated make-dist target 2024-08-26 11:12:33 +02:00
Luca Deri
6f25bda2d8 Removed comment 2024-08-26 11:05:41 +02:00
Luca Deri
243a01870a Modified dist-ntopng 2024-08-26 10:59:06 +02:00
Luca Deri
3dfe6f4413 Reworked resolv librayr 2024-04-03 09:06:20 +02:00
Luca Deri
c739506f31 Added -lresolv dependency 2024-04-02 15:54:24 +02:00
Luca Deri
872e02dc5b Added JE malloc support 2024-02-18 07:53:19 +01:00
Luca
c961b4f45f Updated LuaEngine version 2024-02-12 11:26:45 +01:00
Luca Deri
051b76577b Reworked dependencies 2024-01-16 08:22:18 +01:00
Luca Deri
b54a0a2dc2 Compliation fix after https://github.com/ntop/ntopng/pull/7430 2023-05-02 16:13:25 +02:00
Riccardo Mori
151a047760
Add first fuzzing harness (#7430)
* First sketch of fuzzing

* Add m4 script

The script is used in the fuzzing build

* Add stub sources in the makefile

* [Fuzz] Add RedisStub

* Add gitignore for fuzz dir

* Remove definition of non-implemented method

* [Fuzz] Refactoring code

* [Fuzz] Separate the protobuf support in the makefile

* Clean fuzzing related object files

* [Fuzz] Fix makefile

* Change gitignore

* [Fuzz] Separate headers

* [Fuzz] Add README.md

* [Fuzz] Change make target

* [Fuzz] Update README.md

* Add compatibilty with autoconf < 2.71

* Optionally disable hiredis integration

* Include hiredis only for production build

* [Fuzz] Disable period activities

* Remove unused dependencies for librrd

* Optionally use static linking for zmq library

* Add debug output regarding the linking of libzmq

* [Fuzz] Do not run on empty input

* Optionally use static linking for libjson-c

* Optionally use static linking for libmaxminddb

* Make mysqlclient dependency as optional

* Change gitignore

* [Fuzz] Add corpus for fuzz_dissect_packet

* [Fuzz] Refactor fuzz_dissect_packet

* Change gitignore

* [Fuzz] Use correct naming for corpus

* [Fuzz] Add dictionary

* [Fuzz] Fix declaration of LLVMFuzzerInitialize

* [Fuzz] Refactor onefile

* [Fuzz] Fix the initialization memory leaks

* [Fuzz] Fix invocation of LLVMFuzzerInitialize

* Remove double githooks folder

* [Fuzz] Set interface pcap_data_link

* Change gitignore

* Use pkg-config for detecting protobuf libraries

* Add license

* Improve error message
2023-05-02 16:06:52 +02:00
Riccardo Mori
a87a6e3b8c
Switch code formatter from auto-commit to pre-commit hook (#7386)
* Add pre-commit check for the code formatter

* Remove code formatter CI

* Fix mtime in fast-format command
2023-04-11 15:08:29 +02:00
Luca Deri
835bec8dc6 Added 'format' target for formattign code prior committing it 2023-04-10 09:43:43 +02:00
Alfredo Cardigliano
4f8ec39cd6 Add make dist-ntopng to build ntopng-related dist only 2023-03-14 15:34:48 +01:00
Alfredo Cardigliano
c3331e3b61 Rename make disto to make windows. Add make dist (and dev-dist) to build http dist. 2023-02-06 16:03:27 +01:00
Luca Deri
86f1e60850 clang changes 2022-12-22 11:36:53 +01:00
Luca
7f5a901442 Updated pull target 2022-08-25 17:33:49 +02:00
Luca
0392b65a9e Added pull target for git code update 2022-08-25 15:27:26 +02:00
ouliuquan
ea729d81eb
Upgrade C++ standard to C++1y standard (#6522)
This option works on CentOS 7 (GCC 4.8) and above, other Linux OSes have been upgraded to higher GCC, so CentOS 7 needs to be considered, C++1y (before C++14) is what it can do.
The point for advanced versions of C++ is that we can use a lot of libraries. There are currently a lot of libraries that need to be basically C++11.
2022-04-22 16:55:34 +02:00
MatteoBiscosi
885b3849fb Added makefile targets and added dist to gitignore 2022-04-15 17:23:41 +02:00
Luca Deri
700ffd5d22 Reworked hiredis dependency 2022-04-11 20:48:45 +02:00
Alfredo Cardigliano
0cde86f7ee Cleanup makefile 2022-03-04 18:14:43 +01:00
Giorgio Zoppi
4b8c005abb adding address resolution test
modified:   Makefile.in
	modified:   include/AddressResolution.h
	modified:   include/Ntop.h
	modified:   src/AddressResolution.cpp
	modified:   tests/include/AddressResolutionTest.h
	modified:   tests/src/AddressResolutionTest.cpp
	modified:   tests/src/gtest.cpp
2022-02-05 18:11:46 +01:00
Giorgio Zoppi
eb8587f557 Adding address resolution and reorganizing the tests directory
modified:   Makefile.in
2022-02-05 01:59:33 +01:00
Giorgio Zoppi
86809a2bc7 AddedAddressResolutionTest
modified:   ../Makefile.in
	deleted:    gtest.c
	new file:   include/AddressResolutionTest.h
	deleted:    lua/test_alert_exclusions.lua
	deleted:    lua/test_alert_store.lua
	deleted:    lua/test_alerts.lua
	deleted:    lua/test_control_groups.lua
	deleted:    lua/test_delete_nindex.lua
	deleted:    lua/test_gui_widgets.lua
	deleted:    lua/test_locales.lua
	deleted:    lua/test_notification_endpoints.lua
	deleted:    lua/test_pools.lua
	deleted:    lua/test_recipients.lua
	deleted:    lua/test_widgets.lua
	deleted:    rest/README
	deleted:    rest/conflicts/README
	deleted:    rest/conflicts/v1/.placeholder
	deleted:    rest/conflicts/v2/.placeholder
	deleted:    rest/logs/README
	deleted:    rest/logs/v1/.placeholder
	deleted:    rest/logs/v2/.placeholder
	deleted:    rest/pcap/bad-dns-traffic.pcap
	deleted:    rest/pcap/bcast_domains.pcap
	deleted:    rest/pcap/bitcoin.pcap
	deleted:    rest/pcap/dns_contacts.pcap
	deleted:    rest/pcap/invalid_dns_query.pcap
	deleted:    rest/pcap/malformed_dns.pcap
	deleted:    rest/pcap/malware.pcap
	deleted:    rest/pcap/ntp_contacts.pcap
	deleted:    rest/pcap/selfsigned.pcap
	deleted:    rest/pcap/ssh_notwh_rw.pcap
	deleted:    rest/pcap/ssh_notwh_rw_02.pcap
	deleted:    rest/pcap/synscan.pcap
	deleted:    rest/pcap/tcp_probing.pcap
	deleted:    rest/pcap/test_01.pcap
	deleted:    rest/pcap/test_02.pcap
	deleted:    rest/pcap/tls_cert_expired.pcap
	deleted:    rest/pcap/tls_cipher_suites.pcap
	deleted:    rest/pcap/tls_nosyn.pcap
	deleted:    rest/pcap/tor.pcap
	deleted:    rest/pcap/unknown_issuer.pcap
	deleted:    rest/pcap/web_attack_01.pcap
	deleted:    rest/result/v1/alert_dns_data_exfiltration_01.out
	deleted:    rest/result/v1/alert_dns_data_exfiltration_02.out
	deleted:    rest/result/v1/alert_flow_exclusion_lists.out
	deleted:    rest/result/v1/alert_flow_invalid_dns_query_02.out
	deleted:    rest/result/v1/alert_flow_invalid_dns_query_disabled.out
	deleted:    rest/result/v1/alert_flow_risk_dga_01.out
	deleted:    rest/result/v1/alert_flow_risk_dga_02.out
	deleted:    rest/result/v1/alert_flow_risk_http_numeric_ip_host.out
	deleted:    rest/result/v1/alert_flow_risk_missing_tls_sni.out
	deleted:    rest/result/v1/alert_flow_risk_unsafe_protocol.out
	deleted:    rest/result/v1/alert_tls_certificate_expired.out
	deleted:    rest/result/v1/alert_tls_certificate_selfsigned.out
	deleted:    rest/result/v1/alert_web_mining.out
	deleted:    rest/result/v1/get_alert_data_01.out
	deleted:    rest/result/v1/get_alert_data_02.out
	deleted:    rest/result/v1/get_alert_type_consts_01.out
	deleted:    rest/result/v1/get_checks_config_01.out
	deleted:    rest/result/v1/get_flow_active_01.out
	deleted:    rest/result/v1/get_flow_l4_counters_01.out
	deleted:    rest/result/v1/get_flow_l7_counters_01.out
	deleted:    rest/result/v1/get_host_active_01.out
	deleted:    rest/result/v1/get_host_custom_data_01.out
	deleted:    rest/result/v1/get_host_custom_data_02.out
	deleted:    rest/result/v1/get_host_data_01.out
	deleted:    rest/result/v1/get_host_data_02.out
	deleted:    rest/result/v1/get_host_data_03.out
	deleted:    rest/result/v1/get_host_interfaces_01.out
	deleted:    rest/result/v1/get_host_l7_stats_01.out
	deleted:    rest/result/v1/get_host_l7_stats_02.out
	deleted:    rest/result/v1/get_host_mud_01.out
	deleted:    rest/result/v1/get_interface_address_01.out
	deleted:    rest/result/v1/get_interface_bcast_domains_01.out
	deleted:    rest/result/v1/get_interface_data_01.out
	deleted:    rest/result/v1/get_interface_l7_stats_01.out
	deleted:    rest/result/v1/get_interface_l7_stats_02.out
	deleted:    rest/result/v1/get_interface_l7_stats_03.out
	deleted:    rest/result/v1/get_interface_l7_stats_04.out
	deleted:    rest/result/v1/get_l4_protocol_consts.out
	deleted:    rest/result/v1/get_l7_application_consts_01.out
	deleted:    rest/result/v1/get_l7_category_consts_01.out
	deleted:    rest/result/v1/get_ntopng_interfaces_01.out
	deleted:    rest/result/v1/get_ntopng_users_01.out
	deleted:    rest/result/v1/get_pool_config_01.out
	deleted:    rest/result/v1/mac_alert_bcast_domains_01.out
	deleted:    rest/result/v1/peers_swap_heuristic_01.out
	deleted:    rest/result/v1/peers_swap_heuristic_02.out
	deleted:    rest/result/v1/set_host_alias_01.out
	deleted:    rest/result/v2/alert_dns_data_exfiltration_01.out
	deleted:    rest/result/v2/alert_dns_data_exfiltration_02.out
	deleted:    rest/result/v2/alert_flow_exclusion_lists.out
	deleted:    rest/result/v2/alert_flow_invalid_dns_query_02.out
	deleted:    rest/result/v2/alert_flow_invalid_dns_query_disabled.out
	deleted:    rest/result/v2/alert_flow_risk_dga_01.out
	deleted:    rest/result/v2/alert_flow_risk_dga_02.out
	deleted:    rest/result/v2/alert_flow_risk_http_numeric_ip_host.out
	deleted:    rest/result/v2/alert_flow_risk_missing_tls_sni.out
	deleted:    rest/result/v2/alert_flow_risk_unsafe_protocol.out
	deleted:    rest/result/v2/alert_host_synscan.out
	deleted:    rest/result/v2/alert_host_synscan_flows.out
	deleted:    rest/result/v2/alert_tls_cert_validity_too_long.out
	deleted:    rest/result/v2/alert_tls_certificate_expired.out
	deleted:    rest/result/v2/alert_tls_certificate_selfsigned.out
	deleted:    rest/result/v2/alert_web_mining.out
	deleted:    rest/result/v2/get_alert_data_01.out
	deleted:    rest/result/v2/get_alert_data_02.out
	deleted:    rest/result/v2/get_alert_severity_counters_01.out
	deleted:    rest/result/v2/get_alert_type_consts_01.out
	deleted:    rest/result/v2/get_alert_type_counters_01.out
	deleted:    rest/result/v2/get_checks_config_01.out
	deleted:    rest/result/v2/get_flow_active_01.out
	deleted:    rest/result/v2/get_flow_l4_counters_01.out
	deleted:    rest/result/v2/get_flow_l7_counters_01.out
	deleted:    rest/result/v2/get_host_active_01.out
	deleted:    rest/result/v2/get_host_custom_data_01.out
	deleted:    rest/result/v2/get_host_custom_data_02.out
	deleted:    rest/result/v2/get_host_data_01.out
	deleted:    rest/result/v2/get_host_data_02.out
	deleted:    rest/result/v2/get_host_data_03.out
	deleted:    rest/result/v2/get_host_interfaces_01.out
	deleted:    rest/result/v2/get_host_l7_stats_01.out
	deleted:    rest/result/v2/get_host_l7_stats_02.out
	deleted:    rest/result/v2/get_host_mud_01.out
	deleted:    rest/result/v2/get_interface_address_01.out
	deleted:    rest/result/v2/get_interface_bcast_domains_01.out
	deleted:    rest/result/v2/get_interface_data_01.out
	deleted:    rest/result/v2/get_interface_l7_stats_01.out
	deleted:    rest/result/v2/get_interface_l7_stats_02.out
	deleted:    rest/result/v2/get_interface_l7_stats_03.out
	deleted:    rest/result/v2/get_interface_l7_stats_04.out
	deleted:    rest/result/v2/get_l4_protocol_consts.out
	deleted:    rest/result/v2/get_l7_application_consts_01.out
	deleted:    rest/result/v2/get_l7_category_consts_01.out
	deleted:    rest/result/v2/get_ntopng_interfaces_01.out
	deleted:    rest/result/v2/get_ntopng_users_01.out
	deleted:    rest/result/v2/get_pool_config_01.out
	deleted:    rest/result/v2/mac_alert_bcast_domains_01.out
	deleted:    rest/result/v2/peers_swap_heuristic_01.out
	deleted:    rest/result/v2/peers_swap_heuristic_02.out
	deleted:    rest/result/v2/peers_swap_heuristic_03.out
	deleted:    rest/result/v2/set_host_alias_01.out
	deleted:    rest/run.sh
	deleted:    rest/tests/v1/alert_dns_data_exfiltration_01.yaml
	deleted:    rest/tests/v1/alert_dns_data_exfiltration_02.yaml
	deleted:    rest/tests/v1/alert_flow_exclusion_lists.yaml
	deleted:    rest/tests/v1/alert_flow_invalid_dns_query_02.yaml
	deleted:    rest/tests/v1/alert_flow_invalid_dns_query_disabled.yaml
	deleted:    rest/tests/v1/alert_flow_risk_dga_01.yaml
	deleted:    rest/tests/v1/alert_flow_risk_dga_02.yaml
	deleted:    rest/tests/v1/alert_flow_risk_http_numeric_ip_host.yaml
	deleted:    rest/tests/v1/alert_flow_risk_missing_tls_sni.yaml
	deleted:    rest/tests/v1/alert_flow_risk_unsafe_protocol.yaml
	deleted:    rest/tests/v1/alert_tls_certificate_expired.yaml
	deleted:    rest/tests/v1/alert_tls_certificate_selfsigned.yaml
	deleted:    rest/tests/v1/alert_web_mining.yaml
	deleted:    rest/tests/v1/get_alert_data_01.yaml
	deleted:    rest/tests/v1/get_alert_data_02.yaml
	deleted:    rest/tests/v1/get_alert_type_consts_01.yaml
	deleted:    rest/tests/v1/get_checks_config_01.yaml
	deleted:    rest/tests/v1/get_flow_active_01.yaml
	deleted:    rest/tests/v1/get_flow_l4_counters_01.yaml
	deleted:    rest/tests/v1/get_flow_l7_counters_01.yaml
	deleted:    rest/tests/v1/get_host_active_01.yaml
	deleted:    rest/tests/v1/get_host_custom_data_01.yaml
	deleted:    rest/tests/v1/get_host_custom_data_02.yaml
	deleted:    rest/tests/v1/get_host_data_01.yaml
	deleted:    rest/tests/v1/get_host_data_02.yaml
	deleted:    rest/tests/v1/get_host_data_03.yaml
	deleted:    rest/tests/v1/get_host_interfaces_01.yaml
	deleted:    rest/tests/v1/get_host_l7_stats_01.yaml
	deleted:    rest/tests/v1/get_host_l7_stats_02.yaml
	deleted:    rest/tests/v1/get_host_mud_01.yaml
	deleted:    rest/tests/v1/get_interface_address_01.yaml
	deleted:    rest/tests/v1/get_interface_bcast_domains_01.yaml
	deleted:    rest/tests/v1/get_interface_data_01.yaml
	deleted:    rest/tests/v1/get_interface_l7_stats_01.yaml
	deleted:    rest/tests/v1/get_interface_l7_stats_02.yaml
	deleted:    rest/tests/v1/get_interface_l7_stats_03.yaml
	deleted:    rest/tests/v1/get_interface_l7_stats_04.yaml
	deleted:    rest/tests/v1/get_l4_protocol_consts.yaml
	deleted:    rest/tests/v1/get_l7_application_consts_01.yaml
	deleted:    rest/tests/v1/get_l7_category_consts_01.yaml
	deleted:    rest/tests/v1/get_ntopng_interfaces_01.yaml
	deleted:    rest/tests/v1/get_ntopng_users_01.yaml
	deleted:    rest/tests/v1/get_pool_config_01.yaml
	deleted:    rest/tests/v1/mac_alert_bcast_domains_01.yaml
	deleted:    rest/tests/v1/peers_swap_heuristic_01.yaml
	deleted:    rest/tests/v1/peers_swap_heuristic_02.yaml
	deleted:    rest/tests/v1/set_host_alias_01.yaml
	deleted:    rest/tests/v2/alert_dns_data_exfiltration_01.yaml
	deleted:    rest/tests/v2/alert_dns_data_exfiltration_02.yaml
	deleted:    rest/tests/v2/alert_flow_exclusion_lists.yaml
	deleted:    rest/tests/v2/alert_flow_invalid_dns_query_02.yaml
	deleted:    rest/tests/v2/alert_flow_invalid_dns_query_disabled.yaml
	deleted:    rest/tests/v2/alert_flow_risk_dga_01.yaml
	deleted:    rest/tests/v2/alert_flow_risk_dga_02.yaml
	deleted:    rest/tests/v2/alert_flow_risk_http_numeric_ip_host.yaml
	deleted:    rest/tests/v2/alert_flow_risk_missing_tls_sni.yaml
	deleted:    rest/tests/v2/alert_flow_risk_unsafe_protocol.yaml
	deleted:    rest/tests/v2/alert_host_synscan.yaml
	deleted:    rest/tests/v2/alert_host_synscan_flows.yaml
	deleted:    rest/tests/v2/alert_tls_cert_validity_too_long.yaml
	deleted:    rest/tests/v2/alert_tls_certificate_expired.yaml
	deleted:    rest/tests/v2/alert_tls_certificate_selfsigned.yaml
	deleted:    rest/tests/v2/alert_web_mining.yaml
	deleted:    rest/tests/v2/get_alert_data_01.yaml
	deleted:    rest/tests/v2/get_alert_data_02.yaml
	deleted:    rest/tests/v2/get_alert_severity_counters_01.yaml
	deleted:    rest/tests/v2/get_alert_type_consts_01.yaml
	deleted:    rest/tests/v2/get_alert_type_counters_01.yaml
	deleted:    rest/tests/v2/get_checks_config_01.yaml
	deleted:    rest/tests/v2/get_flow_active_01.yaml
	deleted:    rest/tests/v2/get_flow_l4_counters_01.yaml
	deleted:    rest/tests/v2/get_flow_l7_counters_01.yaml
	deleted:    rest/tests/v2/get_host_active_01.yaml
	deleted:    rest/tests/v2/get_host_custom_data_01.yaml
	deleted:    rest/tests/v2/get_host_custom_data_02.yaml
	deleted:    rest/tests/v2/get_host_data_01.yaml
	deleted:    rest/tests/v2/get_host_data_02.yaml
	deleted:    rest/tests/v2/get_host_data_03.yaml
	deleted:    rest/tests/v2/get_host_interfaces_01.yaml
	deleted:    rest/tests/v2/get_host_l7_stats_01.yaml
	deleted:    rest/tests/v2/get_host_l7_stats_02.yaml
	deleted:    rest/tests/v2/get_host_mud_01.yaml
	deleted:    rest/tests/v2/get_interface_address_01.yaml
	deleted:    rest/tests/v2/get_interface_bcast_domains_01.yaml
	deleted:    rest/tests/v2/get_interface_data_01.yaml
	deleted:    rest/tests/v2/get_interface_l7_stats_01.yaml
	deleted:    rest/tests/v2/get_interface_l7_stats_02.yaml
	deleted:    rest/tests/v2/get_interface_l7_stats_03.yaml
	deleted:    rest/tests/v2/get_interface_l7_stats_04.yaml
	deleted:    rest/tests/v2/get_l4_protocol_consts.yaml
	deleted:    rest/tests/v2/get_l7_application_consts_01.yaml
	deleted:    rest/tests/v2/get_l7_category_consts_01.yaml
	deleted:    rest/tests/v2/get_ntopng_interfaces_01.yaml
	deleted:    rest/tests/v2/get_ntopng_users_01.yaml
	deleted:    rest/tests/v2/get_pool_config_01.yaml
	deleted:    rest/tests/v2/mac_alert_bcast_domains_01.yaml
	deleted:    rest/tests/v2/peers_swap_heuristic_01.yaml
	deleted:    rest/tests/v2/peers_swap_heuristic_02.yaml
	deleted:    rest/tests/v2/peers_swap_heuristic_03.yaml
	deleted:    rest/tests/v2/set_host_alias_01.yaml
	modified:   run.sh
	new file:   src/AddressResolutionTest.cpp
	deleted:    syslog/README.test
deleted:    syslog/ngi_trust.log
	deleted:    syslog/suricata.log

 Untracked files:
	e2e/
	gtest.cpp
2022-02-05 01:48:01 +01:00
Luca Deri
7f711569c4 Added check for unit tests 2022-02-04 23:33:16 +01:00
Giorgio Zoppi
d8255da8d8
modified: Makefile.in (#6281)
* modified:   Makefile.in
	new file:   tests/gtest.c

* Removing sonarcloud it's noisy.
2022-02-04 21:57:47 +01:00
Luca Deri
617ab12871 Added missing libs 2022-01-07 10:51:01 +01:00
Sam James
c4cd135323
build: respect environment options more (#6177)
* build: move away from configure.seed -> configure.ac

Analogous to the change in nDPI [0].

[0] cf931fda6b

Signed-off-by: Sam James <sam@gentoo.org>

* build: use $(MAKE)

This ensures that parallel make works correctly, as otherwise, a fresh
make job will be started without the jobserver fd, and hence
not know about its parent, forcing -j1.

Signed-off-by: Sam James <sam@gentoo.org>

* build: respect CXX, CXXFLAGS, LDFLAGS/LIBS

- Use standard CXX variable for the C++ compiler
- Respect CXXFLAGS from the environment
- LDFLAGS needs to be before objects in order for some flags to work
  like -Wl,--as-needed

Signed-off-by: Sam James <sam@gentoo.org>

* build: add comment for dynamic linking nDPI

It seems to work for me but add a commented
in line for now for convenience, not actually
changing behaviour right now.

(May want to make it a proper configure option
in future.)

Signed-off-by: Sam James <sam@gentoo.org>
2022-01-07 10:16:59 +01:00
Sam James
4e0be8ecd5
build: respect ${PKG_CONFIG} in Makefiles (#6173)
Allow overriding choice of pkg-config binary (this is useful
for cross-compilation in particular) within the Makefiles.

Not yet touching configure, so some work to be done still.

Signed-off-by: Sam James <sam@gentoo.org>
2022-01-03 17:15:06 +01:00
Luca Deri
d01202eb45 Moved to Lua 5.4.3 2021-10-06 16:39:22 +02:00
Simone Mainardi
dac1e85b75 Makes target to check circular Lua deps 2021-10-01 17:54:28 +02:00
Luca Deri
8130d5a042 ZeroMQ and Libsodium dependency cleanup 2021-08-26 11:02:40 +02:00
Simone Mainardi
40f5c4e821 Refactors {flow,host}callbacks into {flow,host}checks (C++) 2021-06-16 15:27:38 +02:00
Simone Mainardi
b12fc91a6b Merge branch 'host-user-scripts' into dev 2021-04-03 10:18:09 +02:00
Luca
a4047c5a1c Implements flow callbacks and alerts in C++
Scaffolding code of the host scripts

Scaffolding code for host alerts

Adds host_callbacks/ for .cpp files

Implements all classes for host callbacks

Removes pro/enterprise host callbacks

Adds typedefs with callback deltas

Compilation fix

Creates instances of host callbacks in loader

Link fix

Removes redundant/non-necessary host alerts

Merges Scan and Flood callbacks together

Removes outdated API files

Refactors alert keys into entity|id

Refactors all flow alert_{...} into flow_alert_{...}

Refactors C++ flow alert_{...} into flow_alert_{...}

Reworks alert ids to include an entity type

Cleanup and merge alertTypeRaw with getAlertType

Minor fix

Refactors alert definitions and keys into sub directories

Implement host alert callback execution and trigger/release logic

Update callbacks API

Adds base CallbacksLoader for {Host,Flow}CallbacksLoader

Implements load of host user scripts with periodicities

Implements runtime reload of host callbacks

Add logic for periodic callbacks

Add 'expired' flag to host alerts

Implements execution of host callbacks and SYN flood checks

Adds triggerAlertAsync calls to SYNFlood

Implements JSON host alert generation info

Handle callback getPeriod. Optimize callback lookup.

Implements host recipients in C++

Add callback status

Define destructor

Iterator fixes

Cleanup host Lua calls (now performed in C++)

Changes to show new host alerts in SQLite

Adds release/engage action on alert JSON

Move AlertableEntity to OtherAlertableEntity, inheriting from a new AlertableEntity. Add HostAlertableEntity.

Implements SYN Flood Attacker with params

Uses parametrized thresholds to trigger syn flood alerts

Implements build alert of both attacker and victim

Implement HostAlertableEntity

Implements SYN scan attacker/victim alerts

Implements flow flood attacker/victim alerts

Removes a debug flag

Add virtual allocStatus

Add HostAlert disableAutoRelease()

Add Ãexplicit releaseAlert()

Implements SYNFloodHostCallbackStatus

Implements SYNScanHostCallbackStatus

Implements FlowFloodHostCallbackStatus

Change trigger API to handle cli/src score

Implements {DNS,SMTP,NTP}ServerContactsAlert

Reworks ServerContacts host alerts

Implement exclusion bitmaps for host alerts

Implements {SMTP,DNS,NTP}ServerContactsAlert

Adds host_info to the generated alert JSON

Minor cleanup

Optimize access to callback status

Move RepliesRequestsRatio to pro

Rework triggerAlert on host to avoid multiple call and unneeded status data

Compilation fix

Reworked host alerts API (wip)

Cleanup unused host callbacks

Compilation fixes

Finishes backend implementation of host alerts exclusions

Rework host callbacks executor

Implements disable of host alerts

Port SYNFlood to the new api

Cleanup

Reduce duplicated code

Comments

Port ServerContacts to the new api

Clenaup

Adds parsing of configuration for host callbacks

Port SYNScanAlert to the new API

Port FlowFlood to the new API

Cleanup unused HostAlert getName

Reworks DNSRequestsErrorsRatioAlert

Adds JSON for DNSTrafficAlert

Adds FlowsAlert

Adds P2PTrafficAlert

Add RepliesRequestsRatioAlert

Adds ScoreAlert

Adds ThroughputAlert

Adds TrafficAlert

Fixes for scan/flood alerts

DNS ratio alert support

Add HTTP stats getters

Implements deltas for many host callbacks

Host score inc

Adds missing Alert params to host alerts

Release all host alerts on idle

Refactors score classes

Implements class Score to contain scores for hosts, flows, etc

Adds scores to VLANs, Networks, ASes and Countries

Host callbacks can trigger a single alert now

FlowFlood, SYNFloo, SYNScan now inherit from FlowHits

Move severity and score to constructor

Add else branch to hits callbacks

Alert definition update for flows_flood, syn_flood, syn_scan

Update field name

Engaged alert init

Adds score incs/decs for AS, VLAN, country, os and network

Restore network scripts

Restored other alert definitions for floods

Handle decreasing alert score

Removes include

Rename flows_flood to flow_flood for consistency

Restored alert_tcp_syn_flood_victim alert_tcp_syn_scan_victim definitions

Fixes for non-host engaged/release alerts

Cleanup LuaEngineFlow and LuaEngineHost classes

Fixes old calls to host lua during shutdown

Removes AlertCheckLuaEngine instance

Fixes purging of flows

Fixes alerts release upon shutdown causing wrong uses

Removes a debug flag

Fix getNumEngagedAlerts

Cleanup unnecessary host callbacks

Removes array of callback statuses inside host

Bitmap fixes

Refactors Bitmap into Bitmap128

Implements 16-bits bitmaps for host alerts

Adds class HostCallbacksStatus

Moves callback status p2p and DNS inside HostCallbacksStatus

Removes unused callbacks in typedefs

Minor cleanup

Adds trigger/release for DNS/p2p alerts

Reworks UI of hosts user scripts

Rename HostCallbackType to HostCallbackID, getType to getID, others
2021-04-03 09:53:15 +02:00
Luca Deri
5aaa3ae31b Cleanup of unused directories 2021-03-25 21:50:17 +01:00
Simone Mainardi
aea9138bfb Implements flow callbacks and alerts in C++ 2021-03-22 09:51:36 +01:00