Skip to content

Commit

Permalink
update: improve k8smeta logging
Browse files Browse the repository at this point in the history
Signed-off-by: Andrea Terzolo <[email protected]>
  • Loading branch information
Andreagit97 authored and poiana committed Nov 19, 2024
1 parent 5ddea47 commit 0890696
Show file tree
Hide file tree
Showing 2 changed files with 47 additions and 10 deletions.
53 changes: 45 additions & 8 deletions plugins/k8smeta/src/plugin.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1116,6 +1116,8 @@ bool my_plugin::extract(const falcosecurity::extract_fields_input& in)
// not in a pod.
if(m_thread_id_pod_uid_map.empty())
{
SPDLOG_TRACE("no pod uid in the framework table for thread id '{}'",
thread_id);
return false;
}

Expand All @@ -1126,6 +1128,8 @@ bool my_plugin::extract(const falcosecurity::extract_fields_input& in)
auto it = m_thread_id_pod_uid_map.find(thread_id);
if(it == m_thread_id_pod_uid_map.end())
{
SPDLOG_TRACE("no pod uid in the plugin cache for thread id '{}'",
thread_id);
return false;
}
pod_uid = it->second;
Expand Down Expand Up @@ -1398,18 +1402,44 @@ static inline sinsp_param get_syscall_evt_param(void* evt, uint32_t num_param)
dataoffset};
}

static inline const char* get_event_name(uint16_t evt_type)
{
switch(evt_type)
{
case PPME_ASYNCEVENT_E:
return "asyncevent";
case PPME_SYSCALL_EXECVE_19_X:
return "execve";
case PPME_SYSCALL_EXECVEAT_X:
return "execveat";
case PPME_SYSCALL_CLONE_20_X:
return "clone";
case PPME_SYSCALL_FORK_20_X:
return "fork";
case PPME_SYSCALL_VFORK_20_X:
return "vfork";
case PPME_SYSCALL_CLONE3_X:
return "clone3";
default:
return "unknown";
}
}

bool inline my_plugin::parse_process_events(
const falcosecurity::parse_event_input& in)
const falcosecurity::parse_event_input& in, uint16_t evt_type)
{
auto res_param = get_syscall_evt_param(in.get_event_reader().get_buf(),
EXECVE_CLONE_RES_PARAM_IDX);
int64_t thread_id = in.get_event_reader().get_tid();

// - For execve/execveat we exclude failed syscall events (ret<0)
// - For clone/fork/vfork/clone3 we exclude failed syscall events (ret<0)
int64_t ret = 0;
memcpy(&ret, res_param.param_pointer, sizeof(ret));
if(ret < 0)
{
SPDLOG_TRACE("failed {}(event: {}) for thread id '{}'",
get_event_name(evt_type), evt_type, thread_id);
return false;
}

Expand All @@ -1426,6 +1456,7 @@ bool inline my_plugin::parse_process_events(
// If croups are empty we don't parse the event
if(cgroup_param.param_len == 0)
{
SPDLOG_TRACE("empty cgroup for thread id '{}'", thread_id);
return false;
}

Expand All @@ -1441,21 +1472,27 @@ bool inline my_plugin::parse_process_events(
{
// retrieve thread entry associated with the event tid
auto& tr = in.get_table_reader();
auto thread_entry = m_thread_table.get_entry(
tr, (int64_t)in.get_event_reader().get_tid());
auto thread_entry = m_thread_table.get_entry(tr, thread_id);

// Write the pod_uid into the entry
auto& tw = in.get_table_writer();
m_pod_uid_field.write_value(tw, thread_entry,
(const char*)pod_uid.c_str());
SPDLOG_TRACE("pushed pod uid '{}' for thread id '{}' into the "
"framework table",
pod_uid, thread_id);
}
else
{
SPDLOG_TRACE("cannot find pod uid for thread id '{}' with cgroup '{}'",
thread_id, cgroup_first_charbuf);
}
return true;
}

bool my_plugin::parse_event(const falcosecurity::parse_event_input& in)
{
// NOTE: today in the libs framework, parsing errors are not logged
auto& evt = in.get_event_reader();

// Workaround: the parsing is the unique place where we can populate the
// sinsp thread table. The first time we call parse we populate the sinsp
Expand Down Expand Up @@ -1491,7 +1528,8 @@ bool my_plugin::parse_event(const falcosecurity::parse_event_input& in)
m_sinsp_proc_populated = true;
}

switch(evt.get_type())
uint16_t evt_type = in.get_event_reader().get_type();
switch(evt_type)
{
case PPME_ASYNCEVENT_E:
return parse_async_event(in);
Expand All @@ -1501,10 +1539,9 @@ bool my_plugin::parse_event(const falcosecurity::parse_event_input& in)
case PPME_SYSCALL_FORK_20_X:
case PPME_SYSCALL_VFORK_20_X:
case PPME_SYSCALL_CLONE3_X:
return parse_process_events(in);
return parse_process_events(in, evt_type);
default:
SPDLOG_ERROR("received an unknown event type {}",
int32_t(evt.get_type()));
SPDLOG_ERROR("received an unknown event type {}", uint16_t(evt_type));
return false;
}
}
4 changes: 2 additions & 2 deletions plugins/k8smeta/src/plugin.h
Original file line number Diff line number Diff line change
Expand Up @@ -237,8 +237,8 @@ class my_plugin

bool inline parse_async_event(const falcosecurity::parse_event_input& in);

bool inline parse_process_events(
const falcosecurity::parse_event_input& in);
bool inline parse_process_events(const falcosecurity::parse_event_input& in,
uint16_t evt_type);

bool parse_event(const falcosecurity::parse_event_input& in);

Expand Down

0 comments on commit 0890696

Please sign in to comment.