-
Notifications
You must be signed in to change notification settings - Fork 0
Events
- config event - This is triggered before the packet processing and reporting threads are created. This is used parse any module configuration from the configuration file.
int module_MODULENAME_config(yaml_parser_t *parser, yaml_event_t *event, int *level);
- starting event (packet processing threads) - This event is triggered when the application starts, is used to setup any packet processing thread storage for the plugin.
void *module_MODULENAME_starting(void *tls);
- packet event (packet processing thread) - This event is triggered when a packet is received. Any BPF filters applied by the plugin will also apply to the plugins packet event.
int module_MODULENAME_packet(libtrace_t *trace, libtrace_thread_t *thread, Flow *flow, libtrace_packet_t *packet, void *tls, void *mls);
- protocol event (packet processing thread) - Each protocol has its own event. A plugin may register for the HTTP protocol event in which would be notified when a HTTP packet is received.
int module_MODULENAME_PROTOCOL(libtrace_t *trace, libtrace_thread_t *thread, Flow *flow, libtrace_packet_t *packet, void *tls, void *mls);
- stopping event (packet processing threads) - Is triggered when the packet processing threads stop (only when the application stops). This is used to cleanup any allocated storage or flush any remaining results before the application stops.
int module_MODULENAME_stopping(void *tls, void *mls);
- tick event (packet processing threads) - Is triggered at a regular time interval set by each plugin. This is used to export results at regular time intervals.
int module_MODULENAME_tick(libtrace_t *trace, libtrace_thread_t *thread, void *tls, void *mls, uint64_t tick);
- flow start event (packet processing thread) - Is triggered when the first packet is seen for a new flow.
int module_MODULENAME_flowstart(bd_flow_record_t *flow_record);
- flow end event (packet processing thread) - Is triggered when a flow has not received any packets within a timeout period, the flow is assumed to have ended.
int module_MODULENAME_flowend(bd_flow_record_t *flow_record);
- clear event (packet processing threads) - Is used to clear any results stored within the plugin. This is triggered when the output for a periodic interval needs to be aligned to the nearest absolute interval
int module_MODULENAME_clear(void *mls);
- starting event (reporting thread) - When the reporting thread first starts (On application launch). Is used to allocate storage used by the reporting thread.
void *module_MODULENAME_reporter_starting(void *tls);
- combining event (reporting thread) - Is triggered when a result is received and needs to be combined with other results for the same time period.
int module_MODULENAME_combine(bd_bigdata_t *bigdata, void *mls, uint64_t tick, void *result);
- result event (reporting thread) - Is triggered when a result is received and is ready to be exported.
int module_MODULENAME_reporter_result(bd_bigdata_t *bigdata, void *mls, bd_result_set *result);
- stopping event (reporting thread) - When the reporting thread stops (only when the application stops). Is used to cleanup any allocated storage within the reporting thread.
int module_MODULENAME_reporter_stopping(void *tls, void *mls);