mirror of
https://github.com/falcosecurity/falco.git
synced 2025-08-19 06:37:15 +00:00
new(userspace/falco): add file name generator helper for capture
Signed-off-by: Leonardo Grasso <me@leonardograsso.com>
This commit is contained in:
parent
1da5514012
commit
a818d48806
@ -1,6 +1,6 @@
|
|||||||
// SPDX-License-Identifier: Apache-2.0
|
// SPDX-License-Identifier: Apache-2.0
|
||||||
/*
|
/*
|
||||||
Copyright (C) 2023 The Falco Authors.
|
Copyright (C) 2025 The Falco Authors.
|
||||||
|
|
||||||
Licensed under the Apache License, Version 2.0 (the "License");
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
you may not use this file except in compliance with the License.
|
you may not use this file except in compliance with the License.
|
||||||
@ -20,6 +20,7 @@ limitations under the License.
|
|||||||
#include "../state.h"
|
#include "../state.h"
|
||||||
#include "../run_result.h"
|
#include "../run_result.h"
|
||||||
|
|
||||||
|
#include <string>
|
||||||
#include <nlohmann/json.hpp>
|
#include <nlohmann/json.hpp>
|
||||||
|
|
||||||
namespace falco {
|
namespace falco {
|
||||||
@ -34,6 +35,44 @@ void check_for_ignored_events(falco::app::state& s);
|
|||||||
void format_plugin_info(std::shared_ptr<sinsp_plugin> p, std::ostream& os);
|
void format_plugin_info(std::shared_ptr<sinsp_plugin> p, std::ostream& os);
|
||||||
void format_described_rules_as_text(const nlohmann::json& v, std::ostream& os);
|
void format_described_rules_as_text(const nlohmann::json& v, std::ostream& os);
|
||||||
|
|
||||||
|
inline std::string generate_scap_file_path(const std::string& prefix,
|
||||||
|
uint64_t timestamp,
|
||||||
|
uint64_t evt_num) {
|
||||||
|
// File path in format: <prefix>_<timestamp>_<evt_num>.scap
|
||||||
|
// Example: "/tmp/falco_00000001234567890_00000000000000042.scap"
|
||||||
|
|
||||||
|
// Add underscore separator between prefix and timestamp
|
||||||
|
std::string path = prefix + "_";
|
||||||
|
|
||||||
|
// Zero-pad timestamp to 20 digits for proper lexicographic sorting
|
||||||
|
// Build digits from right to left in a buffer, then append to path
|
||||||
|
char digits[21]; // 20 digits + null terminator
|
||||||
|
digits[20] = '\0';
|
||||||
|
uint64_t t = timestamp;
|
||||||
|
for (int i = 19; i >= 0; --i) {
|
||||||
|
digits[i] = '0' + (t % 10);
|
||||||
|
t /= 10;
|
||||||
|
}
|
||||||
|
path += digits;
|
||||||
|
|
||||||
|
// Add underscore separator between timestamp and evt_num
|
||||||
|
path += "_";
|
||||||
|
|
||||||
|
// Zero-pad evt_num to 20 digits for proper lexicographic sorting
|
||||||
|
// Build digits from right to left in a buffer, then append to path
|
||||||
|
t = evt_num;
|
||||||
|
for (int i = 19; i >= 0; --i) {
|
||||||
|
digits[i] = '0' + (t % 10);
|
||||||
|
t /= 10;
|
||||||
|
}
|
||||||
|
path += digits;
|
||||||
|
|
||||||
|
// Add file extension
|
||||||
|
path += ".scap";
|
||||||
|
|
||||||
|
return path;
|
||||||
|
}
|
||||||
|
|
||||||
falco::app::run_result open_offline_inspector(falco::app::state& s);
|
falco::app::run_result open_offline_inspector(falco::app::state& s);
|
||||||
falco::app::run_result open_live_inspector(falco::app::state& s,
|
falco::app::run_result open_live_inspector(falco::app::state& s,
|
||||||
std::shared_ptr<sinsp> inspector,
|
std::shared_ptr<sinsp> inspector,
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
// SPDX-License-Identifier: Apache-2.0
|
// SPDX-License-Identifier: Apache-2.0
|
||||||
/*
|
/*
|
||||||
Copyright (C) 2023 The Falco Authors.
|
Copyright (C) 2025 The Falco Authors.
|
||||||
|
|
||||||
Licensed under the Apache License, Version 2.0 (the "License");
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
you may not use this file except in compliance with the License.
|
you may not use this file except in compliance with the License.
|
||||||
@ -20,6 +20,7 @@ limitations under the License.
|
|||||||
#include <libsinsp/plugin_manager.h>
|
#include <libsinsp/plugin_manager.h>
|
||||||
|
|
||||||
#include <unordered_set>
|
#include <unordered_set>
|
||||||
|
#include <cstdint>
|
||||||
|
|
||||||
using namespace falco::app;
|
using namespace falco::app;
|
||||||
using namespace falco::app::actions;
|
using namespace falco::app::actions;
|
||||||
|
Loading…
Reference in New Issue
Block a user