SCReturnInt(0);
}
- if (SignatureHasPacketContent(s)) {
+ if (!(s->proto.proto[6 / 8] & 1 << (6 % 8))) {
SCReturnInt(0);
}
SCReturnInt(0);
}
+ if (!(s->flags & SIG_FLAG_REQUIRE_STREAM)) {
+ SCReturnInt(0);
+ }
+
SCReturnInt(1);
}
SCReturnInt(-1);
}
+ /* if any of these flags are set they are set in a mutually exclusive
+ * manner */
if (s->proto.flags & DETECT_PROTO_ONLY_PKT) {
s->flags |= SIG_FLAG_REQUIRE_PACKET;
} else if (s->proto.flags & DETECT_PROTO_ONLY_STREAM) {
if (s->flags & SIG_FLAG_REQUIRE_PACKET &&
s->flags & SIG_FLAG_REQUIRE_STREAM) {
- SCLogError(SC_ERR_INVALID_SIGNATURE, "can't mix packet keywords with tcp-stream or flow:only_stream.");
+ SCLogError(SC_ERR_INVALID_SIGNATURE, "can't mix packet keywords with "
+ "tcp-stream or flow:only_stream. Invalidating signature.");
SCReturnInt(0);
}
}
}
+ if (!(s->flags & SIG_FLAG_REQUIRE_PACKET)) {
+ s->flags |= SIG_FLAG_REQUIRE_STREAM;
+ SigMatch *sm = s->sm_lists[DETECT_SM_LIST_PMATCH];
+ while (sm != NULL) {
+ if (sm->type == DETECT_CONTENT &&
+ (((DetectContentData *)(sm->ctx))->flags &
+ (DETECT_CONTENT_DEPTH | DETECT_CONTENT_OFFSET))) {
+ s->flags |= SIG_FLAG_REQUIRE_PACKET;
+ break;
+ }
+ sm = sm->next;
+ }
+ }
+
#ifdef DEBUG
int i;
for (i = 0; i < DETECT_SM_LIST_MAX; i++) {
if (s->sm_lists[DETECT_SM_LIST_PMATCH] != NULL) {
/* if we have stream msgs, inspect against those first,
* but not for a "dsize" signature */
- if (!(s->flags & SIG_FLAG_REQUIRE_PACKET)) {
+ if (s->flags & SIG_FLAG_REQUIRE_STREAM) {
char pmatch = 0;
if (smsg != NULL) {
uint8_t pmq_idx = 0;
if (pmatch == 0) {
SCLogDebug("no match in smsg, fall back to packet payload");
- if (p->flags & PKT_STREAM_ADD)
- goto next;
+ if (!(s->flags & SIG_FLAG_REQUIRE_PACKET)) {
+ if (p->flags & PKT_STREAM_ADD)
+ goto next;
+ }
if (sms_runflags & SMS_USED_PM) {
if (s->flags & SIG_FLAG_MPM_PACKET && !(s->flags & SIG_FLAG_MPM_PACKET_NEG) &&