Go to the documentation of this file.
87 static inline void DetectRulePacketRules(
ThreadVars *
const tv,
126 DetectRunInspectIPOnly(th_v,
de_ctx, det_ctx, pflow, p);
129 DetectRunGetRuleGroup(
de_ctx, p, pflow, &scratch);
132 if (scratch.
sgh == NULL) {
133 SCLogDebug(
"no sgh for this packet, nothing to match against");
138 DetectRunPrefilterPkt(th_v,
de_ctx, det_ctx, p, &scratch);
142 DetectRulePacketRules(th_v,
de_ctx, det_ctx, p, pflow, &scratch);
147 if (p->
proto == IPPROTO_TCP) {
160 DetectRunFrames(th_v,
de_ctx, det_ctx, p, pflow, &scratch);
169 }
else if (p->
proto == IPPROTO_UDP) {
170 DetectRunFrames(th_v,
de_ctx, det_ctx, p, pflow, &scratch);
174 DetectRunTx(th_v,
de_ctx, det_ctx, p, pflow, &scratch);
184 DetectRunPostRules(th_v,
de_ctx, det_ctx, p, pflow, &scratch);
186 DetectRunCleanup(det_ctx, p, pflow);
199 SCLogDebug(
"running match functions, sm %p", smd);
230 }
else if (p->
proto == 0) {
231 if (!(PacketIsIPv4(p) || PacketIsIPv6(p))) {
240 int proto = PacketGetIPProto(p);
241 if (
proto == IPPROTO_TCP) {
245 const uint16_t port = dir ? p->
dp : p->
sp;
250 SCLogDebug(
"TCP list %p, port %u, direction %s, sghport %p, sgh %p", list, port,
251 dir ?
"toserver" :
"toclient", sghport, sgh);
252 }
else if (
proto == IPPROTO_UDP) {
254 uint16_t port = dir ? p->
dp : p->
sp;
258 SCLogDebug(
"UDP list %p, port %u, direction %s, sghport %p, sgh %p", list, port,
259 dir ?
"toserver" :
"toclient", sghport, sgh);
290 final_ptr = nonmpm_ptr;
295 nonmpm = *nonmpm_ptr;
309 if (
likely(
id != previous_id)) {
315 final_ptr = nonmpm_ptr;
321 }
else if (mpm > nonmpm) {
326 if (
likely(
id != previous_id)) {
336 nonmpm = *nonmpm_ptr;
342 while (--m_cnt != 0) {
353 final_ptr = ++nonmpm_ptr;
368 nonmpm = *nonmpm_ptr;
374 while (final_cnt-- > 0) {
379 if (
likely(
id != previous_id)) {
393 static inline void DetectPrefilterBuildNonPrefilterList(
401 if ((rule_mask & mask) == rule_mask &&
402 (rule_alproto == 0 || AppProtoEquals(rule_alproto, alproto))) {
415 if ((p->
proto == IPPROTO_TCP) && PacketIsTCP(p) && (PacketGetTCP(p)->th_flags &
TH_SYN)) {
422 SCLogDebug(
"sgh non_pf ptr %p cnt %u (syn %p/%u, other %p/%u)",
434 DetectPostInspectFileFlagsUpdate(
Flow *f,
const SigGroupHead *sgh, uint8_t direction)
439 SCLogDebug(
"requesting disabling all file features for flow");
443 SCLogDebug(
"requesting disabling filestore for flow");
447 if (!(sgh->
flags & SIG_GROUP_HEAD_HAVEFILEMAGIC)) {
448 SCLogDebug(
"requesting disabling magic for flow");
453 SCLogDebug(
"requesting disabling md5 for flow");
457 SCLogDebug(
"requesting disabling sha1 for flow");
461 SCLogDebug(
"requesting disabling sha256 for flow");
465 SCLogDebug(
"requesting disabling filesize for flow");
469 if (flow_file_flags != 0) {
485 SCLogDebug(
"STREAMTCP_STREAM_FLAG_DISABLE_RAW ssn.client");
490 DetectPostInspectFileFlagsUpdate(pflow,
500 SCLogDebug(
"STREAMTCP_STREAM_FLAG_DISABLE_RAW ssn.server");
505 DetectPostInspectFileFlagsUpdate(pflow,
510 static inline void DetectRunGetRuleGroup(
518 bool use_flow_sgh =
false;
521 if (PacketGetIPProto(p) == pflow->
proto) {
525 SCLogDebug(
"sgh = pflow->sgh_toserver; => %p", sgh);
529 SCLogDebug(
"sgh = pflow->sgh_toclient; => %p", sgh);
535 if (!(use_flow_sgh)) {
548 DetectRunPostGetFirstRuleGroup(p, pflow, sgh);
576 SCLogDebug(
"testing against \"ip-only\" signatures");
598 static inline bool DetectRunInspectRuleHeader(
const Packet *p,
const Flow *f,
const Signature *s,
599 const uint32_t sflags,
const uint8_t s_proto_flags)
608 const bool fv = f->
flowvar != NULL;
610 SCLogDebug(
"skipping sig as the flow has no flowvars and sig "
611 "has SIG_FLAG_REQUIRE_FLOWVAR flag set.");
651 SCLogDebug(
"port-less protocol and sig needs ports");
657 if (PacketIsIPv4(p)) {
660 }
else if (PacketIsIPv6(p)) {
667 if (PacketIsIPv4(p)) {
670 }
else if (PacketIsIPv6(p)) {
682 static inline void DetectRunPrefilterPkt(
690 DetectPrefilterSetNonPrefilterList(p, det_ctx, scratch);
699 DetectPrefilterBuildNonPrefilterList(det_ctx, scratch->
pkt_mask, scratch->
alproto);
713 DetectPrefilterMergeSort(
de_ctx, det_ctx);
738 static bool IsOnlyTxInDirection(
Flow *f, uint64_t txid, uint8_t dir)
741 if (tx_cnt == txid + 1) {
745 if (tx_cnt == txid + 2) {
760 static inline void DetectRulePacketRules(
777 (uint64_t)match_cnt);
788 uint32_t sflags, next_sflags = 0;
790 next_s = *match_array++;
791 next_sflags = next_s->
flags;
793 while (match_cnt--) {
795 uint8_t alert_flags = 0;
800 sflags = next_sflags;
802 next_s = *match_array++;
803 next_sflags = next_s->
flags;
827 if (SigDsizePrefilter(p, s, sflags))
838 if (DetectRunInspectRuleHeader(p, pflow, s, sflags, s_proto_flags) ==
false) {
849 DetectRunPostMatch(
tv, det_ctx, p, s);
867 if (pflow->
proto != IPPROTO_UDP) {
870 txd->guessed_applayer_logged++;
876 DetectVarProcessList(det_ctx, pflow, p);
877 DetectReplaceFree(det_ctx);
889 uint8_t flow_flags = 0;
890 bool app_decoder_events =
false;
909 det_ctx->pkt_stream_add_cnt++;
918 flow_flags = STREAM_TOSERVER;
921 flow_flags = STREAM_TOCLIENT;
927 flow_flags |= STREAM_EOF;
958 (p->
proto == IPPROTO_UDP) ||
963 alproto = FlowGetAppProtocol(pflow);
970 SCLogDebug(
"packet doesn't have established flag set (proto %d)", p->
proto);
981 static inline void DetectRunPostRules(
1013 if (pflow != NULL) {
1030 FatalError(
"failed to allocate %" PRIu64
" bytes",
1034 SCLogDebug(
"array initialized to %u elements (%"PRIu64
" bytes)",
1046 const uint32_t need)
1057 uint32_t new_size = needed;
1060 FatalError(
"failed to expand to %" PRIu64
" bytes",
1066 SCLogDebug(
"array expanded from %u to %u elements (%"PRIu64
" bytes -> %"PRIu64
" bytes)",
1079 DetectRunTxSortHelper(
const void *a,
const void *b)
1083 if (s1->
id == s0->
id) {
1090 return s0->
id > s1->
id ? 1 : -1;
1094 #define TRACE_SID_TXS(sid,txs,...) \
1096 char _trace_buf[2048]; \
1097 snprintf(_trace_buf, sizeof(_trace_buf), __VA_ARGS__); \
1098 SCLogNotice("%p/%"PRIu64"/%u: %s", txs->tx_ptr, txs->tx_id, sid, _trace_buf); \
1101 #define TRACE_SID_TXS(sid,txs,...)
1110 tx_ptr = SCDoH2GetDnsTx(tx_ptr, flow_flags);
1115 }
else if (engine_alproto != alproto) {
1139 const uint8_t in_flow_flags,
1143 uint32_t *stored_flags,
1147 const uint8_t flow_flags = in_flow_flags;
1148 const int direction = (flow_flags & STREAM_TOSERVER) ? 0 : 1;
1149 uint32_t inspect_flags = stored_flags ? *stored_flags : 0;
1150 int total_matches = 0;
1151 uint16_t file_no_match = 0;
1152 bool retval =
false;
1153 bool mpm_before_progress =
false;
1154 bool mpm_in_progress =
false;
1156 TRACE_SID_TXS(s->
id, tx,
"starting %s", direction ?
"toclient" :
"toserver");
1159 if (
likely(stored_flags == NULL)) {
1161 if (DetectRunInspectRuleHeader(p, f, s, s->
flags, s->
proto.
flags) ==
false) {
1178 TRACE_SID_TXS(s->
id, tx,
"engine %p inspect_flags %x", engine, inspect_flags);
1179 if (!(inspect_flags &
BIT_U32(engine->
id)) &&
1180 direction == engine->
dir)
1183 if (tx_ptr == NULL) {
1187 engine = engine->
next;
1197 SCLogDebug(
"tx progress %d < engine progress %d",
1204 "engine->mpm: t->tx_progress %u > engine->progress %u, so set "
1205 "mpm_before_progress",
1207 mpm_before_progress =
true;
1210 "engine->mpm: t->tx_progress %u == engine->progress %u, so set "
1213 mpm_in_progress =
true;
1221 TRACE_SID_TXS(s->
id, tx,
"stream skipped, stored result %d used instead", match);
1226 de_ctx, det_ctx, engine, s, f, flow_flags, alstate, tx_ptr, tx->
tx_id);
1231 TRACE_SID_TXS(s->
id, tx,
"stream ran, store result %d for next tx (if any)", match);
1236 engine = engine->
next;
1243 engine = engine->
next;
1255 if (engine->
mpm && mpm_before_progress) {
1261 engine = engine->
next;
1262 }
while (engine != NULL);
1263 TRACE_SID_TXS(s->
id, tx,
"inspect_flags %x, total_matches %u, engine %p",
1264 inspect_flags, total_matches, engine);
1266 if (engine == NULL && total_matches) {
1273 *stored_flags = inspect_flags;
1274 TRACE_SID_TXS(s->
id, tx,
"continue inspect flags %08x", inspect_flags);
1281 if (file_no_match) {
1292 inspect_flags, flow_flags, file_no_match);
1296 "mpm won't trigger for it anymore");
1300 "we may have to revisit anyway");
1302 inspect_flags, flow_flags, file_no_match);
1306 "mpm will revisit it");
1307 }
else if (inspect_flags != 0 || file_no_match != 0) {
1310 inspect_flags, flow_flags, file_no_match);
1319 NULL, 0, NULL, NULL, 0, 0, 0, 0, 0, \
1327 void *alstate,
const uint64_t tx_id,
void *tx_ptr,
const int tx_end_state,
1328 const uint8_t flow_flags)
1336 bool updated = (flow_flags & STREAM_TOSERVER) ? txd->updated_ts : txd->updated_tc;
1337 if (!updated && tx_progress < tx_end_state && ((flow_flags & STREAM_EOF) == 0)) {
1341 uint64_t detect_flags =
1342 (flow_flags & STREAM_TOSERVER) ? txd->detect_flags_ts : txd->detect_flags_tc;
1344 SCLogDebug(
"%"PRIu64
" tx already fully inspected for %s. Flags %016"PRIx64,
1345 tx_id, flow_flags & STREAM_TOSERVER ?
"toserver" :
"toclient",
1351 SCLogDebug(
"%" PRIu64
" tx should not be inspected in direction %s. Flags %016" PRIx64,
1352 tx_id, flow_flags & STREAM_TOSERVER ?
"toserver" :
"toclient", detect_flags);
1357 const int dir_int = (flow_flags & STREAM_TOSERVER) ? 0 : 1;
1367 .de_state = tx_dir_state,
1368 .detect_flags = detect_flags,
1369 .prefilter_flags = prefilter_flags,
1370 .prefilter_flags_orig = prefilter_flags,
1371 .tx_progress = tx_progress,
1372 .tx_end_state = tx_end_state,
1377 static inline void StoreDetectFlags(
DetectTransaction *tx,
const uint8_t flow_flags,
1378 const uint8_t ipproto,
const AppProto alproto,
const uint64_t detect_flags)
1381 if (
likely(txd != NULL)) {
1382 if (flow_flags & STREAM_TOSERVER) {
1383 txd->detect_flags_ts = detect_flags;
1385 txd->detect_flags_tc = detect_flags;
1392 static inline void RuleMatchCandidateMergeStateRules(
1410 uint32_t j = *array_idx;
1419 uint32_t k = *array_idx;
1441 if (s->
num <= s0->
id) {
1472 const uint8_t flow_flags = scratch->
flow_flags;
1474 void *
const alstate = f->
alstate;
1475 const uint8_t ipproto = f->
proto;
1486 AppLayerGetTxIterTuple ires = IterFunc(ipproto, alproto, alstate, tx_id_min, total_txs, &state);
1487 if (ires.tx_ptr == NULL)
1491 alstate, ires.tx_id, ires.tx_ptr, tx_end_state, flow_flags);
1493 SCLogDebug(
"%p/%"PRIu64
" no transaction to inspect",
1499 tx_id_min = tx.
tx_id + 1;
1501 bool do_sort =
false;
1502 uint32_t array_idx = 0;
1512 SCLogDebug(
"%p/%"PRIu64
" rules added from prefilter: %u candidates",
1516 if (!(RuleMatchCandidateTxArrayHasSpace(det_ctx, total_rules))) {
1517 RuleMatchCandidateTxArrayExpand(det_ctx, total_rules);
1531 if (!(RuleMatchCandidateTxArrayHasSpace(det_ctx, total_rules))) {
1532 RuleMatchCandidateTxArrayExpand(det_ctx, total_rules);
1538 uint32_t x = array_idx;
1540 RuleMatchCandidateMergeStateRules(det_ctx, &array_idx);
1544 const uint32_t old = array_idx;
1549 if (have_new_file) {
1550 SCLogDebug(
"%p/%"PRIu64
" destate: need to consider new file",
1557 for (; tx_store != NULL; tx_store = tx_store->
next) {
1563 store_cnt++, state_cnt++)
1580 do_sort |= (old && old != array_idx);
1586 DetectRunTxSortHelper);
1598 for (uint32_t i = 0; i < array_idx; i++) {
1605 for (uint32_t i = 0; i < array_idx; i++) {
1615 while ((i + 1) < array_idx &&
1617 SCLogDebug(
"%p/%" PRIu64
" inspecting SKIP NEXT: sid %u (%u), flags %08x",
1622 SCLogDebug(
"%p/%"PRIu64
" inspecting: sid %u (%u), flags %08x",
1625 if (inspect_flags) {
1627 SCLogDebug(
"%p/%"PRIu64
" inspecting: sid %u (%u), flags %08x ALREADY COMPLETE",
1633 if (inspect_flags) {
1643 const int r = DetectRunTxInspectRule(
tv,
de_ctx, det_ctx, p, f, flow_flags,
1644 alstate, &tx, s, inspect_flags, can, scratch);
1647 DetectRunPostMatch(
tv, det_ctx, p, s);
1653 DetectVarProcessList(det_ctx, p->
flow, p);
1663 uint64_t new_detect_flags = 0;
1667 SCLogDebug(
"%p/%"PRIu64
" tx is done for direction %s. Flag %016"PRIx64,
1669 flow_flags & STREAM_TOSERVER ?
"toserver" :
"toclient",
1675 SCLogDebug(
"%p/%"PRIu64
" updated prefilter flags %016"PRIx64
" "
1676 "(was: %016"PRIx64
") for direction %s. Flag %016"PRIx64,
1678 flow_flags & STREAM_TOSERVER ?
"toserver" :
"toclient",
1681 if (new_detect_flags != 0 &&
1686 SCLogDebug(
"%p/%"PRIu64
" Storing new flags %016"PRIx64
" (was %016"PRIx64
")",
1689 StoreDetectFlags(&tx, flow_flags, ipproto, alproto, new_detect_flags);
1710 SCLogDebug(
"pcap_cnt %" PRIu64
": %s: skip frame inspection for TCP w/o APP UPDATE",
1715 if (frames_container == NULL) {
1720 frames = &frames_container->
toserver;
1722 frames = &frames_container->
toclient;
1725 for (uint32_t idx = 0; idx < frames->
cnt; idx++) {
1728 if (frame == NULL) {
1733 uint32_t array_idx = 0;
1741 SCLogDebug(
"%p/%" PRIi64
" rules added from prefilter: %u candidates", frame, frame->
id,
1746 if (!(RuleMatchCandidateTxArrayHasSpace(
1747 det_ctx, total_rules))) {
1748 RuleMatchCandidateTxArrayExpand(det_ctx, total_rules);
1763 uint32_t x = array_idx;
1774 SCLogDebug(
"%p/%" PRIi64
" rule %u (%u) added from 'match' list", frame, frame->
id,
1778 SCLogDebug(
"%p/%" PRIi64
" rules added from 'match' list: %u", frame, frame->
id,
1783 for (uint32_t i = 0; i < array_idx; i++) {
1790 while ((i + 1) < array_idx &&
1794 SCLogDebug(
"%p/%" PRIi64
" inspecting: sid %u (%u)", frame, frame->
id, s->
id, s->
num);
1797 SCLogDebug(
"%p/%" PRIi64
" Start sid %u", frame, frame->
id, s->
id);
1801 bool r = DetectRunInspectRuleHeader(p, f, s, s->
flags, s->
proto.
flags);
1806 DetectRunPostMatch(
tv, det_ctx, p, s);
1811 "%p/%" PRIi64
" sig %u (%u) matched", frame, frame->
id, s->
id, s->
num);
1818 DetectVarProcessList(det_ctx, p->
flow, p);
1829 "frame->inspect_progress: %" PRIu64
" -> not updated", frame->
inspect_progress);
1832 SCLogDebug(
"%p/%" PRIi64
" rules inspected, running cleanup", frame, frame->
id);
1863 SCLogDebug(
"p->pcap %"PRIu64
": no detection on packet, "
1864 "PKT_NOPACKET_INSPECTION is set", p->
pcap_cnt);
1877 (void)DetectRun(
tv,
de_ctx, det_ctx, p);
1908 if (det_ctx == NULL) {
1909 printf(
"ERROR: Detect has no thread ctx\n");
1915 SCLogDebug(
"Detect Engine using new det_ctx - %p",
1926 if (tenant_id > 0 && tenant_id < det_ctx->mt_det_ctxs_cnt) {
1929 if (det_ctx == NULL)
1937 SCLogDebug(
"MT de_ctx %p det_ctx %p (tenant %u)",
de_ctx, det_ctx, tenant_id);
1948 DetectFlow(
tv,
de_ctx, det_ctx, p);
1950 DetectNoFlow(
tv,
de_ctx, det_ctx, p);
1953 #ifdef PROFILE_RULES
1956 gettimeofday(&
ts, NULL);
1957 if (
ts.tv_sec != det_ctx->rule_perf_last_sync) {
1958 SCProfilingRuleThreatAggregate(det_ctx);
1959 det_ctx->rule_perf_last_sync =
ts.tv_sec;
1973 DetectPostInspectFileFlagsUpdate(f, NULL , STREAM_TOSERVER);
1974 DetectPostInspectFileFlagsUpdate(f, NULL , STREAM_TOCLIENT);
1985 DetectFlow(
tv,
de_ctx, det_ctx, p);
1987 DetectNoFlow(
tv,
de_ctx, det_ctx, p);
#define PKT_IS_TOCLIENT(p)
uint32_t non_pf_syn_store_cnt
bool PacketCheckAction(const Packet *p, const uint8_t a)
#define FLOWFILE_NO_MD5_TS
SignatureNonPrefilterStore * non_pf_store_ptr
void RulesDumpTxMatchArray(const DetectEngineThreadCtx *det_ctx, const SigGroupHead *sgh, const Packet *p, const uint64_t tx_id, const uint32_t rule_cnt, const uint32_t pkt_prefilter_cnt)
#define SIG_GROUP_HEAD_HAVEFILEMD5
#define FLOWFILE_NO_MD5_TC
PrefilterEngine * tx_engines
struct AppLayerTxData * tx_data_ptr
#define DE_STATE_CHUNK_SIZE
#define FLOWFILE_NO_SIZE_TS
uint64_t inspect_progress
uint16_t alert_queue_size
#define FLOWFILE_NO_SIZE_TC
DetectMatchAddressIPv6 * addr_src_match6
SigTableElmt * sigmatch_table
#define PACKET_ALERT_FLAG_TX
struct SigGroupHead_ * decoder_event_sgh
int FlowGetPacketDirection(const Flow *f, const Packet *p)
determine the direction of the packet compared to the flow
DetectEngineLookupFlow flow_gh[FLOW_STATES]
#define DE_STATE_FLAG_SIG_CANT_MATCH
uint16_t counter_match_list
struct DetectEngineAppInspectionEngine_ * next
#define DETECT_PROTO_IPV6
#define PKT_IS_PSEUDOPKT(p)
return 1 if the packet is a pseudo packet
uint32_t rule_id_array_cnt
Container for matching data for a signature group.
#define SIG_GROUP_HEAD_HAVEFILESIZE
#define SC_ATOMIC_SET(name, val)
Set the value for the atomic variable.
#define KEYWORD_PROFILING_SET_LIST(ctx, list)
int DetectAddressMatchIPv4(const DetectMatchAddressIPv4 *addrs, uint16_t addrs_cnt, const Address *a)
Match a packets address against a signatures addrs array.
InspectEngineFuncPtr Callback
#define FLOW_SGH_TOCLIENT
void AppLayerParserSetTransactionInspectId(const Flow *f, AppLayerParserState *pstate, void *alstate, const uint8_t flags, bool tag_txs_as_inspected)
AppLayerGetTxIteratorFunc AppLayerGetTxIterator(const uint8_t ipproto, const AppProto alproto)
struct HtpBodyChunk_ * next
int AppLayerParserGetStateProgress(uint8_t ipproto, AppProto alproto, void *alstate, uint8_t flags)
get the progress value for a tx/protocol
#define FLOWFILE_NO_MAGIC_TS
#define ICMPV4_DEST_UNREACH_IS_VALID(p)
#define SIG_GROUP_HEAD_HAVEFILESHA1
#define FLOW_TC_APP_UPDATED
main detection engine ctx
int AppLayerParserGetStateProgressCompletionStatus(AppProto alproto, uint8_t direction)
struct DetectRunScratchpad DetectRunScratchpad
#define APP_LAYER_TX_SKIP_INSPECT_FLAG
struct DetectEngineAppInspectionEngine_::@79 v2
DetectEngineStateDirection dir_state[2]
Frame * FrameGetByIndex(Frames *frames, const uint32_t idx)
#define FLOW_PKT_TOSERVER
#define APP_LAYER_TX_INSPECTED_FLAG
#define SIG_GROUP_HEAD_HAVERAWSTREAM
void SigMatchSignatures(ThreadVars *tv, DetectEngineCtx *de_ctx, DetectEngineThreadCtx *det_ctx, Packet *p)
wrapper for old tests
SigMatchData * sm_arrays[DETECT_SM_LIST_MAX]
struct SigGroupHead_ * sh
#define PKT_NOPAYLOAD_INSPECTION
#define PACKET_PROFILING_DETECT_END(p, id)
TmEcode Detect(ThreadVars *tv, Packet *p, void *data)
Detection engine thread wrapper.
#define FLOW_PKT_TOCLIENT_IPONLY_SET
bool DetectRunFrameInspectRule(ThreadVars *tv, DetectEngineThreadCtx *det_ctx, const Signature *s, Flow *f, Packet *p, const Frames *frames, const Frame *frame)
#define KEYWORD_PROFILING_START
uint16_t counter_fnonmpm_list
void DisableDetectFlowFileFlags(Flow *f)
disable file features we don't need Called if we have no detection engine.
uint64_t AppLayerParserGetTransactionInspectId(AppLayerParserState *pstate, uint8_t direction)
uint16_t counter_nonmpm_list
void DetectRunPrefilterFrame(DetectEngineThreadCtx *det_ctx, const SigGroupHead *sgh, Packet *p, const Frames *frames, const Frame *frame, const AppProto alproto)
PacketEngineEvents events
DetectEngineFrameInspectionEngine * frame_inspect
const uint64_t prefilter_flags_orig
void PacketCreateMask(Packet *p, SignatureMask *mask, AppProto alproto, bool app_decoder_events)
#define SIG_FLAG_APPLAYER
#define KEYWORD_PROFILING_END(ctx, type, m)
HashTable * mt_det_ctxs_hash
bool DetectEnginePktInspectionRun(ThreadVars *tv, DetectEngineThreadCtx *det_ctx, const Signature *s, Flow *f, Packet *p, uint8_t *alert_flags)
const struct SigGroupHead_ * sgh_toserver
uint16_t counter_alerts_suppressed
void DetectRunStoreStateTx(const SigGroupHead *sgh, Flow *f, void *tx, uint64_t tx_id, const Signature *s, uint32_t inspect_flags, uint8_t flow_flags, const uint16_t file_no_match)
AppLayerParserState * alparser
#define DETECT_ENGINE_INSPECT_SIG_CANT_MATCH_FILES
#define FLOWFILE_NO_SHA1_TC
@ DETECT_SM_LIST_POSTMATCH
RuleMatchCandidateTx * tx_candidates
DetectMatchAddressIPv4 * addr_src_match4
uint16_t counter_alerts_overflow
#define PKT_IS_TOSERVER(p)
void Prefilter(DetectEngineThreadCtx *det_ctx, const SigGroupHead *sgh, Packet *p, const uint8_t flags, const SignatureMask mask)
#define DEBUG_VALIDATE_PACKET(p)
#define FLOWFILE_NO_STORE_TS
uint32_t tx_candidates_size
#define FLOW_PKT_TOSERVER_IPONLY_SET
#define FRAME_FLAG_TX_ID_SET
uint64_t AppLayerParserGetTxDetectFlags(AppLayerTxData *txd, const uint8_t dir)
#define PKT_PSEUDO_STREAM_END
#define STREAM_FLAGS_FOR_PACKET(p)
struct SigGroupHead_ * sgh[256]
void * HashTableLookup(HashTable *ht, void *data, uint16_t datalen)
Per thread variable structure.
struct DeStateStore_ * next
#define FLOWFILE_NO_SHA256_TS
#define DETECT_ENGINE_INSPECT_SIG_MATCH
#define PKT_DETECT_HAS_STREAMDATA
bool StreamReassembleRawHasDataReady(TcpSession *ssn, Packet *p)
does the stream engine have data to inspect?
const char * PktSrcToString(enum PktSrcEnum pkt_src)
#define PACKET_ALERT_FLAG_TX_GUESSED
Port structure for detection engine.
DetectEngineAppInspectionEngine * app_inspect
const struct SigGroupHead_ * sgh_toclient
#define SIG_FLAG_REQUIRE_FLOWVAR
uint64_t raw_stream_progress
void FileUpdateFlowFileFlags(Flow *f, uint16_t set_file_flags, uint8_t direction)
set a flow's file flags
void AlertQueueAppend(DetectEngineThreadCtx *det_ctx, const Signature *s, Packet *p, uint64_t tx_id, uint8_t alert_flags)
Append signature to local packet alert queue for later preprocessing.
void RuleMatchCandidateTxArrayFree(DetectEngineThreadCtx *det_ctx)
FramesContainer * AppLayerFramesGetContainer(Flow *f)
#define APP_LAYER_TX_PREFILTER_MASK
void FlowSetIPOnlyFlag(Flow *f, int direction)
Set the IPOnly scanned flag for 'direction'.
#define FLOW_TOSERVER_IPONLY_SET
#define RULE_PROFILING_END(a, b, c, p)
#define RULE_PROFILING_START(p)
#define SCReturnPtr(x, type)
DetectEngineStateDirection * de_state
Data structures and function prototypes for keeping state for the detection engine.
int(* Match)(DetectEngineThreadCtx *, Packet *, const Signature *, const SigMatchCtx *)
void RulesDumpMatchArray(const DetectEngineThreadCtx *det_ctx, const SigGroupHead *sgh, const Packet *p)
uint16_t addr_dst_match6_cnt
#define FLOW_PKT_TOCLIENT
PrefilterEngine * frame_engines
#define PACKET_ALERT_NOTX
#define APP_LAYER_PARSER_NO_INSPECTION
void * AppLayerParserGetTx(uint8_t ipproto, AppProto alproto, void *alstate, uint64_t tx_id)
#define DETECT_ENGINE_INSPECT_SIG_CANT_MATCH
#define DETECT_ENGINE_STATE_FLAG_FILE_NEW
#define SCRealloc(ptr, sz)
#define FLOWFILE_NO_SHA256_TC
#define DETECT_ENGINE_INSPECT_SIG_MATCH_MORE_FILES
struct AppLayerTxData AppLayerTxData
#define DETECT_PROTO_IPV4
int DetectAddressMatchIPv6(const DetectMatchAddressIPv6 *addrs, uint16_t addrs_cnt, const Address *a)
Match a packets address against a signatures addrs array.
void DetectEngineStateResetTxs(Flow *f)
Reset de state for active tx' To be used on detect engine reload.
#define FLOWFILE_NO_MAGIC_TC
SignatureNonPrefilterStore * non_pf_other_store_array
#define FLOW_TOCLIENT_IPONLY_SET
#define APP_LAYER_TX_RESERVED_FLAGS
uint32_t non_pf_other_store_cnt
uint8_t app_update_direction
uint64_t frame_inspect_progress
uint32_t profile_match_logging_threshold
#define FLOW_TS_APP_UPDATED
AppLayerTxData * AppLayerParserGetTxData(uint8_t ipproto, AppProto alproto, void *tx)
#define FLOWFILE_NO_STORE_TC
SigIntId * non_pf_id_array
uint16_t addr_src_match6_cnt
void StreamReassembleRawUpdateProgress(TcpSession *ssn, Packet *p, const uint64_t progress)
update stream engine after detection
void StatsAddUI64(ThreadVars *tv, uint16_t id, uint64_t x)
Adds a value of type uint64_t to the local counter.
#define FLOWFILE_NO_SHA1_TS
const bool app_decoder_events
#define PACKET_PROFILING_DETECT_START(p, id)
#define PACKET_ALERT_FLAG_FRAME
uint32_t non_pf_store_cnt
#define FLOW_SGH_TOSERVER
#define SGH_PROFILING_RECORD(det_ctx, sgh)
void PacketAlertFinalize(DetectEngineCtx *de_ctx, DetectEngineThreadCtx *det_ctx, Packet *p)
Check the threshold of the sigs that match, set actions, break on pass action This function iterate t...
DetectMatchAddressIPv6 * addr_dst_match6
DeStateStoreItem store[DE_STATE_CHUNK_SIZE]
uint8_t guess_applayer_log_limit
void InspectionBufferClean(DetectEngineThreadCtx *det_ctx)
#define TRACE_SID_TXS(sid, txs,...)
#define FLOW_PKT_ESTABLISHED
#define STREAMTCP_FLAG_APP_LAYER_DISABLED
void IPOnlyMatchPacket(ThreadVars *tv, const DetectEngineCtx *de_ctx, DetectEngineThreadCtx *det_ctx, const DetectEngineIPOnlyCtx *io_ctx, Packet *p)
Match a packet against the IP Only detection engine contexts.
SignatureNonPrefilterStore * non_pf_syn_store_array
#define PKT_NOPACKET_INSPECTION
void * DetectGetInnerTx(void *tx_ptr, AppProto alproto, AppProto engine_alproto, uint8_t flow_flags)
#define DE_STATE_FLAG_FULL_INSPECT
#define STREAMTCP_STREAM_FLAG_DISABLE_RAW
AppLayerGetTxIterTuple(* AppLayerGetTxIteratorFunc)(const uint8_t ipproto, const AppProto alproto, void *alstate, uint64_t min_tx_id, uint64_t max_tx_id, AppLayerGetTxIterState *state)
tx iterator prototype
#define DE_STATE_FLAG_FILE_INSPECT
#define FLOW_NOPACKET_INSPECTION
DetectEngineIPOnlyCtx io_ctx
#define SC_ATOMIC_GET(name)
Get the value from the atomic variable.
DetectMatchAddressIPv4 * addr_dst_match4
uint8_t FlowGetDisruptionFlags(const Flow *f, uint8_t flags)
get 'disruption' flags: GAP/DEPTH/PASS
uint16_t addr_src_match4_cnt
uint16_t AppLayerParserStateIssetFlag(AppLayerParserState *pstate, uint16_t flag)
void GenericVarFree(GenericVar *gv)
uint16_t addr_dst_match4_cnt
AppProto alproto
application level protocol
#define SIG_GROUP_HEAD_HAVEFILESHA256
uint64_t AppLayerParserGetTxCnt(const Flow *f, void *alstate)
#define PACKET_ALERT_FLAG_STATE_MATCH
bool AppLayerParserHasDecoderEvents(AppLayerParserState *pstate)
#define DEBUG_VALIDATE_BUG_ON(exp)
const uint64_t detect_flags
uint16_t counter_mpm_list
const SigGroupHead * SigMatchSignaturesGetSgh(const DetectEngineCtx *de_ctx, const Packet *p)
Get the SigGroupHead for a packet.
void DetectRunPrefilterTx(DetectEngineThreadCtx *det_ctx, const SigGroupHead *sgh, Packet *p, const uint8_t ipproto, const uint8_t flow_flags, const AppProto alproto, void *alstate, DetectTransaction *tx)
run prefilter engines on a transaction
void RuleMatchCandidateTxArrayInit(DetectEngineThreadCtx *det_ctx, uint32_t size)
DetectPort * DetectPortLookupGroup(DetectPort *dp, uint16_t port)
Function that find the group matching port in a group head.
uint32_t(* TenantGetId)(const void *, const Packet *p)
int DetectProtoContainsProto(const DetectProto *dp, int proto)
see if a DetectProto contains a certain proto