From 1e8d2c41ccad87ab5cf6284d00b21086a86e565b Mon Sep 17 00:00:00 2001 From: Lukas Hutak Date: Wed, 3 Jul 2019 17:09:46 +0200 Subject: [PATCH] FDS output: update dependency of collector version, improve handling of exceptions during a message process --- src/plugins/output/fds/src/fds.cpp | 14 +++++++++++--- 1 file changed, 11 insertions(+), 3 deletions(-) diff --git a/src/plugins/output/fds/src/fds.cpp b/src/plugins/output/fds/src/fds.cpp index c0ecedbe..292e17ab 100644 --- a/src/plugins/output/fds/src/fds.cpp +++ b/src/plugins/output/fds/src/fds.cpp @@ -30,7 +30,7 @@ IPX_API struct ipx_plugin_info ipx_plugin_info = { // Plugin version string (like "1.2.3") "2.0.0", // Minimal IPFIXcol version string (like "1.2.3") - "2.0.0" + "2.1.0" }; /// Instance @@ -106,6 +106,7 @@ int ipx_plugin_process(ipx_ctx_t *ctx, void *cfg, ipx_msg_t *msg) { auto *inst = reinterpret_cast(cfg); + bool failed = false; try { // Check if the current time window should be closed @@ -114,12 +115,19 @@ ipx_plugin_process(ipx_ctx_t *ctx, void *cfg, ipx_msg_t *msg) inst->storage_ptr->process_msg(msg_ipfix); } catch (const FDS_exception &ex) { IPX_CTX_ERROR(ctx, "%s", ex.what()); - inst->storage_ptr->window_close(); + failed = true; } catch (std::exception &ex) { IPX_CTX_ERROR(ctx, "Unexpected error has occurred: %s", ex.what()); - inst->storage_ptr->window_close(); + failed = true; } catch (...) { IPX_CTX_ERROR(ctx, "Unknown error has occurred!"); + failed = true; + } + + if (failed) { + IPX_CTX_ERROR(ctx, "Due to the previous error(s), the output file is possibly corrupted. " + "Therefore, no flow records are stored until a new file is automatically opened " + "after current window expiration."); inst->storage_ptr->window_close(); }