suricata
output-json-email-common.h
Go to the documentation of this file.
1 /* Copyright (C) 2007-2014 Open Information Security Foundation
2  *
3  * You can copy, redistribute or modify this Program under the terms of
4  * the GNU General Public License version 2 as published by the Free
5  * Software Foundation.
6  *
7  * This program is distributed in the hope that it will be useful,
8  * but WITHOUT ANY WARRANTY; without even the implied warranty of
9  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
10  * GNU General Public License for more details.
11  *
12  * You should have received a copy of the GNU General Public License
13  * version 2 along with this program; if not, write to the Free Software
14  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
15  * 02110-1301, USA.
16  */
17 
18 /**
19  * \file
20  *
21  * \author Tom DeCanio <td@npulsetech.com>
22  */
23 
24 #ifndef __OUTPUT_JSON_EMAIL_COMMON_H__
25 #define __OUTPUT_JSON_EMAIL_COMMON_H__
26 
27 #ifdef HAVE_LIBJANSSON
28 typedef struct OutputJsonEmailCtx_ {
29  LogFileCtx *file_ctx;
30  uint32_t flags; /** Store mode */
31  uint64_t fields;/** Store fields */
32  OutputJsonCommonSettings cfg;
33 } OutputJsonEmailCtx;
34 
35 typedef struct JsonEmailLogThread_ {
36  OutputJsonEmailCtx *emaillog_ctx;
37  MemBuffer *buffer;
38 } JsonEmailLogThread;
39 
40 TmEcode JsonEmailLogJson(JsonEmailLogThread *aft, json_t *js, const Packet *p, Flow *f, void *state, void *vtx, uint64_t tx_id);
41 json_t *JsonEmailAddMetadata(const Flow *f, uint32_t tx_id);
42 
43 void OutputEmailInitConf(ConfNode *conf, OutputJsonEmailCtx *email_ctx);
44 
45 #endif /* HAVE_LIBJANSSON */
46 #endif /* __OUTPUT_JSON_EMAIL_COMMON_H__ */
uint16_t flags
Definition: conf.h:32
uint16_t tx_id
Flow data structure.
Definition: flow.h:325