|
suricata
|
Flow data structure. More...
#include <flow.h>

Flow data structure.
The flow is a global data structure that is created for new packets of a flow and then looked up for the following packets of a flow.
Locking
The flow is updated/used by multiple packets at the same time. This is why there is a flow-mutex. It's a mutex and not a spinlock because some operations on the flow can be quite expensive, thus spinning would be too expensive.
The flow "header" (addresses, ports, proto, recursion level) are static after the initialization and remain read-only throughout the entire live of a flow. This is why we can access those without protection of the lock.
| union { ... } |
| union { ... } |
| union { ... } |
| AppLayerParserState* Flow_::alparser |
application level storage ptrs. parser internal state
Definition at line 471 of file flow.h.
Referenced by AppLayerFrameDump(), AppLayerFramesFreeContainer(), AppLayerFramesGetContainer(), AppLayerFramesSetupContainer(), AppLayerParserParse(), AppLayerProtoDetectReset(), FlowCleanupAppLayer(), FlowNeedsReassembly(), HttpXFFGetIP(), LLVMFuzzerTestOneInput(), Prefilter(), and StreamTcpDisableAppLayer().
| AppProto Flow_::alproto |
application level protocol
Definition at line 443 of file flow.h.
Referenced by AppLayerFramesSetupContainer(), AppLayerHandleTCPData(), AppLayerHandleUdp(), AppLayerIncAllocErrorCounter(), AppLayerIncGapErrorCounter(), AppLayerIncInternalErrorCounter(), AppLayerIncParserErrorCounter(), AppLayerIncTxCounter(), AppLayerParserSetTransactionInspectId(), AppLayerParserStateCleanup(), AppLayerProtoDetectReset(), AppLayerRequestProtocolChange(), DetectEngineInspectBufferGeneric(), DetectEngineInspectBufferSingle(), DetectEngineInspectFiledata(), DetectEngineInspectMultiBufferGeneric(), DetectRunFrameInspectRule(), DetectRunStoreStateTx(), EveAddAppProto(), FlowNeedsReassembly(), FrameJsonLogOneFrame(), LLVMFuzzerTestOneInput(), LuaExtensionsMatchSetup(), LuaStateNeedProto(), Prefilter(), RulesDumpMatchArray(), RulesDumpTxMatchArray(), and SCAppLayerForceProtocolChange().
| AppProto Flow_::alproto_expect |
expected app protocol: used in protocol change/upgrade like in STARTTLS.
Definition at line 452 of file flow.h.
Referenced by AppLayerRequestProtocolChange(), and EveAddAppProto().
| AppProto Flow_::alproto_orig |
original application level protocol. Used to indicate the previous protocol when changing to another protocol , e.g. with STARTTLS.
Definition at line 449 of file flow.h.
Referenced by AppLayerRequestProtocolChange(), EveAddAppProto(), and SCAppLayerForceProtocolChange().
| AppProto Flow_::alproto_tc |
Definition at line 445 of file flow.h.
Referenced by AppLayerHandleTCPData(), AppLayerHandleUdp(), AppLayerProtoDetectReset(), AppLayerRequestProtocolChange(), EveAddAppProto(), and SCAppLayerForceProtocolChange().
| AppProto Flow_::alproto_ts |
Definition at line 444 of file flow.h.
Referenced by AppLayerHandleTCPData(), AppLayerHandleUdp(), AppLayerProtoDetectReset(), AppLayerRequestProtocolChange(), EveAddAppProto(), and SCAppLayerForceProtocolChange().
| void* Flow_::alstate |
application layer state
Definition at line 472 of file flow.h.
Referenced by DetectFileInspectGeneric(), FlowCleanupAppLayer(), FlowNeedsReassembly(), and LuaExtensionsMatchSetup().
| uint8_t Flow_::applied_exception_policy |
which exception policies were applied, if any
Definition at line 466 of file flow.h.
Referenced by ExceptionPolicyParse().
| uint32_t Flow_::de_ctx_version |
| Port Flow_::dp |
tcp/udp destination port
Definition at line 363 of file flow.h.
Referenced by LLVMFuzzerTestOneInput(), and SCFlowGetDestinationPort().
| FlowAddress Flow_::dst |
Definition at line 350 of file flow.h.
Referenced by LLVMFuzzerTestOneInput().
| struct { ... } Flow_::esp |
| struct FlowBucket_* Flow_::fb |
Definition at line 484 of file flow.h.
Referenced by FlowBitFree(), FlowBitIsnotset(), FlowBitIsset(), and FlowBitToggle().
| uint8_t Flow_::ffr_tc |
Definition at line 379 of file flow.h.
Referenced by FlowNeedsReassembly().
| uint8_t Flow_::ffr_ts |
Definition at line 378 of file flow.h.
Referenced by FlowNeedsReassembly().
| uint16_t Flow_::file_flags |
file tracking/extraction flags
Definition at line 398 of file flow.h.
Referenced by FileFlowToFlags().
| uint64_t Flow_::flags |
generic flags
Definition at line 396 of file flow.h.
Referenced by FlowChangeProto(), FlowClearMemory(), FlowGetPacketDirection(), FlowHasAlerts(), FlowSendToLocalThread(), FlowSetChangeProtoFlag(), FlowSetHasAlertsFlag(), FlowSwap(), FlowUnsetChangeProtoFlag(), LLVMFuzzerTestOneInput(), and SCFlowGetFlags().
| uint32_t Flow_::flow_hash |
| FlowStateType Flow_::flow_state |
Definition at line 413 of file flow.h.
Referenced by FlowHandlePacketUpdate(), FlowUpdateState(), and PacketBypassCallback().
| GenericVar* Flow_::flowvar |
Definition at line 482 of file flow.h.
Referenced by EveAddMetadata(), FlowVarAddFloat(), FlowVarAddIdValue(), FlowVarAddIntNoLock(), FlowVarAddKeyValue(), FlowVarGet(), and FlowVarGetByKey().
| struct { ... } Flow_::icmp_d |
| struct { ... } Flow_::icmp_s |
| SCTime_t Flow_::lastts |
time stamp of last update (last packet). Set/updated under the flow and flow hash row locks, safe to read under either the flow lock or flow hash row lock.
Definition at line 411 of file flow.h.
Referenced by AppLayerExpectationCreate(), FlowHandlePacketUpdate(), and SCFlowGetLastTimeAsParts().
| struct LiveDevice_* Flow_::livedev |
| struct Flow_* Flow_::next |
Definition at line 394 of file flow.h.
Referenced by FlowGetExistingFlowFromFlowId(), FlowQueuePrivateAppendFlow(), FlowQueuePrivateAppendPrivate(), FlowQueuePrivateGetFromTop(), FlowQueuePrivatePrependFlow(), FlowReset(), and FlowShutdown().
| uint32_t Flow_::probing_parser_toclient_alproto_masks |
Definition at line 420 of file flow.h.
Referenced by AppLayerProtoDetectReset(), and FlowSwap().
| uint32_t Flow_::probing_parser_toserver_alproto_masks |
Definition at line 419 of file flow.h.
Referenced by AppLayerProtoDetectReset(), and FlowSwap().
| uint8_t Flow_::proto |
ip proto of the flow
Definition at line 369 of file flow.h.
Referenced by AppLayerFrameDump(), AppLayerFramesSetupContainer(), AppLayerParserParse(), AppLayerParserSetTransactionInspectId(), DetectEngineInspectBufferGeneric(), DetectEngineInspectBufferSingle(), DetectEngineInspectFiledata(), DetectEngineInspectMultiBufferGeneric(), DetectRunFrameInspectRule(), DetectRunStoreStateTx(), FlowCleanupAppLayer(), FlowGetDisruptionFlags(), FlowInit(), FlowReset(), FlowShutdown(), FrameJsonLogOneFrame(), FramesPrune(), LLVMFuzzerTestOneInput(), LuaExtensionsMatchSetup(), StreamTcpAppLayerIsDisabled(), UTHAddStreamToFlow(), and UTHRemoveSessionFromFlow().
| void* Flow_::protoctx |
protocol specific data pointer, e.g. for TcpSession
Definition at line 426 of file flow.h.
Referenced by AppLayerFrameDump(), AppLayerFramesSetupContainer(), AppLayerFramesSlide(), DetectEngineInspectStreamPayload(), FlowClearMemory(), FlowGetDisruptionFlags(), FlowNeedsReassembly(), FramesPrune(), LLVMFuzzerTestOneInput(), SCAppLayerParserTriggerRawStreamInspection(), StreamTcpAppLayerIsDisabled(), StreamTcpDetectLogFlush(), StreamTcpDisableAppLayer(), StreamTcpPacket(), StreamTcpPruneSession(), StreamTcpReassembleDepthReached(), StreamTcpSegmentForEach(), StreamTcpSegmentForSession(), StreamTcpSessionPktFree(), UTHAddSessionToFlow(), UTHAddStreamToFlow(), and UTHRemoveSessionFromFlow().
| uint16_t Flow_::protodetect_dp |
destination port to be used in protocol detection. This is meant for use with STARTTLS and HTTP CONNECT detection 0 if not used
Definition at line 402 of file flow.h.
Referenced by AppLayerRequestProtocolChange().
| uint8_t Flow_::protomap |
mapping to Flow's protocol specific protocols for timeouts and state and free functions.
Definition at line 438 of file flow.h.
Referenced by AppLayerIncAllocErrorCounter(), AppLayerIncGapErrorCounter(), AppLayerIncInternalErrorCounter(), AppLayerIncParserErrorCounter(), AppLayerIncTxCounter(), AppLayerParserParse(), AppLayerParserStateCleanup(), FlowHandlePacketUpdate(), and LLVMFuzzerTestOneInput().
| uint8_t Flow_::recursion_level |
Definition at line 370 of file flow.h.
Referenced by FlowInit().
| const struct SigGroupHead_* Flow_::sgh_toclient |
| const struct SigGroupHead_* Flow_::sgh_toserver |
| Port Flow_::sp |
tcp/udp source port
Definition at line 352 of file flow.h.
Referenced by FlowGetPacketDirection(), LLVMFuzzerTestOneInput(), and SCFlowGetSourcePort().
| FlowAddress Flow_::src |
Definition at line 350 of file flow.h.
Referenced by FlowGetPacketDirection(), and LLVMFuzzerTestOneInput().
| SCTime_t Flow_::startts |
Definition at line 486 of file flow.h.
Referenced by EveAddFlow().
| Storage Flow_::storage[] |
Definition at line 493 of file flow.h.
Referenced by FlowAllocStorageById(), FlowFreeStorage(), FlowFreeStorageById(), FlowGetStorageById(), and FlowSetStorageById().
| uint32_t Flow_::tenant_id |
| FlowThreadId Flow_::thread_id[2] |
Thread ID for the stream/detect portion of this flow
Definition at line 385 of file flow.h.
Referenced by FlowInit(), and FlowSendToLocalThread().
| uint32_t Flow_::timeout_policy |
timeout in seconds by policy, add to Flow::lastts to get actual time this times out. Ignored in emergency mode.
| uint64_t Flow_::todstbytecnt |
Definition at line 490 of file flow.h.
Referenced by EveAddFlow(), and FlowHandlePacketUpdate().
| uint32_t Flow_::todstpktcnt |
Definition at line 488 of file flow.h.
Referenced by EveAddFlow(), and FlowHandlePacketUpdate().
| uint64_t Flow_::tosrcbytecnt |
Definition at line 491 of file flow.h.
Referenced by EveAddFlow().
| uint32_t Flow_::tosrcpktcnt |
Definition at line 489 of file flow.h.
Referenced by EveAddFlow().
| uint16_t Flow_::vlan_id[VLAN_MAX_LAYERS] |
Definition at line 371 of file flow.h.
Referenced by FlowInit().
| uint8_t Flow_::vlan_idx |
Definition at line 373 of file flow.h.
Referenced by FlowInit().