diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-19 17:39:49 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-19 17:39:49 +0000 |
commit | a0aa2307322cd47bbf416810ac0292925e03be87 (patch) | |
tree | 37076262a026c4b48c8a0e84f44ff9187556ca35 /src/util-file.h | |
parent | Initial commit. (diff) | |
download | suricata-a0aa2307322cd47bbf416810ac0292925e03be87.tar.xz suricata-a0aa2307322cd47bbf416810ac0292925e03be87.zip |
Adding upstream version 1:7.0.3.upstream/1%7.0.3
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'src/util-file.h')
-rw-r--r-- | src/util-file.h | 255 |
1 files changed, 255 insertions, 0 deletions
diff --git a/src/util-file.h b/src/util-file.h new file mode 100644 index 0000000..55d9119 --- /dev/null +++ b/src/util-file.h @@ -0,0 +1,255 @@ +/* Copyright (C) 2007-2021 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 Victor Julien <victor@inliniac.net> + * + */ + +#ifndef __UTIL_FILE_H__ +#define __UTIL_FILE_H__ + +#include "conf.h" +#include "util-streaming-buffer.h" +#include "flow.h" + +/* Hack: Pulling rust.h to get the SCSha256 causes all sorts of problems with + * header include orders, which is something we'll have to resolve as we provide + * more functionality via Rust. But this lets me continue with replacing nss + * without fighting the headers at this time. */ +typedef struct SCSha256 SCSha256; +#define SC_SHA256_LEN 32 + +typedef struct SCSha1 SCSha1; +#define SC_SHA1_LEN 20 + +typedef struct SCMd5 SCMd5; +#define SC_MD5_LEN 16 + +#define FILE_TRUNCATED BIT_U16(0) +#define FILE_NOMAGIC BIT_U16(1) +#define FILE_NOMD5 BIT_U16(2) +#define FILE_MD5 BIT_U16(3) +#define FILE_NOSHA1 BIT_U16(4) +#define FILE_SHA1 BIT_U16(5) +#define FILE_NOSHA256 BIT_U16(6) +#define FILE_SHA256 BIT_U16(7) +#define FILE_LOGGED BIT_U16(8) +#define FILE_NOSTORE BIT_U16(9) +#define FILE_STORE BIT_U16(10) +#define FILE_STORED BIT_U16(11) +#define FILE_NOTRACK BIT_U16(12) /**< track size of file */ +#define FILE_USE_DETECT BIT_U16(13) /**< use content_inspected tracker */ +#define FILE_HAS_GAPS BIT_U16(15) + +// to be used instead of PATH_MAX which depends on the OS +#define SC_FILENAME_MAX 4096 + +#define FILEDATA_CONTENT_LIMIT 100000 +#define FILEDATA_CONTENT_INSPECT_MIN_SIZE 32768 +#define FILEDATA_CONTENT_INSPECT_WINDOW 4096 + +typedef enum FileState_ { + FILE_STATE_NONE = 0, /**< no state */ + FILE_STATE_OPENED, /**< flow file is opened */ + FILE_STATE_CLOSED, /**< flow file is completed, + there will be no more data. */ + FILE_STATE_TRUNCATED, /**< flow file is not complete, but + there will be no more data. */ + FILE_STATE_ERROR, /**< file is in an error state */ + FILE_STATE_MAX +} FileState; + +typedef struct File_ { + uint16_t flags; + uint16_t name_len; + FileState state; + StreamingBuffer *sb; + uint32_t file_track_id; /**< id used by protocol parser */ + uint32_t file_store_id; /**< id used in store file name file.<id> */ + int fd; /**< file descriptor for filestore, not + open if equal to -1 */ + uint8_t *name; +#ifdef HAVE_MAGIC + char *magic; +#endif + struct File_ *next; + SCMd5 *md5_ctx; + uint8_t md5[SC_MD5_LEN]; + SCSha1 *sha1_ctx; + uint8_t sha1[SC_SHA1_LEN]; + SCSha256 *sha256_ctx; + uint8_t sha256[SC_SHA256_LEN]; + uint64_t content_inspected; /**< used in pruning if FILE_USE_DETECT + * flag is set */ + uint64_t content_stored; + uint64_t size; + uint32_t inspect_window; + uint32_t inspect_min_size; + uint64_t start; + uint64_t end; + + uint32_t *sid; /* signature id of a rule that triggered the filestore event */ + uint32_t sid_cnt; + uint32_t sid_max; +} File; + +typedef struct FileContainer_ { + File *head; + File *tail; +} FileContainer; + +FileContainer *FileContainerAlloc(void); +void FileContainerFree(FileContainer *, const StreamingBufferConfig *cfg); + +void FileContainerRecycle(FileContainer *, const StreamingBufferConfig *cfg); + +void FileContainerAdd(FileContainer *, File *); + +/** + * \brief Open a new File + * + * \param ffc flow container + * \param sbcfg buffer config + * \param name filename character array + * \param name_len filename len + * \param data initial data + * \param data_len initial data len + * \param flags open flags + * + * \retval ff flowfile object + * + * \note filename is not a string, so it's not nul terminated. + * + * If flags contains the FILE_USE_DETECT bit, the pruning code will + * consider not just the content_stored tracker, but also content_inspected. + * It's the responsibility of the API user to make sure this tracker is + * properly updated. + */ +int FileOpenFileWithId(FileContainer *, const StreamingBufferConfig *, + uint32_t track_id, const uint8_t *name, uint16_t name_len, + const uint8_t *data, uint32_t data_len, uint16_t flags); + +/** + * \brief Close a File + * + * \param ffc the container + * \param data final data if any + * \param data_len data len if any + * \param flags flags + * + * \retval 0 ok + * \retval -1 error + */ +int FileCloseFile(FileContainer *, const StreamingBufferConfig *sbcfg, const uint8_t *data, + uint32_t data_len, uint16_t flags); +int FileCloseFileById(FileContainer *, const StreamingBufferConfig *sbcfg, uint32_t track_id, + const uint8_t *data, uint32_t data_len, uint16_t flags); +int FileCloseFilePtr(File *ff, const StreamingBufferConfig *sbcfg, const uint8_t *data, + uint32_t data_len, uint16_t flags); + +/** + * \brief Store a chunk of file data in the flow. The open "flowfile" + * will be used. + * + * \param ffc the container + * \param data data chunk + * \param data_len data chunk len + * + * \retval 0 ok + * \retval -1 error + */ +int FileAppendData(FileContainer *, const StreamingBufferConfig *sbcfg, const uint8_t *data, + uint32_t data_len); +int FileAppendDataById(FileContainer *, const StreamingBufferConfig *sbcfg, uint32_t track_id, + const uint8_t *data, uint32_t data_len); +int FileAppendGAPById(FileContainer *ffc, const StreamingBufferConfig *sbcfg, uint32_t track_id, + const uint8_t *data, uint32_t data_len); + +void FileSetInspectSizes(File *file, const uint32_t win, const uint32_t min); + +/** + * \brief Sets the offset range for a file. + * + * \param ffc the container + * \param start start offset + * \param end end offset + * + * \retval 0 ok + * \retval -1 error + */ +int FileSetRange(FileContainer *, uint64_t start, uint64_t end); + +/** + * \brief Tag a file for storing + * + * \param ff The file to store + */ +int FileStore(File *); + +/** + * \brief disable file storing for a transaction + * + * \param f flow + * \param direction STREAM_TOSERVER or STREAM_TOCLIENT + * \param tx transaction pointer + * \param tx_id transaction id + */ +void FileDisableStoringForTransaction(Flow *f, const uint8_t direction, void *tx, uint64_t tx_id); + +void FileForceFilestoreEnable(void); +int FileForceFilestore(void); +void FileReassemblyDepthEnable(uint32_t size); +uint32_t FileReassemblyDepth(void); + +void FileForceMagicEnable(void); +int FileForceMagic(void); + +void FileForceMd5Enable(void); +int FileForceMd5(void); + +void FileForceSha1Enable(void); +int FileForceSha1(void); + +void FileForceSha256Enable(void); +int FileForceSha256(void); + +void FileUpdateFlowFileFlags(Flow *f, uint16_t set_file_flags, uint8_t direction); + +void FileForceHashParseCfg(ConfNode *); + +void FileForceTrackingEnable(void); + +void FileStoreFileById(FileContainer *fc, uint32_t); + +uint64_t FileDataSize(const File *file); +uint64_t FileTrackedSize(const File *file); + +uint16_t FileFlowFlagsToFlags(const uint16_t flow_file_flags, uint8_t direction); +uint16_t FileFlowToFlags(const Flow *flow, uint8_t direction); + +#ifdef DEBUG +void FilePrintFlags(const File *file); +#else +#define FilePrintFlags(file) +#endif + +void FilesPrune(FileContainer *fc, const StreamingBufferConfig *sbcfg, const bool trunc); + +#endif /* __UTIL_FILE_H__ */ |