Go to the documentation of this file.
60 static void IPRepRegisterTests(
void);
78 static inline uint8_t GetRep(
const SReputation *r,
const uint8_t cat,
const uint32_t
version)
88 static uint8_t GetHostRepSrc(
Packet *p, uint8_t cat, uint32_t
version)
115 static uint8_t GetHostRepDst(
Packet *p, uint8_t cat, uint32_t
version)
150 const DetectIPRepData *rd = (
const DetectIPRepData *)ctx;
160 val = GetHostRepSrc(p, rd->cat,
version);
167 val = GetHostRepDst(p, rd->cat,
version);
176 val = GetHostRepSrc(p, rd->cat,
version);
177 SCLogDebug(
"checking src -- val %u (looking for cat %u, val %u)", val, rd->cat,
188 val = GetHostRepDst(p, rd->cat,
version);
197 val = GetHostRepSrc(p, rd->cat,
version);
202 val = GetHostRepDst(p, rd->cat,
version);
218 DetectIPRepData *cd = rs_detect_iprep_parse(rawstr);
220 SCLogError(
"\"%s\" is not a valid setting for iprep", rawstr);
224 SCLogDebug(
"cmd %u, cat %u, op %u, val %u", cd->cmd, cd->cat, cd->du8.mode, cd->du8.arg1);
249 DetectIPRepData *fd = (DetectIPRepData *)ptr;
254 rs_detect_iprep_free(fd);
261 static FILE *DetectIPRepGenerateCategoriesDummy(
void)
264 const char *buffer =
"1,BadHosts,Know bad hosts";
266 fd =
SCFmemopen((
void *)buffer, strlen(buffer),
"r");
273 static FILE *DetectIPRepGenerateCategoriesDummy2(
void)
277 "1,BadHosts,Know bad hosts\n"
278 "2,GoodHosts,Know good hosts\n";
280 fd =
SCFmemopen((
void *)buffer, strlen(buffer),
"r");
287 static FILE *DetectIPRepGenerateNetworksDummy(
void)
290 const char *buffer =
"10.0.0.0/24,1,20";
292 fd =
SCFmemopen((
void *)buffer, strlen(buffer),
"r");
299 static FILE *DetectIPRepGenerateNetworksDummy2(
void)
304 "192.168.0.0/16,2,127";
306 fd =
SCFmemopen((
void *)buffer, strlen(buffer),
"r");
313 static int DetectIPRepTest01(
void)
324 memset(&th_v, 0,
sizeof(th_v));
335 fd = DetectIPRepGenerateCategoriesDummy();
339 fd = DetectIPRepGenerateNetworksDummy();
344 "badhost\"; iprep:any,BadHosts,>,1; sid:1;rev:1;)");
366 static int DetectIPRepTest02(
void)
377 memset(&th_v, 0,
sizeof(th_v));
388 fd = DetectIPRepGenerateCategoriesDummy();
392 fd = DetectIPRepGenerateNetworksDummy();
397 "badhost\"; iprep:src,BadHosts,>,1; sid:1; rev:1;)");
418 static int DetectIPRepTest03(
void)
429 memset(&th_v, 0,
sizeof(th_v));
440 fd = DetectIPRepGenerateCategoriesDummy();
444 fd = DetectIPRepGenerateNetworksDummy();
449 "badhost\"; iprep:dst,BadHosts,>,1; sid:1; rev:1;)");
470 static int DetectIPRepTest04(
void)
481 memset(&th_v, 0,
sizeof(th_v));
493 fd = DetectIPRepGenerateCategoriesDummy();
497 fd = DetectIPRepGenerateNetworksDummy();
502 "badhost\"; iprep:both,BadHosts,>,1; sid:1; rev:1;)");
523 static int DetectIPRepTest05(
void)
534 memset(&th_v, 0,
sizeof(th_v));
545 fd = DetectIPRepGenerateCategoriesDummy();
549 fd = DetectIPRepGenerateNetworksDummy();
554 "badhost\"; iprep:any,BadHosts,>,1; sid:1; rev:1;)");
575 static int DetectIPRepTest06(
void)
586 memset(&th_v, 0,
sizeof(th_v));
597 fd = DetectIPRepGenerateCategoriesDummy();
601 fd = DetectIPRepGenerateNetworksDummy2();
606 "badhost\"; iprep:any,BadHosts,>,1; sid:1; rev:1;)");
627 static int DetectIPRepTest07(
void)
638 memset(&th_v, 0,
sizeof(th_v));
649 fd = DetectIPRepGenerateCategoriesDummy();
653 fd = DetectIPRepGenerateNetworksDummy2();
658 "badhost\"; iprep:any,BadHosts,>,1; sid:1; rev:1;)");
679 static int DetectIPRepTest08(
void)
690 memset(&th_v, 0,
sizeof(th_v));
702 fd = DetectIPRepGenerateCategoriesDummy();
706 fd = DetectIPRepGenerateNetworksDummy();
711 "badhost\"; iprep:any,BadHosts,>,1; sid:1; rev:1;)");
732 static int DetectIPRepTest09(
void)
743 memset(&th_v, 0,
sizeof(th_v));
755 fd = DetectIPRepGenerateCategoriesDummy2();
759 fd = DetectIPRepGenerateNetworksDummy2();
764 "alert tcp any any -> any any (msg:\"test\"; iprep:src,BadHosts,>,9; sid:1; rev:1;)");
788 void IPRepRegisterTests(
void)
#define FAIL_IF_NULL(expr)
Fail a test if expression evaluates to NULL.
#define PKT_HOST_DST_LOOKED_UP
void SigMatchAppendSMToList(Signature *s, SigMatch *new, const int list)
Append a SigMatch to the list type.
void(* Free)(DetectEngineCtx *, void *)
uint8_t rep[SREP_MAX_CATS]
void UtRegisterTest(const char *name, int(*TestFn)(void))
Register unit test.
void HostRelease(Host *h)
uint32_t UTHSetIPv4Address(const char *str)
return the uint32_t for a ipv4 address string
main detection engine ctx
void DetectEngineCtxFree(DetectEngineCtx *)
Free a DetectEngineCtx::
Packet * UTHBuildPacket(uint8_t *payload, uint16_t payload_len, uint8_t ipproto)
UTHBuildPacket is a wrapper that build packets with default ip and port fields.
void SigMatchSignatures(ThreadVars *tv, DetectEngineCtx *de_ctx, DetectEngineThreadCtx *det_ctx, Packet *p)
wrapper for old tests
Signature * DetectEngineAppendSig(DetectEngineCtx *, const char *)
Parse and append a Signature into the Detection Engine Context signature list.
int(* Setup)(DetectEngineCtx *, Signature *, const char *)
#define PASS
Pass the test.
SRepCIDRTree * srepCIDR_ctx
int SRepLoadCatFileFromFD(FILE *fp)
#define PKT_HOST_SRC_LOOKED_UP
Per thread variable structure.
#define HostReference(dst_h_ptr, h)
Data structures and function prototypes for keeping state for the detection engine.
int(* Match)(DetectEngineThreadCtx *, Packet *, const Signature *, const SigMatchCtx *)
int SRepLoadFileFromFD(SRepCIDRTree *cidr_ctx, FILE *fp)
void DetectIPRepFree(DetectEngineCtx *, void *)
SigMatch * SigMatchAlloc(void)
uint8_t SRepCIDRGetIPRepDst(SRepCIDRTree *cidr_ctx, Packet *p, uint8_t cat, uint32_t version)
int SigGroupBuild(DetectEngineCtx *de_ctx)
Convert the signature list into the runtime match structure.
Used to start a pointer to SigMatch context Should never be dereferenced without casting to something...
int DetectU8Match(const uint8_t parg, const DetectUintData_u8 *du8)
TmEcode DetectEngineThreadCtxInit(ThreadVars *, void *, void **)
initialize thread specific detection engine context
#define FAIL_IF(expr)
Fail a test if expression evaluates to true.
TmEcode DetectEngineThreadCtxDeinit(ThreadVars *, void *)
SigTableElmt sigmatch_table[DETECT_TBLSIZE]
void HostShutdown(void)
shutdown the flow engine
#define SCLogError(...)
Macro used to log ERROR messages.
int SRepInit(DetectEngineCtx *de_ctx)
init reputation
void UTHFreePacket(Packet *p)
UTHFreePacket: function to release the allocated data from UTHBuildPacket and the packet itself.
a single match condition for a signature
void SRepResetVersion(void)
DetectEngineCtx * DetectEngineCtxInit(void)
Host * HostLookupHostFromHash(Address *a)
look up a host in the hash
void HostInitConfig(bool quiet)
initialize the configuration
#define SC_ATOMIC_GET(name)
Get the value from the atomic variable.
void DetectIPRepRegister(void)
#define SIGMATCH_IPONLY_COMPAT
#define DEBUG_VALIDATE_BUG_ON(exp)
uint8_t SRepCIDRGetIPRepSrc(SRepCIDRTree *cidr_ctx, Packet *p, uint8_t cat, uint32_t version)
void(* RegisterTests)(void)