Wireshark 4.7.0
The Wireshark network protocol analyzer
Loading...
Searching...
No Matches
sinsp-span.h
1/* sinsp-span.h
2 *
3 * By Gerald Combs
4 * Copyright (C) 2022 Sysdig, Inc.
5 *
6 * Wireshark - Network traffic analyzer
7 * By Gerald Combs <[email protected]>
8 * Copyright 1998 Gerald Combs
9 *
10 * SPDX-License-Identifier: GPL-2.0-or-later
11 */
12
13#ifndef __SINSP_SPAN_H__
14#define __SINSP_SPAN_H__
15
16#include <stdint.h>
17
18#include <epan/ftypes/ftypes.h>
19#include <wsutil/wmem/wmem.h>
20
21#ifdef __cplusplus
22extern "C" {
23#endif // __cplusplus
24
25#define FALCO_FIELD_NAME_PREFIX "falco."
26
27#define N_PROC_LINEAGE_ENTRIES 16
28#define N_PROC_LINEAGE_ENTRY_FIELDS 4
29
31typedef struct sinsp_span_t sinsp_span_t;
32
36typedef enum sinsp_field_display_format_e {
37 SFDF_UNKNOWN,
38 SFDF_DECIMAL,
39 SFDF_HEXADECIMAL,
40 SFDF_OCTAL
41} sinsp_field_display_format_e;
42
43
49typedef enum sinsp_syscall_category_e {
50 SSC_EVENT,
51 SSC_EVTARGS,
52 SSC_PROCESS,
53 SSC_PROCLINEAGE,
54 SSC_USER,
55 SSC_GROUP,
56 SSC_CONTAINER,
57 SSC_FD,
58 SSC_FS,
59/* SSC_SYSLOG, */
60 SSC_FDLIST,
61 SSC_OTHER,
62 NUM_SINSP_SYSCALL_CATEGORIES
63} sinsp_syscall_category_e;
64
65
69typedef struct sinsp_field_info_t {
70 enum ftenum type;
71 sinsp_field_display_format_e display_format;
72 char abbrev[64];
73 char display[64];
74 char description[1024];
75 bool skip;
76 bool is_info;
80
81
83#define SFE_SMALL_BUF_SIZE 8
84
92typedef struct sinsp_field_extract_t {
94 union {
95 uint8_t *bytes;
96 const char *str;
97 int32_t i32;
98 int64_t i64;
99 uint32_t u32;
100 uint64_t u64;
101 double dbl;
102 bool boolean;
103 char small_str[SFE_SMALL_BUF_SIZE];
104 uint8_t small_bytes[SFE_SMALL_BUF_SIZE];
107 uint16_t field_idx;
109
110
115#define PLUGIN_EVENT_HEADER_SIZE (26 + 4 + 4 + 4)
116
125 uint32_t field_id;
126 const char *field_name;
132 union {
133 uint8_t *bytes;
134 const char *str;
135 int32_t i32;
136 int64_t i64;
137 uint32_t u32;
138 uint64_t u64;
139 double dbl;
140 uint8_t ipv6[16];
141 bool boolean;
146
154sinsp_span_t *create_sinsp_span(void);
155
161void destroy_sinsp_span(sinsp_span_t *sinsp_span);
162
163// Common routines
170uint32_t get_sinsp_source_id(sinsp_source_info_t *ssi);
171
179const char *get_sinsp_source_last_error(sinsp_source_info_t *ssi);
180
187const char *get_sinsp_source_name(sinsp_source_info_t *ssi);
188
195const char *get_sinsp_source_description(sinsp_source_info_t *ssi);
196
205bool get_sinsp_source_field_info(sinsp_source_info_t *ssi, size_t field_num, sinsp_field_info_t *field);
206
207// libsinsp builtin syscall routines.
208
215void create_sinsp_syscall_source(sinsp_span_t *sinsp_span, sinsp_source_info_t **ssi_ptr);
216
225void open_sinsp_capture(sinsp_span_t *sinsp_span, const char *filepath);
226
227//uint32_t process_syscall_capture(sinsp_span_t * sinsp_span, sinsp_source_info_t *ssi, uint32_t to_event);
228
234void close_sinsp_capture(sinsp_span_t *sinsp_span);
235
247bool extract_syscall_source_fields(sinsp_span_t *sinsp_span, sinsp_source_info_t *ssi, uint32_t frame_num, sinsp_field_extract_t **sinsp_fields, uint32_t *sinsp_field_len, void** sisnp_evt_info);
248
256sinsp_syscall_category_e get_syscall_parent_category(sinsp_source_info_t *ssi, size_t field_check_idx);
257
277bool get_extracted_syscall_source_fields(sinsp_span_t *sinsp_span, uint32_t frame_num, sinsp_field_extract_t **sinsp_fields, uint32_t *sinsp_field_len, void** sinsp_evt_info);
278
286char* get_evt_arg_name(void* sinsp_evt_info, uint32_t arg_num);
287
294bool evt_creates_fd(void* sinsp_evt_info);
295
296// Extractor plugin routines.
297// These roughly match common_plugin_info
298
307char *create_sinsp_plugin_source(sinsp_span_t *sinsp_span, const char* libname, sinsp_source_info_t **ssi_ptr);
308
315size_t get_sinsp_source_nfields(sinsp_source_info_t *ssi);
316
332bool extract_plugin_source_fields(sinsp_source_info_t *ssi, uint32_t event_num, const uint8_t *evt_data, uint32_t evt_datalen, wmem_allocator_t *pool, plugin_field_extract_t *sinsp_fields, uint32_t sinsp_field_len);
333
334
335#ifdef __cplusplus
336}
337#endif // __cplusplus
338
339#endif // __SINSP_SPAN_H__
ftenum
Fundamental field value types used throughout the Wireshark dissector framework.
Definition ftypes.h:26
Internal memory allocator interface used by the wmem subsystem.
Definition wmem_allocator.h:34
Holds a single field extraction request/result for a plugin event.
Definition sinsp-span.h:124
bool boolean
Definition sinsp-span.h:141
const char * str
Definition sinsp-span.h:134
uint8_t ipv6[16]
Definition sinsp-span.h:140
uint8_t * bytes
Definition sinsp-span.h:133
const char * field_name
Definition sinsp-span.h:126
enum ftenum type
Definition sinsp-span.h:127
double dbl
Definition sinsp-span.h:139
uint32_t u32
Definition sinsp-span.h:137
int32_t i32
Definition sinsp-span.h:135
uint32_t field_id
Definition sinsp-span.h:125
union plugin_field_extract_t::@560 res
Extracted value; the active member is determined by type.
bool is_generated
Definition sinsp-span.h:129
bool is_present
Definition sinsp-span.h:128
uint64_t u64
Definition sinsp-span.h:138
int64_t i64
Definition sinsp-span.h:136
int data_length
Definition sinsp-span.h:144
int data_start
Definition sinsp-span.h:143
Holds a single extracted field value from a sinsp syscall event.
Definition sinsp-span.h:92
char small_str[8]
Definition sinsp-span.h:103
bool boolean
Definition sinsp-span.h:102
int res_len
Definition sinsp-span.h:106
const char * str
Definition sinsp-span.h:96
uint64_t u64
Definition sinsp-span.h:100
int32_t i32
Definition sinsp-span.h:97
uint32_t u32
Definition sinsp-span.h:99
uint8_t * bytes
Definition sinsp-span.h:95
double dbl
Definition sinsp-span.h:101
uint8_t small_bytes[8]
Definition sinsp-span.h:104
uint16_t field_idx
Definition sinsp-span.h:107
union sinsp_field_extract_t::@559 res
Extracted value; the active member depends on the field type.
int64_t i64
Definition sinsp-span.h:98
Metadata describing a single sinsp filter/display field.
Definition sinsp-span.h:69
enum ftenum type
Definition sinsp-span.h:70
bool is_info
Definition sinsp-span.h:76
bool is_conversation
Definition sinsp-span.h:77
char display[64]
Definition sinsp-span.h:73
sinsp_field_display_format_e display_format
Definition sinsp-span.h:71
char abbrev[64]
Definition sinsp-span.h:72
char description[1024]
Definition sinsp-span.h:74
bool skip
Definition sinsp-span.h:75
bool is_numeric_address
Definition sinsp-span.h:78
Definition sinsp-span.cpp:52
Definition sinsp-span.cpp:71