mirror of
https://github.com/optim-enterprises-bv/nDPId-2.git
synced 2025-10-30 17:57:52 +00:00
* nDPIsrvd: Collector/Distributor logging improved * nDPIsrvd: Command line option for max remote descriptors * nDPId: Stop spamming nDPIsrvd Collector with the same events over and over again * nDPId: Refactored some variable names and events Signed-off-by: Toni Uhlig <matzeton@googlemail.com>
160 lines
4.3 KiB
C
160 lines
4.3 KiB
C
#include <signal.h>
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
#include <unistd.h>
|
|
|
|
#include "nDPIsrvd.h"
|
|
|
|
static int main_thread_shutdown = 0;
|
|
static struct nDPIsrvd_socket * sock = NULL;
|
|
|
|
#ifdef ENABLE_MEMORY_PROFILING
|
|
void nDPIsrvd_memprof_log(char const * const format, ...)
|
|
{
|
|
va_list ap;
|
|
|
|
va_start(ap, format);
|
|
fprintf(stderr, "%s", "nDPIsrvd MemoryProfiler: ");
|
|
vfprintf(stderr, format, ap);
|
|
fprintf(stderr, "%s\n", "");
|
|
va_end(ap);
|
|
}
|
|
#endif
|
|
|
|
static void nDPIsrvd_write_flow_info_cb(struct nDPIsrvd_flow const * const flow, void * user_data)
|
|
{
|
|
(void)user_data;
|
|
|
|
fprintf(stderr,
|
|
"[Flow %4llu][ptr: "
|
|
#ifdef __LP64__
|
|
"0x%016llx"
|
|
#else
|
|
"0x%08lx"
|
|
#endif
|
|
"][last-seen: %13llu][idle-time: %13llu]\n",
|
|
flow->id_as_ull,
|
|
#ifdef __LP64__
|
|
(unsigned long long int)flow,
|
|
#else
|
|
(unsigned long int)flow,
|
|
#endif
|
|
flow->last_seen,
|
|
flow->idle_time);
|
|
}
|
|
|
|
static void nDPIsrvd_verify_flows_cb(struct nDPIsrvd_flow const * const flow, void * user_data)
|
|
{
|
|
(void)user_data;
|
|
|
|
fprintf(stderr, "Flow %llu verification failed\n", flow->id_as_ull);
|
|
}
|
|
|
|
static void sighandler(int signum)
|
|
{
|
|
struct nDPIsrvd_instance * current_instance;
|
|
struct nDPIsrvd_instance * itmp;
|
|
int verification_failed = 0;
|
|
|
|
if (signum == SIGUSR1)
|
|
{
|
|
nDPIsrvd_flow_info(sock, nDPIsrvd_write_flow_info_cb, NULL);
|
|
|
|
HASH_ITER(hh, sock->instance_table, current_instance, itmp)
|
|
{
|
|
if (nDPIsrvd_verify_flows(current_instance, nDPIsrvd_verify_flows_cb, NULL) != 0)
|
|
{
|
|
fprintf(stderr, "Flow verification failed for instance %d\n", current_instance->alias_source_key);
|
|
verification_failed = 1;
|
|
}
|
|
}
|
|
if (verification_failed == 0)
|
|
{
|
|
fprintf(stderr, "%s\n", "Flow verification succeeded.");
|
|
}
|
|
}
|
|
else if (main_thread_shutdown == 0)
|
|
{
|
|
main_thread_shutdown = 1;
|
|
}
|
|
}
|
|
|
|
static enum nDPIsrvd_callback_return simple_json_callback(struct nDPIsrvd_socket * const sock,
|
|
struct nDPIsrvd_instance * const instance,
|
|
struct nDPIsrvd_flow * const flow)
|
|
{
|
|
(void)sock;
|
|
(void)flow;
|
|
|
|
struct nDPIsrvd_json_token const * const flow_event_name = TOKEN_GET_SZ(sock, "flow_event_name");
|
|
if (TOKEN_VALUE_EQUALS_SZ(flow_event_name, "new") != 0)
|
|
{
|
|
printf("Instance %d, Flow %llu new\n", instance->alias_source_key, flow->id_as_ull);
|
|
}
|
|
|
|
return CALLBACK_OK;
|
|
}
|
|
|
|
static void simple_flow_cleanup_callback(struct nDPIsrvd_socket * const sock,
|
|
struct nDPIsrvd_instance * const instance,
|
|
struct nDPIsrvd_flow * const flow,
|
|
enum nDPIsrvd_cleanup_reason reason)
|
|
{
|
|
(void)sock;
|
|
|
|
char const * const reason_str = nDPIsrvd_enum_to_string(reason);
|
|
printf("Instance %d, Flow %llu cleanup, reason: %s\n",
|
|
instance->alias_source_key,
|
|
flow->id_as_ull,
|
|
(reason_str != NULL ? reason_str : "UNKNOWN"));
|
|
|
|
if (reason == CLEANUP_REASON_FLOW_TIMEOUT)
|
|
{
|
|
printf("Did an nDPId instance die or was SIGKILL'ed?\n");
|
|
exit(1);
|
|
}
|
|
}
|
|
|
|
int main(int argc, char ** argv)
|
|
{
|
|
signal(SIGUSR1, sighandler);
|
|
signal(SIGINT, sighandler);
|
|
signal(SIGTERM, sighandler);
|
|
signal(SIGPIPE, sighandler);
|
|
|
|
sock = nDPIsrvd_socket_init(0, 0, simple_json_callback, simple_flow_cleanup_callback);
|
|
if (sock == NULL)
|
|
{
|
|
return 1;
|
|
}
|
|
|
|
if (nDPIsrvd_setup_address(&sock->address, (argc > 1 ? argv[1] : "127.0.0.1:7000")) != 0)
|
|
{
|
|
return 1;
|
|
}
|
|
|
|
if (nDPIsrvd_connect(sock) != CONNECT_OK)
|
|
{
|
|
nDPIsrvd_socket_free(&sock);
|
|
return 1;
|
|
}
|
|
|
|
enum nDPIsrvd_read_return read_ret;
|
|
while (main_thread_shutdown == 0 && (read_ret = nDPIsrvd_read(sock)) == READ_OK)
|
|
{
|
|
enum nDPIsrvd_parse_return parse_ret = nDPIsrvd_parse_all(sock);
|
|
if (parse_ret != PARSE_NEED_MORE_DATA)
|
|
{
|
|
printf("Could not parse json string: %s\n", nDPIsrvd_enum_to_string(parse_ret));
|
|
break;
|
|
}
|
|
}
|
|
|
|
if (read_ret != READ_OK)
|
|
{
|
|
printf("Parse read %s\n", nDPIsrvd_enum_to_string(read_ret));
|
|
}
|
|
|
|
return 1;
|
|
}
|