]> git.ipfire.org Git - thirdparty/suricata.git/commitdiff
detect: implement http_content_type sticky buffer
authorVictor Julien <victor@inliniac.net>
Sat, 1 Apr 2017 21:28:12 +0000 (23:28 +0200)
committerVictor Julien <victor@inliniac.net>
Thu, 20 Apr 2017 15:41:11 +0000 (17:41 +0200)
src/Makefile.am
src/detect-http-content-type.c [new file with mode: 0644]
src/detect-http-content-type.h [new file with mode: 0644]
src/detect-http-headers.c
src/detect.h

index 7d30e666ac4df48cc4ffee8ec9c3958bf4faa2e9..94eafcd7a14ca231f8b3160ecc54fdb2bcb43469 100644 (file)
@@ -168,6 +168,7 @@ detect-http-accept-enc.c detect-http-accept-enc.h \
 detect-http-accept-lang.c detect-http-accept-lang.h \
 detect-http-client-body.c detect-http-client-body.h \
 detect-http-connection.c detect-http-connection.h \
+detect-http-content-type.c detect-http-content-type.h \
 detect-http-cookie.c detect-http-cookie.h \
 detect-http-header.c detect-http-header.h \
 detect-http-headers.c detect-http-headers.h detect-http-headers-stub.h \
diff --git a/src/detect-http-content-type.c b/src/detect-http-content-type.c
new file mode 100644 (file)
index 0000000..5ca85b6
--- /dev/null
@@ -0,0 +1,47 @@
+/* Copyright (C) 2007-2017 Open Information Security Foundation
+ *
+ * You can copy, redistribute or modify this Program under the terms of
+ * the GNU General Public License version 2 as published by the Free
+ * Software Foundation.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * version 2 along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
+ * 02110-1301, USA.
+ */
+
+/**
+ * \ingroup httplayer
+ *
+ * @{
+ */
+
+
+/**
+ * \file
+ *
+ * \author Victor Julien <victor@inliniac.net>
+ *
+ * Implement http_content_type sticky buffer
+ */
+
+#define KEYWORD_NAME "http_content_type"
+#define KEYWORD_DOC "http-keywords#http-content-type"
+#define BUFFER_NAME "http_content_type"
+#define BUFFER_DESC "http content type header"
+#define HEADER_NAME "Content-Type"
+#define KEYWORD_ID DETECT_AL_HTTP_HEADER_CONTENT_TYPE
+#define KEYWORD_TOSERVER 1
+#define KEYWORD_TOCLIENT 1
+
+#include "detect-http-headers-stub.h"
+
+void RegisterHttpHeadersContentType(void)
+{
+    DetectHttpHeadersRegisterStub();
+}
diff --git a/src/detect-http-content-type.h b/src/detect-http-content-type.h
new file mode 100644 (file)
index 0000000..291b275
--- /dev/null
@@ -0,0 +1,23 @@
+/* Copyright (C) 2007-2017 Open Information Security Foundation
+ *
+ * You can copy, redistribute or modify this Program under the terms of
+ * the GNU General Public License version 2 as published by the Free
+ * Software Foundation.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * version 2 along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
+ * 02110-1301, USA.
+ */
+
+#ifndef __DETECT_HTTP_CONTENT_TYPE_H__
+#define __DETECT_HTTP_CONTENT_TYPE_H__
+
+void RegisterHttpHeadersContentType(void);
+
+#endif /* __DETECT_HTTP_CONTENT_TYPE_H__ */
index c1bde84a911e423c4eac016cfe4d12fe5080c631..2b8c769a60e4ab5c04d303b8347bff4bb47ada35 100644 (file)
@@ -19,6 +19,7 @@
 #include "detect-http-accept-enc.h"
 #include "detect-http-accept-lang.h"
 #include "detect-http-connection.h"
+#include "detect-http-content-type.h"
 #include "detect-http-referer.h"
 
 void DetectHttpHeadersRegister(void)
@@ -28,4 +29,5 @@ void DetectHttpHeadersRegister(void)
     RegisterHttpHeadersAcceptLang();
     RegisterHttpHeadersReferer();
     RegisterHttpHeadersConnection();
+    RegisterHttpHeadersContentType();
 }
index 6a30a575efb90e6827b515d00bd755c463893ae8..783ac476c2d11efa0a7d29df729a47cf2543bdd2 100644 (file)
@@ -1245,6 +1245,7 @@ enum {
     DETECT_AL_HTTP_HEADER_ACCEPT_LANG,
     DETECT_AL_HTTP_HEADER_ACCEPT_ENC,
     DETECT_AL_HTTP_HEADER_CONNECTION,
+    DETECT_AL_HTTP_HEADER_CONTENT_TYPE,
     DETECT_AL_HTTP_HEADER_REFERER,
     DETECT_AL_HTTP_RAW_HEADER,
     DETECT_AL_HTTP_URI,