mirror of https://github.com/OISF/suricata
imap: extend detection patterns
Ticket: #2886 Signed-off-by: mmaatuq <mahmoudmatook.mm@gmail.com>pull/11515/head
parent
bce8f4b853
commit
64d18e3cc2
@ -0,0 +1,96 @@
|
|||||||
|
/* Copyright (C) 2024 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \file
|
||||||
|
*
|
||||||
|
* \author Mahmoud Maatuq <mahmoudmatook.mm@gmail.com>
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "app-layer.h"
|
||||||
|
#include "app-layer-detect-proto.h"
|
||||||
|
#include "app-layer-imap.h"
|
||||||
|
|
||||||
|
static int IMAPRegisterPatternsForProtocolDetection(void)
|
||||||
|
{
|
||||||
|
if (AppLayerProtoDetectPMRegisterPatternCI(
|
||||||
|
IPPROTO_TCP, ALPROTO_IMAP, "* OK ", 5, 0, STREAM_TOCLIENT) < 0) {
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (AppLayerProtoDetectPMRegisterPatternCI(
|
||||||
|
IPPROTO_TCP, ALPROTO_IMAP, "* NO ", 5, 0, STREAM_TOCLIENT) < 0) {
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (AppLayerProtoDetectPMRegisterPatternCI(
|
||||||
|
IPPROTO_TCP, ALPROTO_IMAP, "* BAD ", 6, 0, STREAM_TOCLIENT) < 0) {
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (AppLayerProtoDetectPMRegisterPatternCI(
|
||||||
|
IPPROTO_TCP, ALPROTO_IMAP, "* LIST ", 7, 0, STREAM_TOCLIENT) < 0) {
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (AppLayerProtoDetectPMRegisterPatternCI(
|
||||||
|
IPPROTO_TCP, ALPROTO_IMAP, "* ESEARCH ", 10, 0, STREAM_TOCLIENT) < 0) {
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (AppLayerProtoDetectPMRegisterPatternCI(
|
||||||
|
IPPROTO_TCP, ALPROTO_IMAP, "* STATUS ", 9, 0, STREAM_TOCLIENT) < 0) {
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (AppLayerProtoDetectPMRegisterPatternCI(
|
||||||
|
IPPROTO_TCP, ALPROTO_IMAP, "* FLAGS ", 8, 0, STREAM_TOCLIENT) < 0) {
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* there is no official document that limits the length of the tag
|
||||||
|
* some practical implementations limit it to 20 characters
|
||||||
|
* but keeping depth equal to 31 fails unit tests such AppLayerTest10
|
||||||
|
* so keeping depth 17 for now to pass unit tests, that might miss some detections
|
||||||
|
* until we find a better solution for the unit tests.
|
||||||
|
*
|
||||||
|
* AppLayerTest10 fails because it expects protocol detection to be completed with only 17 bytes
|
||||||
|
* as input, and with this new pattern, we would need more bytes to finish protocol detection.
|
||||||
|
*/
|
||||||
|
if (AppLayerProtoDetectPMRegisterPatternCI(IPPROTO_TCP, ALPROTO_IMAP, " CAPABILITY",
|
||||||
|
17 /*6 for max tag len + space + len(CAPABILITY)*/, 0, STREAM_TOSERVER) < 0) {
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
void RegisterIMAPParsers(void)
|
||||||
|
{
|
||||||
|
const char *proto_name = "imap";
|
||||||
|
|
||||||
|
if (AppLayerProtoDetectConfProtoDetectionEnabled("tcp", proto_name)) {
|
||||||
|
SCLogDebug("IMAP protocol detection is enabled.");
|
||||||
|
AppLayerProtoDetectRegisterProtocol(ALPROTO_IMAP, proto_name);
|
||||||
|
if (IMAPRegisterPatternsForProtocolDetection() < 0)
|
||||||
|
SCLogError("Failed to register IMAP protocol detection patterns.");
|
||||||
|
} else {
|
||||||
|
SCLogDebug("Protocol detector and parser disabled for IMAP.");
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,28 @@
|
|||||||
|
/* Copyright (C) 2024 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \file
|
||||||
|
*
|
||||||
|
* \author Mahmoud Maatuq <mahmoudmatook.mm@gmail.com>
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef SURICATA_APP_LAYER_IMAP_H
|
||||||
|
#define SURICATA_APP_LAYER_IMAP_H
|
||||||
|
void RegisterIMAPParsers(void);
|
||||||
|
#endif
|
Loading…
Reference in New Issue