mirror of https://github.com/OISF/suricata
detect: implement http {location,server} sticky buffer
This implements inspection of the Server and Location buffer as a content sticky buffer.pull/3746/head
parent
081fdc6804
commit
81c1af0887
@ -0,0 +1,50 @@
|
||||
/* Copyright (C) 2007-2019 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 Jeff Lucovsky <jeff@lucovsky.org>
|
||||
*
|
||||
* Implements http.location sticky buffer
|
||||
*
|
||||
* "Location" is an HTTP response-header field used to redirect the recipient to
|
||||
* a location other than the Request-URI for request completion.
|
||||
*/
|
||||
|
||||
#define KEYWORD_NAME "http.location"
|
||||
#define KEYWORD_DOC "http-keywords.html#http-location"
|
||||
#define BUFFER_NAME "http.location"
|
||||
#define BUFFER_DESC "http location header"
|
||||
#define HEADER_NAME "Location"
|
||||
#define KEYWORD_ID DETECT_AL_HTTP_HEADER_LOCATION
|
||||
#define KEYWORD_TOCLIENT 1
|
||||
|
||||
#include "detect-http-headers-stub.h"
|
||||
#include "detect-http-location.h"
|
||||
|
||||
void RegisterHttpHeadersLocation(void)
|
||||
{
|
||||
DetectHttpHeadersRegisterStub();
|
||||
}
|
||||
@ -0,0 +1,23 @@
|
||||
/* Copyright (C) 2007-2019 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_LOCATION_H__
|
||||
#define __DETECT_HTTP_LOCATION_H__
|
||||
|
||||
void RegisterHttpHeadersLocation(void);
|
||||
|
||||
#endif /* __DETECT_HTTP_LOCATION_H__ */
|
||||
@ -0,0 +1,50 @@
|
||||
/* Copyright (C) 2007-2019 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 Jeff Lucovsky <jeff@lucovsky.org>
|
||||
*
|
||||
* Implements http.server sticky buffer
|
||||
*
|
||||
* "Server" is an HTTP response-header field containing information about the software
|
||||
* used by the origin server to handle the request.
|
||||
*/
|
||||
|
||||
#define KEYWORD_NAME "http.server"
|
||||
#define KEYWORD_DOC "http-keywords.html#http-server"
|
||||
#define BUFFER_NAME "http.server"
|
||||
#define BUFFER_DESC "http server header"
|
||||
#define HEADER_NAME "Server"
|
||||
#define KEYWORD_ID DETECT_AL_HTTP_HEADER_SERVER
|
||||
#define KEYWORD_TOCLIENT 1
|
||||
|
||||
#include "detect-http-headers-stub.h"
|
||||
#include "detect-http-server.h"
|
||||
|
||||
void RegisterHttpHeadersServer(void)
|
||||
{
|
||||
DetectHttpHeadersRegisterStub();
|
||||
}
|
||||
@ -0,0 +1,23 @@
|
||||
/* Copyright (C) 2007-2019 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_SERVER_H__
|
||||
#define __DETECT_HTTP_SERVER_H__
|
||||
|
||||
void RegisterHttpHeadersServer(void);
|
||||
|
||||
#endif /* __DETECT_HTTP_SERVER_H__ */
|
||||
Loading…
Reference in New Issue