|  |  |  | @ -171,7 +171,7 @@ static int DetectWithinSetup (DetectEngineCtx *de_ctx, Signature *s, char *withi | 
		
	
		
			
				|  |  |  |  |                 DETECT_CONTENT, s->sm_lists_tail[DETECT_SM_LIST_HHDMATCH], | 
		
	
		
			
				|  |  |  |  |                 DETECT_CONTENT, s->sm_lists_tail[DETECT_SM_LIST_HRHDMATCH], | 
		
	
		
			
				|  |  |  |  |                 DETECT_CONTENT, s->sm_lists_tail[DETECT_SM_LIST_HMDMATCH], | 
		
	
		
			
				|  |  |  |  |                 DETECT_AL_HTTP_COOKIE, s->sm_lists_tail[DETECT_SM_LIST_HCDMATCH], | 
		
	
		
			
				|  |  |  |  |                 DETECT_CONTENT, s->sm_lists_tail[DETECT_SM_LIST_HCDMATCH], | 
		
	
		
			
				|  |  |  |  |                 DETECT_AL_HTTP_STAT_MSG, s->sm_lists_tail[DETECT_SM_LIST_HSMDMATCH], | 
		
	
		
			
				|  |  |  |  |                 DETECT_AL_HTTP_STAT_CODE, s->sm_lists_tail[DETECT_SM_LIST_HSCDMATCH], | 
		
	
		
			
				|  |  |  |  |                 DETECT_AL_HTTP_RAW_URI, s->sm_lists_tail[DETECT_SM_LIST_HRUDMATCH]); | 
		
	
	
		
			
				
					|  |  |  | @ -300,74 +300,6 @@ static int DetectWithinSetup (DetectEngineCtx *de_ctx, Signature *s, char *withi | 
		
	
		
			
				|  |  |  |  | 
 | 
		
	
		
			
				|  |  |  |  |             break; | 
		
	
		
			
				|  |  |  |  | 
 | 
		
	
		
			
				|  |  |  |  |         case DETECT_AL_HTTP_COOKIE: | 
		
	
		
			
				|  |  |  |  |             cd = (DetectContentData *)pm->ctx; | 
		
	
		
			
				|  |  |  |  |             if (cd->flags & DETECT_CONTENT_NEGATED) { | 
		
	
		
			
				|  |  |  |  |                 if (cd->flags & DETECT_CONTENT_FAST_PATTERN) { | 
		
	
		
			
				|  |  |  |  |                     SCLogError(SC_ERR_INVALID_SIGNATURE, "You can't have a relative " | 
		
	
		
			
				|  |  |  |  |                                "negated keyword set along with a fast_pattern"); | 
		
	
		
			
				|  |  |  |  |                     goto error; | 
		
	
		
			
				|  |  |  |  |                 } | 
		
	
		
			
				|  |  |  |  |             } else { | 
		
	
		
			
				|  |  |  |  |                 if (cd->flags & DETECT_CONTENT_FAST_PATTERN_ONLY) { | 
		
	
		
			
				|  |  |  |  |                     SCLogError(SC_ERR_INVALID_SIGNATURE, "You can't have a relative " | 
		
	
		
			
				|  |  |  |  |                                "keyword set along with a fast_pattern:only;"); | 
		
	
		
			
				|  |  |  |  |                     goto error; | 
		
	
		
			
				|  |  |  |  |                 } | 
		
	
		
			
				|  |  |  |  |             } | 
		
	
		
			
				|  |  |  |  | 
 | 
		
	
		
			
				|  |  |  |  |             if (str[0] != '-' && isalpha(str[0])) { | 
		
	
		
			
				|  |  |  |  |                 SigMatch *bed_sm = | 
		
	
		
			
				|  |  |  |  |                     DetectByteExtractRetrieveSMVar(str, s, | 
		
	
		
			
				|  |  |  |  |                                                    SigMatchListSMBelongsTo(s, pm)); | 
		
	
		
			
				|  |  |  |  |                 if (bed_sm == NULL) { | 
		
	
		
			
				|  |  |  |  |                     SCLogError(SC_ERR_INVALID_SIGNATURE, "Unknown byte_extract var " | 
		
	
		
			
				|  |  |  |  |                                "seen in within - %s\n", str); | 
		
	
		
			
				|  |  |  |  |                     goto error; | 
		
	
		
			
				|  |  |  |  |                 } | 
		
	
		
			
				|  |  |  |  |                 cd->within = ((DetectByteExtractData *)bed_sm->ctx)->local_id; | 
		
	
		
			
				|  |  |  |  |                 cd->flags |= DETECT_CONTENT_WITHIN_BE; | 
		
	
		
			
				|  |  |  |  |             } else { | 
		
	
		
			
				|  |  |  |  |                 cd->within = strtol(str, NULL, 10); | 
		
	
		
			
				|  |  |  |  |                 if (cd->within < (int32_t)cd->content_len) { | 
		
	
		
			
				|  |  |  |  |                     SCLogError(SC_ERR_WITHIN_INVALID, "within argument \"%"PRIi32"\" is " | 
		
	
		
			
				|  |  |  |  |                                "less than the content length \"%"PRIu32"\" which is invalid, since " | 
		
	
		
			
				|  |  |  |  |                                "this will never match.  Invalidating signature", cd->within, | 
		
	
		
			
				|  |  |  |  |                                cd->content_len); | 
		
	
		
			
				|  |  |  |  |                     goto error; | 
		
	
		
			
				|  |  |  |  |                 } | 
		
	
		
			
				|  |  |  |  |             } | 
		
	
		
			
				|  |  |  |  | 
 | 
		
	
		
			
				|  |  |  |  |             cd->flags |= DETECT_CONTENT_WITHIN; | 
		
	
		
			
				|  |  |  |  | 
 | 
		
	
		
			
				|  |  |  |  |             /* reassigning pm */ | 
		
	
		
			
				|  |  |  |  |             pm = SigMatchGetLastSMFromLists(s, 4, | 
		
	
		
			
				|  |  |  |  |                                             DETECT_AL_HTTP_COOKIE, pm->prev, | 
		
	
		
			
				|  |  |  |  |                                             DETECT_PCRE, pm->prev); | 
		
	
		
			
				|  |  |  |  |             if (pm == NULL) { | 
		
	
		
			
				|  |  |  |  |                 SCLogError(SC_ERR_DISTANCE_MISSING_CONTENT, "distance for http_cookie " | 
		
	
		
			
				|  |  |  |  |                            "needs preceeding http_cookie content"); | 
		
	
		
			
				|  |  |  |  |                 goto error; | 
		
	
		
			
				|  |  |  |  |             } | 
		
	
		
			
				|  |  |  |  | 
 | 
		
	
		
			
				|  |  |  |  |             if (pm->type == DETECT_PCRE) { | 
		
	
		
			
				|  |  |  |  |                 DetectPcreData *tmp_pd = (DetectPcreData *)pm->ctx; | 
		
	
		
			
				|  |  |  |  |                 tmp_pd->flags |=  DETECT_PCRE_RELATIVE_NEXT; | 
		
	
		
			
				|  |  |  |  |             } else { | 
		
	
		
			
				|  |  |  |  |                 /* reassigning cd */ | 
		
	
		
			
				|  |  |  |  |                 cd = (DetectContentData *)pm->ctx; | 
		
	
		
			
				|  |  |  |  |                 if (cd->flags & DETECT_CONTENT_FAST_PATTERN_ONLY) { | 
		
	
		
			
				|  |  |  |  |                     SCLogError(SC_ERR_INVALID_SIGNATURE, "Previous keyword " | 
		
	
		
			
				|  |  |  |  |                                "has a fast_pattern:only; set.  You can't " | 
		
	
		
			
				|  |  |  |  |                                "have relative keywords around a fast_pattern " | 
		
	
		
			
				|  |  |  |  |                                "only content"); | 
		
	
		
			
				|  |  |  |  |                     goto error; | 
		
	
		
			
				|  |  |  |  |                 } | 
		
	
		
			
				|  |  |  |  |                 cd->flags |= DETECT_CONTENT_RELATIVE_NEXT; | 
		
	
		
			
				|  |  |  |  |             } | 
		
	
		
			
				|  |  |  |  | 
 | 
		
	
		
			
				|  |  |  |  |             break; | 
		
	
		
			
				|  |  |  |  | 
 | 
		
	
		
			
				|  |  |  |  |         case DETECT_AL_HTTP_RAW_URI: | 
		
	
		
			
				|  |  |  |  |             cd = (DetectContentData *)pm->ctx; | 
		
	
		
			
				|  |  |  |  |             if (cd->flags & DETECT_CONTENT_NEGATED) { | 
		
	
	
		
			
				
					|  |  |  | 
 |