Go to the documentation of this file.
267 static void PrintFeatureList(
const SigTableElmt *e,
char sep)
279 printf(
"compatible with IP only rule");
285 printf(
"compatible with decoder event only rule");
291 printf(
"content modifier");
297 printf(
"sticky buffer");
303 printf(
"supports firewall");
309 printf(
"multi buffer");
338 printf(
"banned from firewall rules");
344 printf(
"banned from firewall mode");
364 static void SigMultilinePrint(
size_t i,
const char *prefix)
369 printf(
"%sFeatures: ", prefix);
386 if (
name == NULL || strlen(
name) == 0) {
390 if (strcmp(keyword,
name) == 0) {
403 if (keyword == NULL) {
404 printf(
"=====Supported keywords=====\n");
405 for (i = 0; i < size; i++) {
407 if (
name != NULL && strlen(
name) > 0) {
408 if (
name[0] ==
'_' || strcmp(
name,
"template") == 0)
411 printf(
"- %s\n",
name);
414 }
else if (strcmp(
"csv", keyword) == 0) {
415 printf(
"name;description;app layer;features;documentation\n");
416 for (i = 0; i < size; i++) {
418 if (
name != NULL && strlen(
name) > 0) {
419 if (
name[0] ==
'_' || strcmp(
name,
"template") == 0)
437 }
else if (strcmp(
"all", keyword) == 0) {
438 for (i = 0; i < size; i++) {
440 if (
name != NULL && strlen(
name) > 0) {
441 if (
name[0] ==
'_' || strcmp(
name,
"template") == 0)
444 SigMultilinePrint(i,
"\t");
448 for (i = 0; i < size; i++) {
452 SigMultilinePrint(i,
"");
456 printf(
"Non existing keyword\n");
462 static void DetectFileHandlerRegister(
void)
472 SCSigTableNamesElmt kw;
474 kw.name = (
char *)base->
name;
475 kw.desc = (
char *)base->
desc;
476 kw.url = (
char *)base->
url;
477 SCDetectSigMatchNamesFree(&kw);
500 #define ARRAY_CAP_STEP 16
501 static void (**PreregisteredCallbacks)(void) = NULL;
502 static size_t preregistered_callbacks_nb = 0;
503 static size_t preregistered_callbacks_cap = 0;
511 if (preregistered_callbacks_nb == preregistered_callbacks_cap) {
512 void *tmp =
SCRealloc(PreregisteredCallbacks,
518 PreregisteredCallbacks = tmp;
520 PreregisteredCallbacks[preregistered_callbacks_nb] = KeywordsRegister;
521 preregistered_callbacks_nb++;
532 FatalError(
"Could not allocate sigmatch_table");
688 SCDetectNfsProcedureRegister();
729 DetectTransformCompressWhitespaceRegister();
730 DetectTransformStripWhitespaceRegister();
731 DetectTransformStripPseudoHeadersRegister();
732 DetectTransformMd5Register();
733 DetectTransformSha1Register();
734 DetectTransformSha256Register();
735 DetectTransformDotPrefixRegister();
737 DetectTransformUrlDecodeRegister();
738 DetectTransformXorRegister();
739 DetectTransformToLowerRegister();
740 DetectTransformToUpperRegister();
741 DetectTransformHeaderLowercaseRegister();
742 DetectTransformFromBase64DecodeRegister();
743 SCDetectTransformDomainRegister();
745 DetectTransformGunzipRegister();
746 DetectTransformZlibDeflateRegister();
747 DetectTransformSubsliceRegister();
749 DetectFileHandlerRegister();
757 SCDetectDHCPRegister();
758 SCDetectWebsocketRegister();
759 SCDetectEnipRegister();
760 SCDetectMqttRegister();
761 SCDetectRfbRegister();
762 SCDetectSipRegister();
763 SCDetectTemplateRegister();
764 SCDetectLdapRegister();
765 SCDetectSdpRegister();
766 SCDetectDNSRegister();
767 SCDetectPgsqlRegister();
768 SCDetectSshRegister();
769 SCDetectQuicRegister();
770 SCDetectSmbRegister();
771 SCDetectIkeRegister();
772 SCDetectDcerpcRegister();
773 SCDetectKrb5Register();
775 for (
size_t i = 0; i < preregistered_callbacks_nb; i++) {
776 PreregisteredCallbacks[i]();
793 SCLogDebug(
"detection plugin %s has no unittest "
798 "registration function.",
void DetectFtpReplyReceivedRegister(void)
Registration function for ftp.reply_received: keyword.
void DetectEmailRegister(void)
void DetectFtpCommandDataRegister(void)
void DetectFragBitsRegister(void)
Registration function for fragbits: keyword.
void DetectHttpHHRegister(void)
Registers the keyword handlers for the "http_host" keyword.
void DetectITypeRegister(void)
Registration function for itype: keyword.
void DetectAppLayerEventRegister(void)
Registers the keyword handlers for the "app-layer-event" keyword.
void DetectDsizeRegister(void)
Registration function for dsize: keyword.
void DetectFlowBytesRegister(void)
void DetectMsgRegister(void)
void DetectTlsJa3HashRegister(void)
Registration function for keyword: ja3_hash.
void DetectTemplateRegister(void)
Registration function for template: keyword.
#define SIGMATCH_INFO_MULTI_UINT
void DetectGeoipRegister(void)
Registration function for geoip keyword (no libgeoip support)
void DetectNfsVersionRegister(void)
Registration function for nfs_procedure keyword.
void DetectFtpCommandRegister(void)
void DetectXbitsRegister(void)
void DetectTlsJa3SHashRegister(void)
Registration function for keyword: ja3s.hash.
void DetectRevRegister(void)
bool SCSigTableHasKeyword(const char *keyword)
Check if a keyword exists.
SigTableElmt * sigmatch_table
void DetectConfigRegister(void)
Registers the "config" keyword for detection.
void DetectTcpmssRegister(void)
Registration function for tcpmss: keyword.
void DetectTlsSerialRegister(void)
Registration function for keyword: tls.cert_serial.
void DetectSidRegister(void)
#define SIGMATCH_BAN_FIREWALL_RULE
void DetectTlsFingerprintRegister(void)
Registration function for keyword: tls.cert_fingerprint.
void DetectHttpServerBodyRegister(void)
Registers the keyword handlers for the "http_server_body" keyword.
void DetectHttpStartRegister(void)
Registers the keyword handlers for the "http_start" keyword.
void DetectDNP3Register(void)
void DetectHttpUriRegister(void)
Registration function for keywords: http_uri and http.uri.
void DetectGidRegister(void)
Registration function for gid: keyword.
void DetectIPProtoRegister(void)
Registration function for ip_proto keyword.
void DetectFlowElephantRegister(void)
void DetectICMPv6hdrRegister(void)
Registration function for icmpv6.hdr: keyword.
void DetectTlsJa3StringRegister(void)
Registration function for keyword: ja3.string.
void DetectTlsRandomRegister(void)
Registration function for keyword: tls.random.
void DetectFtpReplyRegister(void)
void DetectPriorityRegister(void)
Registers the handler functions for the "priority" keyword.
#define SIGMATCH_INFO_UINT8
void DetectFilesizeRegister(void)
Registration function for filesize: keyword.
void DetectHttpProtocolRegister(void)
Registers the keyword handlers for the "http.protocol" keyword.
void DetectFragOffsetRegister(void)
Registration function for fragoffset.
void DetectRpcRegister(void)
Registration function for rpc keyword.
void DetectVlanLayersRegister(void)
void DetectSameipRegister(void)
Registration function for sameip: keyword.
void DetectIcmpv4HdrRegister(void)
Registration function for icmpv4.hdr: keyword.
void DetectTcphdrRegister(void)
Registration function for tcp.hdr: keyword.
void DetectFlowBytesToClientRegister(void)
void DetectDatarepRegister(void)
void DetectFlowBytesToServerRegister(void)
void DetectSCTPChunkTypeRegister(void)
void DetectHostbitsRegister(void)
void DetectRegisterAppLayerHookLists(void)
register app hooks as generic lists
void DetectTlsValidityRegister(void)
Registration function for tls validity keywords.
void DetectIpOptsRegister(void)
Registration function for ipopts: keyword.
void DetectUricontentRegister(void)
Registration function for uricontent: keyword.
element in sigmatch type table.
void DetectFlowPktsRegister(void)
int SCSigTablePreRegister(void(*KeywordsRegister)(void))
void DetectFilemagicRegister(void)
Registration function for keyword: filemagic.
void DetectTlsSniRegister(void)
Registration function for keyword: tls.sni.
void DetectTargetRegister(void)
Registration function for target keyword.
void DetectHttpCookieRegister(void)
Registration function for keyword: http_cookie.
void DetectBufferTypeCloseRegistration(void)
#define SIGMATCH_BAN_FIREWALL_MODE
void SigTableRegisterTests(void)
void DetectSeqRegister(void)
Registration function for ack: keyword.
void DetectAsn1Register(void)
Registration function for asn1.
void DetectFlowAgeRegister(void)
void DetectBsizeRegister(void)
Registration function for bsize: keyword.
#define SIGMATCH_INFO_MULTI_BUFFER
void DetectFlowPktsToClientRegister(void)
void DetectBytejumpRegister(void)
void DetectICMPv6mtuRegister(void)
Registration function for icmpv6.mtu: keyword.
void SigTableCleanup(void)
#define SIGMATCH_INFO_UINT16
void DetectTlsVersionRegister(void)
Registration function for keyword: tls.version.
void DetectReplaceRegister(void)
void DetectICodeRegister(void)
Registration function for icode: keyword.
void DetectWindowRegister(void)
Registration function for window: keyword.
void DetectL3ProtoRegister(void)
Registration function for ip_proto keyword.
void SCDetectSMTPRegister(void)
void DetectWithinRegister(void)
void DetectContentRegister(void)
void(* Cleanup)(struct SigTableElmt_ *)
void DetectIcmpIdRegister(void)
Registration function for icode: icmp_id.
void DetectSslStateRegister(void)
Registers the keyword handlers for the "ssl_state" keyword.
void DetectLuaRegister(void)
Registration function for keyword: lua.
#define SIGMATCH_INFO_UINT64
void DetectDnsNameRegister(void)
void DetectFiledataRegister(void)
Registration function for keyword: file_data.
void DetectIpv6hdrRegister(void)
Registration function for ipv6.hdr: keyword.
void DetectIcmpSeqRegister(void)
Registration function for icmp_seq.
void DetectIdRegister(void)
Registration function for keyword: id.
void DetectHttpUARegister(void)
Registers the keyword handlers for the "http_user_agent" keyword.
#define SCLogWarning(...)
Macro used to log WARNING messages.
void DetectFlowPktsToServerRegister(void)
void DetectTcpWscaleRegister(void)
Registration function for tcp.wscale keyword.
void DetectPktDataRegister(void)
Registration function for keyword: file_data.
void DetectRequiresRegister(void)
void DetectFlowbitsRegister(void)
#define SIGMATCH_INFO_CONTENT_MODIFIER
void DetectDatasetRegister(void)
#define SIGMATCH_IPONLY_COMPAT
void DetectUdphdrRegister(void)
Registration function for udp.hdr: keyword.
void DetectBytetestRegister(void)
void DetectTlsSubjectAltNameRegister(void)
Registration function for keyword: tls.subjectaltname.
void DetectDepthRegister(void)
void DetectSipMethodRegister(void)
Data structures and function prototypes for keeping state for the detection engine.
void DetectMarkRegister(void)
Registration function for nfq_set_mark: keyword.
void DetectReferenceRegister(void)
Registration function for the reference: keyword.
void DetectFileSha256Register(void)
Registration function for keyword: filesha256.
void DetectPrefilterRegister(void)
void DetectTlsCertsRegister(void)
Registration function for keyword: tls.certs.
void DetectFtpbounceRegister(void)
Registration function for ftpbounce: keyword.
void DetectSCTPHdrRegister(void)
void DetectFtpCompletionCodeRegister(void)
#define SIGMATCH_DEONLY_COMPAT
void DetectOffsetRegister(void)
void SCDetectHelperKeywordSetCleanCString(uint16_t id)
#define SCRealloc(ptr, sz)
void DetectSipUriRegister(void)
void DetectBypassRegister(void)
Registration function for keyword: bypass.
void DetectAckRegister(void)
Registration function for ack: keyword.
void DetectFilestoreRegister(void)
Registration function for keyword: filestore.
void DetectSCTPChunkDataRegister(void)
void DetectAppLayerStateRegister(void)
void DetectTlsRegister(void)
Registration function for keyword: tls.version.
void DetectTagRegister(void)
Registration function for keyword tag.
void DetectHttpResponseLineRegister(void)
Registers the keyword handlers for the "http_response_line" keyword.
void DetectTlsIssuerRegister(void)
Registration function for keyword: tls.cert_issuer.
void DetectBase64DataRegister(void)
void DetectHttpStatCodeRegister(void)
Registration function for keyword: http_stat_code.
void DetectSCTPVtagRegister(void)
#define DETECT_TBLSIZE_STEP
void DetectTlsAlpnRegister(void)
Registration function for keyword: tls.alpn.
void DetectHttpClientBodyRegister(void)
Registers the keyword handlers for the "http_client_body" keyword.
void DetectCsumRegister(void)
Registers handlers for all the checksum keywords. The checksum keywords that are registered are ipv4-...
void DetectUrilenRegister(void)
Registration function for urilen: keyword.
void DetectFtpDynamicPortRegister(void)
void DetectIGMPTypeRegister(void)
Registration function for igmp.type keyword.
void DetectHttp2Register(void)
Registration function for HTTP2 keywords.
void DetectIpv4hdrRegister(void)
Registration function for ipv4.hdr: keyword.
void DetectHttpRequestLineRegister(void)
Registers the keyword handlers for the "http_request_line" keyword.
void DetectFileSha1Register(void)
Registration function for keyword: filesha1.
void DetectFlowRegister(void)
Registration function for flow: keyword.
void DetectRawbytesRegister(void)
void DetectEntropyRegister(void)
void DetectTosRegister(void)
Register Tos keyword.
void DetectBytemathRegister(void)
Registers the keyword handlers for the "byte_math" keyword.
#define SIGMATCH_INFO_ENUM_UINT
void DetectEngineEventRegister(void)
Registration function for decode-event: keyword.
#define SIGMATCH_INFO_BITFLAGS_UINT
void DetectFlagsRegister(void)
Registration function for flags: keyword.
void DetectFlowvarRegister(void)
void DetectNoalertRegister(void)
bool(* SupportsPrefilter)(const Signature *s)
#define SIGMATCH_INFO_UINT32
void DetectStreamSizeRegister(void)
Registration function for stream_size: keyword.
void DetectDetectionFilterRegister(void)
Registration function for detection_filter: keyword.
void DetectSCTPChunkCntRegister(void)
void DetectDistanceRegister(void)
void DetectTlsJa3SStringRegister(void)
Registration function for keyword: ja3s.string.
void DetectThresholdRegister(void)
Registration function for threshold: keyword.
#define SIGMATCH_INFO_STICKY_BUFFER
void DetectFlowintRegister(void)
void DetectAppLayerProtocolRegister(void)
void DetectTlsCertChainLenRegister(void)
#define SIGMATCH_SUPPORT_FIREWALL
void DetectIPAddrBufferRegister(void)
const char * GetDocURL(void)
void DetectFastPatternRegister(void)
Registration function for fast_pattern keyword.
void DetectHttpStatMsgRegister(void)
Registration function for keyword: http_stat_msg.
void DetectVlanIdRegister(void)
void DetectPktvarRegister(void)
void DetectSslVersionRegister(void)
Registration function for keyword: ssl_version.
void DetectModbusRegister(void)
Registration function for Modbus keyword.
void DetectDnsResponseRegister(void)
void DetectFtpModeRegister(void)
void DetectNocaseRegister(void)
void DetectJa4HashRegister(void)
Registration function for keyword: ja4.hash.
void DetectIGMPHdrRegister(void)
Registration function for igmp.hdr: keyword.
void DetectBase64DecodeRegister(void)
void DetectFilenameRegister(void)
Registration function for keyword: filename.
void DetectIPRepRegister(void)
void(* Transform)(DetectEngineThreadCtx *, InspectionBuffer *, const void *context)
void DetectFileRegisterFileProtocols(DetectFileHandlerTableElmt *reg)
void DetectFtpdataRegister(void)
Registration function for ftpcommand: keyword.
void DetectHttpMethodRegister(void)
Registration function for keyword: http_method.
void DetectTtlRegister(void)
Registration function for ttl: keyword.
void DetectTlsSubjectRegister(void)
Registration function for keyword: tls.cert_subject.
void DetectPcreRegister(void)
DetectFileHandlerTableElmt filehandler_table[DETECT_TBLSIZE_STATIC]
void DetectClasstypeRegister(void)
Registers the handler functions for the "Classtype" keyword.
#define DEBUG_VALIDATE_BUG_ON(exp)
int SigTableList(const char *keyword)
void(* RegisterTests)(void)
void DetectIsdataatRegister(void)
Registration function for isdataat: keyword.
void DetectEtherhdrRegister(void)
Registration function for ether.hdr: keyword.
void DetectFileMd5Register(void)
Registration function for keyword: filemd5.
void DetectFrameRegister(void)
Registration function for keyword: ja3_hash.