suricata
output-json-alert.c
Go to the documentation of this file.
1 /* Copyright (C) 2013-2024 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  * Logs alerts in JSON format.
24  *
25  */
26 
27 #include "suricata-common.h"
28 #include "packet.h"
29 #include "detect.h"
30 #include "flow.h"
31 #include "flow-bindgen.h"
32 #include "conf.h"
33 
34 #include "stream.h"
35 #include "threadvars.h"
36 #include "util-debug.h"
37 #include "stream-tcp.h"
38 
39 #include "util-logopenfile.h"
40 #include "util-misc.h"
41 #include "util-time.h"
42 
43 #include "detect-parse.h"
44 #include "detect-engine.h"
45 #include "detect-metadata.h"
46 #include "app-layer-parser.h"
47 #include "app-layer-htp-xff.h"
48 #include "app-layer-ftp.h"
49 #include "app-layer-frames.h"
50 #include "log-pcap.h"
51 
52 #include "output.h"
53 #include "output-json.h"
54 #include "output-json-alert.h"
55 #include "output-json-http.h"
56 #include "rust.h"
57 #include "output-json-smtp.h"
59 #include "output-json-nfs.h"
60 #include "output-json-smb.h"
61 #include "output-json-flow.h"
62 #include "output-json-ike.h"
63 #include "output-json-frame.h"
64 
65 #include "util-print.h"
66 #include "util-optimize.h"
67 #include "util-buffer.h"
68 #include "util-reference-config.h"
69 #include "util-validate.h"
70 
71 #include "action-globals.h"
72 
73 #define MODULE_NAME "JsonAlertLog"
74 
75 #define LOG_JSON_PAYLOAD BIT_U16(0)
76 #define LOG_JSON_PACKET BIT_U16(1)
77 #define LOG_JSON_PAYLOAD_BASE64 BIT_U16(2)
78 #define LOG_JSON_TAGGED_PACKETS BIT_U16(3)
79 #define LOG_JSON_APP_LAYER BIT_U16(4)
80 #define LOG_JSON_FLOW BIT_U16(5)
81 #define LOG_JSON_HTTP_BODY BIT_U16(6)
82 #define LOG_JSON_HTTP_BODY_BASE64 BIT_U16(7)
83 #define LOG_JSON_RULE_METADATA BIT_U16(8)
84 #define LOG_JSON_RULE BIT_U16(9)
85 #define LOG_JSON_VERDICT BIT_U16(10)
86 #define LOG_JSON_WEBSOCKET_PAYLOAD BIT_U16(11)
87 #define LOG_JSON_WEBSOCKET_PAYLOAD_BASE64 BIT_U16(12)
88 #define LOG_JSON_PAYLOAD_LENGTH BIT_U16(13)
89 #define LOG_JSON_REFERENCE BIT_U16(14)
90 
91 #define METADATA_DEFAULTS ( LOG_JSON_FLOW | \
92  LOG_JSON_APP_LAYER | \
93  LOG_JSON_RULE_METADATA)
94 
95 #define JSON_BODY_LOGGING \
96  (LOG_JSON_HTTP_BODY | LOG_JSON_HTTP_BODY_BASE64 | LOG_JSON_WEBSOCKET_PAYLOAD | \
97  LOG_JSON_WEBSOCKET_PAYLOAD_BASE64)
98 
99 #define JSON_STREAM_BUFFER_SIZE 4096
100 
101 typedef struct AlertJsonOutputCtx_ {
103  uint16_t flags;
109 
110 typedef struct JsonAlertLogThread_ {
115 
116 static void AlertJsonSourceTarget(
117  const Packet *p, const PacketAlert *pa, SCJsonBuilder *js, JsonAddrInfo *addr)
118 {
119  SCJbOpenObject(js, "source");
120  if (pa->s->flags & SIG_FLAG_DEST_IS_TARGET) {
121  SCJbSetString(js, "ip", addr->src_ip);
122  switch (p->proto) {
123  case IPPROTO_ICMP:
124  case IPPROTO_ICMPV6:
125  break;
126  case IPPROTO_UDP:
127  case IPPROTO_TCP:
128  case IPPROTO_SCTP:
129  SCJbSetUint(js, "port", addr->sp);
130  break;
131  }
132  } else if (pa->s->flags & SIG_FLAG_SRC_IS_TARGET) {
133  SCJbSetString(js, "ip", addr->dst_ip);
134  switch (p->proto) {
135  case IPPROTO_ICMP:
136  case IPPROTO_ICMPV6:
137  break;
138  case IPPROTO_UDP:
139  case IPPROTO_TCP:
140  case IPPROTO_SCTP:
141  SCJbSetUint(js, "port", addr->dp);
142  break;
143  }
144  }
145  SCJbClose(js);
146 
147  SCJbOpenObject(js, "target");
148  if (pa->s->flags & SIG_FLAG_DEST_IS_TARGET) {
149  SCJbSetString(js, "ip", addr->dst_ip);
150  switch (p->proto) {
151  case IPPROTO_ICMP:
152  case IPPROTO_ICMPV6:
153  break;
154  case IPPROTO_UDP:
155  case IPPROTO_TCP:
156  case IPPROTO_SCTP:
157  SCJbSetUint(js, "port", addr->dp);
158  break;
159  }
160  } else if (pa->s->flags & SIG_FLAG_SRC_IS_TARGET) {
161  SCJbSetString(js, "ip", addr->src_ip);
162  switch (p->proto) {
163  case IPPROTO_ICMP:
164  case IPPROTO_ICMPV6:
165  break;
166  case IPPROTO_UDP:
167  case IPPROTO_TCP:
168  case IPPROTO_SCTP:
169  SCJbSetUint(js, "port", addr->sp);
170  break;
171  }
172  }
173  SCJbClose(js);
174 }
175 
176 static void AlertJsonReference(const PacketAlert *pa, SCJsonBuilder *jb)
177 {
178  if (!pa->s->references) {
179  return;
180  }
181 
182  const DetectReference *kv = pa->s->references;
183  SCJbOpenArray(jb, "references");
184  while (kv) {
185  /* Note that the key and reference sizes have been bound
186  * checked during parsing
187  * add +2 to safisfy gcc 15 + -Wformat-truncation=2
188  */
189  const size_t size_needed = kv->key_len + kv->reference_len + 3;
191  char kv_store[size_needed];
192  snprintf(kv_store, size_needed, "%s%s", kv->key, kv->reference);
193  SCJbAppendString(jb, kv_store);
194  kv = kv->next;
195  }
196  SCJbClose(jb);
197 }
198 
199 static void AlertJsonMetadata(const PacketAlert *pa, SCJsonBuilder *js)
200 {
201  if (pa->s->metadata && pa->s->metadata->json_str) {
202  SCJbSetFormatted(js, pa->s->metadata->json_str);
203  }
204 }
205 
206 void AlertJsonHeader(const Packet *p, const PacketAlert *pa, SCJsonBuilder *js, uint16_t flags,
207  JsonAddrInfo *addr, char *xff_buffer)
208 {
209  const char *action = "allowed";
210  /* use packet action if rate_filter modified the action */
213  action = "blocked";
214  }
215  } else {
216  if (pa->action & ACTION_REJECT_ANY) {
217  action = "blocked";
218  } else if ((pa->action & ACTION_DROP) && EngineModeIsIPS()) {
219  action = "blocked";
220  }
221  }
222 
223  /* Add tx_id to root element for correlation with other events. */
224  /* json_object_del(js, "tx_id"); */
225  if (pa->flags & PACKET_ALERT_FLAG_TX) {
226  SCJbSetUint(js, "tx_id", pa->tx_id);
227  }
229  SCJbSetBool(js, "tx_guessed", true);
230  }
231 
232  SCJbOpenObject(js, "alert");
233 
234  SCJbSetString(js, "action", action);
235  if (EngineModeIsFirewall()) {
236  SCJbSetString(js, "engine", (pa->s->flags & SIG_FLAG_FIREWALL) ? "fw" : "td");
237  }
238  SCJbSetUint(js, "gid", pa->s->gid);
239  SCJbSetUint(js, "signature_id", pa->s->id);
240  SCJbSetUint(js, "rev", pa->s->rev);
241  /* TODO: SCJsonBuilder should handle unprintable characters like
242  * SCJsonString. */
243  SCJbSetString(js, "signature", pa->s->msg ? pa->s->msg : "");
244  SCJbSetString(js, "category", pa->s->class_msg ? pa->s->class_msg : "");
245  SCJbSetUint(js, "severity", pa->s->prio);
246 
247  if (p->tenant_id > 0) {
248  SCJbSetUint(js, "tenant_id", p->tenant_id);
249  }
250 
251  if (addr && pa->s->flags & SIG_FLAG_HAS_TARGET) {
252  AlertJsonSourceTarget(p, pa, js, addr);
253  }
254 
255  if ((flags & LOG_JSON_REFERENCE)) {
256  AlertJsonReference(pa, js);
257  }
258 
260  AlertJsonMetadata(pa, js);
261  }
262 
263  if (pa->json_info != NULL) {
264  SCJbOpenObject(js, "context");
265  const struct PacketContextData *json_info = pa->json_info;
266  while (json_info) {
267  SCLogDebug("JSON string '{%s}'", json_info->json_string);
268  /* The string is valid json as it is validated by JANSSON
269  during parsing and included later via a format string */
270  SCJbSetFormatted(js, json_info->json_string);
271  json_info = json_info->next;
272  }
273  SCJbClose(js);
274  }
275  if (flags & LOG_JSON_RULE) {
276  SCJbSetString(js, "rule", pa->s->sig_str);
277  }
278  if (xff_buffer && xff_buffer[0]) {
279  SCJbSetString(js, "xff", xff_buffer);
280  }
281 
282  SCJbClose(js);
283 }
284 
285 static void AlertJsonTunnel(const Packet *p, SCJsonBuilder *js, OutputJsonCommonSettings *cfg)
286 {
287  if (p->root == NULL) {
288  return;
289  }
290 
291  SCJbOpenObject(js, "tunnel");
292 
293  enum PktSrcEnum pkt_src;
295  JsonAddrInfoInit(p->root, 0, &addr, cfg);
296  pkt_src = p->root->pkt_src;
297 
298  SCJbSetString(js, "src_ip", addr.src_ip);
299  SCJbSetUint(js, "src_port", addr.sp);
300  SCJbSetString(js, "dest_ip", addr.dst_ip);
301  SCJbSetUint(js, "dest_port", addr.dp);
302  SCJbSetString(js, "proto", addr.proto);
303 
304  SCJbSetUint(js, "depth", p->recursion_level);
305  uint64_t pcap_cnt = PcapPacketCntGet(p->root);
306  if (pcap_cnt != 0) {
307  SCJbSetUint(js, "pcap_cnt", pcap_cnt);
308  }
309  SCJbSetString(js, "pkt_src", PktSrcToString(pkt_src));
310  SCJbClose(js);
311 }
312 
313 static void AlertAddPayload(AlertJsonOutputCtx *json_output_ctx, SCJsonBuilder *js, const Packet *p)
314 {
315  if (json_output_ctx->flags & LOG_JSON_PAYLOAD_BASE64) {
316  SCJbSetBase64(js, "payload", p->payload, p->payload_len);
317  }
318  if (json_output_ctx->flags & LOG_JSON_PAYLOAD_LENGTH) {
319  SCJbSetUint(js, "payload_length", p->payload_len);
320  }
321 
322  if (json_output_ctx->flags & LOG_JSON_PAYLOAD) {
323  SCJbSetPrintAsciiString(js, "payload_printable", p->payload, p->payload_len);
324  }
325 }
326 
327 static void AlertAddAppLayer(
328  const Packet *p, SCJsonBuilder *jb, const uint64_t tx_id, const uint16_t option_flags)
329 {
332  SCJsonBuilderMark mark = { 0, 0, 0 };
333  if (al && al->LogTx) {
334  void *state = FlowGetAppState(p->flow);
335  if (state) {
336  void *tx = AppLayerParserGetTx(p->flow->proto, proto, state, tx_id);
337  if (tx) {
338  const int ts =
339  AppLayerParserGetStateProgress(p->flow->proto, proto, tx, STREAM_TOSERVER);
340  const int tc =
341  AppLayerParserGetStateProgress(p->flow->proto, proto, tx, STREAM_TOCLIENT);
342  SCJbSetString(jb, "ts_progress",
343  AppLayerParserGetStateNameById(p->flow->proto, proto, ts, STREAM_TOSERVER));
344  SCJbSetString(jb, "tc_progress",
345  AppLayerParserGetStateNameById(p->flow->proto, proto, tc, STREAM_TOCLIENT));
346  SCJbGetMark(jb, &mark);
347  switch (proto) {
348  // first check some protocols need special options for alerts logging
349  case ALPROTO_WEBSOCKET:
350  if (option_flags &
352  bool pp = (option_flags & LOG_JSON_WEBSOCKET_PAYLOAD) != 0;
353  bool pb64 = (option_flags & LOG_JSON_WEBSOCKET_PAYLOAD_BASE64) != 0;
354  if (!SCWebSocketLogDetails(tx, jb, pp, pb64)) {
355  SCJbRestoreMark(jb, &mark);
356  }
357  // nothing more to log or do
358  return;
359  }
360  }
361  if (!al->LogTx(tx, jb)) {
362  SCJbRestoreMark(jb, &mark);
363  }
364  }
365  }
366  return;
367  }
368  void *state = FlowGetAppState(p->flow);
369  if (state) {
370  void *tx = AppLayerParserGetTx(p->flow->proto, proto, state, tx_id);
371  if (tx) {
372  const int ts =
373  AppLayerParserGetStateProgress(p->flow->proto, proto, tx, STREAM_TOSERVER);
374  const int tc =
375  AppLayerParserGetStateProgress(p->flow->proto, proto, tx, STREAM_TOCLIENT);
376  SCJbSetString(jb, "ts_progress",
377  AppLayerParserGetStateNameById(p->flow->proto, proto, ts, STREAM_TOSERVER));
378  SCJbSetString(jb, "tc_progress",
379  AppLayerParserGetStateNameById(p->flow->proto, proto, tc, STREAM_TOCLIENT));
380  }
381  }
382  switch (proto) {
383  case ALPROTO_HTTP1:
384  // TODO: Could result in an empty http object being logged.
385  SCJbOpenObject(jb, "http");
386  if (EveHttpAddMetadata(p->flow, tx_id, jb)) {
387  if (option_flags & LOG_JSON_HTTP_BODY) {
388  EveHttpLogJSONBodyPrintable(jb, p->flow, tx_id);
389  }
390  if (option_flags & LOG_JSON_HTTP_BODY_BASE64) {
391  EveHttpLogJSONBodyBase64(jb, p->flow, tx_id);
392  }
393  }
394  SCJbClose(jb);
395  break;
396  case ALPROTO_SMTP:
397  SCJbGetMark(jb, &mark);
398  SCJbOpenObject(jb, "smtp");
399  if (EveSMTPAddMetadata(p->flow, tx_id, jb)) {
400  SCJbClose(jb);
401  } else {
402  SCJbRestoreMark(jb, &mark);
403  }
404  SCJbGetMark(jb, &mark);
405  SCJbOpenObject(jb, "email");
406  if (EveEmailAddMetadata(p->flow, tx_id, jb)) {
407  SCJbClose(jb);
408  } else {
409  SCJbRestoreMark(jb, &mark);
410  }
411  break;
412  case ALPROTO_NFS:
413  /* rpc */
414  SCJbGetMark(jb, &mark);
415  SCJbOpenObject(jb, "rpc");
416  if (EveNFSAddMetadataRPC(p->flow, tx_id, jb)) {
417  SCJbClose(jb);
418  } else {
419  SCJbRestoreMark(jb, &mark);
420  }
421  /* nfs */
422  SCJbGetMark(jb, &mark);
423  SCJbOpenObject(jb, "nfs");
424  if (EveNFSAddMetadata(p->flow, tx_id, jb)) {
425  SCJbClose(jb);
426  } else {
427  SCJbRestoreMark(jb, &mark);
428  }
429  break;
430  case ALPROTO_SMB:
431  SCJbGetMark(jb, &mark);
432  SCJbOpenObject(jb, "smb");
433  if (EveSMBAddMetadata(p->flow, tx_id, jb)) {
434  SCJbClose(jb);
435  } else {
436  SCJbRestoreMark(jb, &mark);
437  }
438  break;
439  case ALPROTO_IKE:
440  SCJbGetMark(jb, &mark);
441  if (!EveIKEAddMetadata(p->flow, tx_id, jb)) {
442  SCJbRestoreMark(jb, &mark);
443  }
444  break;
445  case ALPROTO_DCERPC: {
446  if (state) {
447  void *tx = AppLayerParserGetTx(p->flow->proto, proto, state, tx_id);
448  if (tx) {
449  SCJbGetMark(jb, &mark);
450  SCJbOpenObject(jb, "dcerpc");
451  if (p->proto == IPPROTO_TCP) {
452  if (!SCDcerpcLogJsonRecordTcp(state, tx, jb)) {
453  SCJbRestoreMark(jb, &mark);
454  }
455  } else {
456  if (!SCDcerpcLogJsonRecordUdp(state, tx, jb)) {
457  SCJbRestoreMark(jb, &mark);
458  }
459  }
460  SCJbClose(jb);
461  }
462  }
463  break;
464  }
465  default:
466  break;
467  }
468 }
469 
470 static void AlertAddFiles(const Packet *p, SCJsonBuilder *jb, const uint64_t tx_id)
471 {
472  const uint8_t direction =
473  (p->flowflags & FLOW_PKT_TOSERVER) ? STREAM_TOSERVER : STREAM_TOCLIENT;
474  FileContainer *ffc = NULL;
475  if (p->flow->alstate != NULL) {
476  void *tx = AppLayerParserGetTx(p->flow->proto, p->flow->alproto, p->flow->alstate, tx_id);
477  if (tx) {
478  AppLayerGetFileState files = AppLayerParserGetTxFiles(p->flow, tx, direction);
479  ffc = files.fc;
480  }
481  }
482  if (ffc != NULL) {
483  File *file = ffc->head;
484  bool isopen = false;
485  while (file) {
486  if (!isopen) {
487  isopen = true;
488  SCJbOpenArray(jb, "files");
489  }
490  SCJbStartObject(jb);
491  EveFileInfo(jb, file, tx_id, file->flags);
492  SCJbClose(jb);
493  file = file->next;
494  }
495  if (isopen) {
496  SCJbClose(jb);
497  }
498  }
499 }
500 
501 static void AlertAddFrame(
502  const Packet *p, const int64_t frame_id, SCJsonBuilder *jb, MemBuffer *buffer)
503 {
504  if (p->flow == NULL || (p->proto == IPPROTO_TCP && p->flow->protoctx == NULL))
505  return;
506 
507  FramesContainer *frames_container = AppLayerFramesGetContainer(p->flow);
508  if (frames_container == NULL)
509  return;
510 
511  Frames *frames = NULL;
512  TcpStream *stream = NULL;
513  if (p->proto == IPPROTO_TCP) {
514  TcpSession *ssn = p->flow->protoctx;
515  if (PKT_IS_TOSERVER(p)) {
516  stream = &ssn->client;
517  frames = &frames_container->toserver;
518  } else {
519  stream = &ssn->server;
520  frames = &frames_container->toclient;
521  }
522  Frame *frame = FrameGetById(frames, frame_id);
523  if (frame != NULL) {
524  FrameJsonLogOneFrame(IPPROTO_TCP, frame, p->flow, stream, p, jb, buffer);
525  }
526  } else if (p->proto == IPPROTO_UDP) {
527  if (PKT_IS_TOSERVER(p)) {
528  frames = &frames_container->toserver;
529  } else {
530  frames = &frames_container->toclient;
531  }
532  Frame *frame = FrameGetById(frames, frame_id);
533  if (frame != NULL) {
534  FrameJsonLogOneFrame(IPPROTO_UDP, frame, p->flow, NULL, p, jb, buffer);
535  }
536  }
537 }
538 
539 /**
540  * \brief Build verdict object
541  *
542  * \param p Pointer to Packet current being logged
543  * \param alert_action action bitfield from the alert: only used for ACTION_PASS
544  */
545 void EveAddVerdict(SCJsonBuilder *jb, const Packet *p, const uint8_t alert_action)
546 {
547  SCJbOpenObject(jb, "verdict");
548 
549  const uint8_t packet_action = PacketGetAction(p);
550  SCLogDebug("%" PRIu64 ": packet_action %02x alert_action %02x", PcapPacketCntGet(p),
551  packet_action, alert_action);
552  /* add verdict info */
553  if (packet_action & ACTION_REJECT_ANY) {
554  // check rule to define type of reject packet sent
555  if (EngineModeIsIPS()) {
556  JB_SET_STRING(jb, "action", "drop");
557  } else {
558  JB_SET_STRING(jb, "action", "alert");
559  }
560  if (packet_action & ACTION_REJECT) {
561  JB_SET_STRING(jb, "reject_target", "to_client");
562  } else if (packet_action & ACTION_REJECT_DST) {
563  JB_SET_STRING(jb, "reject_target", "to_server");
564  } else if (packet_action & ACTION_REJECT_BOTH) {
565  JB_SET_STRING(jb, "reject_target", "both");
566  }
567  SCJbOpenArray(jb, "reject");
568  switch (p->proto) {
569  case IPPROTO_UDP:
570  case IPPROTO_ICMP:
571  case IPPROTO_ICMPV6:
572  SCJbAppendString(jb, "icmp-prohib");
573  break;
574  case IPPROTO_TCP:
575  SCJbAppendString(jb, "tcp-reset");
576  break;
577  }
578  SCJbClose(jb);
579 
580  } else if ((packet_action & ACTION_DROP) && EngineModeIsIPS()) {
581  JB_SET_STRING(jb, "action", "drop");
582  } else if (packet_action & ACTION_ACCEPT) {
583  JB_SET_STRING(jb, "action", "accept");
584  } else if (alert_action & ACTION_PASS) {
585  JB_SET_STRING(jb, "action", "pass");
586  } else {
587  // TODO make sure we don't have a situation where this wouldn't work
588  JB_SET_STRING(jb, "action", "alert");
589  }
590 
591  /* Close verdict */
592  SCJbClose(jb);
593 }
594 
597  uint64_t last_re;
598 };
599 
600 static int AlertJsonStreamDataCallback(
601  void *cb_data, const uint8_t *input, const uint32_t input_len, const uint64_t input_offset)
602 {
603  struct AlertJsonStreamDataCallbackData *cbd = cb_data;
604  if (input_offset > cbd->last_re) {
606  cbd->payload, "[%" PRIu64 " bytes missing]", input_offset - cbd->last_re);
607  }
608 
609  int done = 0;
610  uint32_t written = MemBufferWriteRaw(cbd->payload, input, input_len);
611  if (written < input_len)
612  done = 1;
613  cbd->last_re = input_offset + input_len;
614  return done;
615 }
616 
617 /** \internal
618  * \brief try to log stream data into payload/payload_printable
619  * \retval true stream data logged
620  * \retval false stream data not logged
621  */
622 static bool AlertJsonStreamData(const AlertJsonOutputCtx *json_output_ctx, JsonAlertLogThread *aft,
623  Flow *f, const Packet *p, SCJsonBuilder *jb)
624 {
625  TcpSession *ssn = f->protoctx;
626  TcpStream *stream = (PKT_IS_TOSERVER(p)) ? &ssn->client : &ssn->server;
627 
628  MemBufferReset(aft->payload_buffer);
630  .last_re = STREAM_BASE_OFFSET(stream) };
631  uint64_t unused = 0;
632  StreamReassembleLog(ssn, stream, AlertJsonStreamDataCallback, &cbd, STREAM_BASE_OFFSET(stream),
633  &unused, false);
634  if (cbd.payload->offset) {
635  if (json_output_ctx->flags & LOG_JSON_PAYLOAD_BASE64) {
636  SCJbSetBase64(jb, "payload", cbd.payload->buffer, cbd.payload->offset);
637  }
638  if (json_output_ctx->flags & LOG_JSON_PAYLOAD_LENGTH) {
639  SCJbSetUint(jb, "payload_length", cbd.payload->offset);
640  }
641 
642  if (json_output_ctx->flags & LOG_JSON_PAYLOAD) {
643  SCJbSetPrintAsciiString(
644  jb, "payload_printable", cbd.payload->buffer, cbd.payload->offset);
645  }
646  return true;
647  }
648  return false;
649 }
650 
651 static void AlertJsonAddFirewall(SCJsonBuilder *jb, const Signature *s)
652 {
653  struct DetectFirewallPolicy pol = { .action = s->action, .action_scope = s->action_scope };
654 
655  SCJbOpenObject(jb, "firewall");
656  const char *hook = NULL;
657  char hook_string[256];
658  switch (s->detect_table) {
660  if (s->flags & SIG_FLAG_TOSERVER) {
662  IPPROTO_TCP, s->alproto, s->app_progress_hook, STREAM_TOSERVER);
663  } else {
665  IPPROTO_TCP, s->alproto, s->app_progress_hook, STREAM_TOCLIENT);
666  }
667  if (hook) {
668  snprintf(hook_string, sizeof(hook_string), "%s:%s", AppProtoToString(s->alproto),
669  hook);
670  hook = hook_string;
671  }
672  break;
674  hook = "packet:filter";
675  break;
677  hook = "packet:pre_flow";
678  break;
680  hook = "packet:pre_stream";
681  break;
682  }
683  if (hook) {
684  SCJbSetString(jb, "hook", hook);
685  }
686  char policy_string[64] = "";
687  DetectFirewallPolicyToString(&pol, policy_string, sizeof(policy_string));
688  if (strlen(policy_string) > 0) {
689  SCJbSetString(jb, "policy", policy_string);
690  }
691  SCJbClose(jb);
692 }
693 
694 static int AlertJson(ThreadVars *tv, JsonAlertLogThread *aft, const Packet *p)
695 {
696  AlertJsonOutputCtx *json_output_ctx = aft->json_output_ctx;
697 
698  if (p->alerts.cnt == 0 && !(p->flags & PKT_HAS_TAG))
699  return TM_ECODE_OK;
700 
701  const uint8_t final_action = p->alerts.cnt > 0 ? p->alerts.alerts[p->alerts.cnt - 1].action : 0;
702  for (int i = 0; i < p->alerts.cnt; i++) {
703  const PacketAlert *pa = &p->alerts.alerts[i];
704  if (unlikely(pa->s == NULL || (pa->action & ACTION_ALERT) == 0)) {
705  continue;
706  }
707 
708  /* First initialize the address info (5-tuple). */
710  JsonAddrInfoInit(p, LOG_DIR_PACKET, &addr, &json_output_ctx->eve_ctx->cfg);
711 
712  /* Check for XFF, overwriting address info if needed. */
713  HttpXFFCfg *xff_cfg = json_output_ctx->xff_cfg != NULL ? json_output_ctx->xff_cfg
714  : json_output_ctx->parent_xff_cfg;
715  int have_xff_ip = 0;
716  char xff_buffer[XFF_MAXLEN];
717  xff_buffer[0] = 0;
718  if ((xff_cfg != NULL) && !(xff_cfg->flags & XFF_DISABLED) && p->flow != NULL) {
720  if (pa->flags & PACKET_ALERT_FLAG_TX) {
721  have_xff_ip = HttpXFFGetIPFromTx(p->flow, pa->tx_id, xff_cfg,
722  xff_buffer, XFF_MAXLEN);
723  } else {
724  have_xff_ip = HttpXFFGetIP(p->flow, xff_cfg, xff_buffer,
725  XFF_MAXLEN);
726  }
727  }
728 
729  if (have_xff_ip && xff_cfg->flags & XFF_OVERWRITE) {
730  if (p->flowflags & FLOW_PKT_TOCLIENT) {
731  strlcpy(addr.dst_ip, xff_buffer, JSON_ADDR_LEN);
732  } else {
733  strlcpy(addr.src_ip, xff_buffer, JSON_ADDR_LEN);
734  }
735  /* Clear have_xff_ip so the xff field does not get
736  * logged below. */
737  have_xff_ip = false;
738  }
739  if (have_xff_ip && !(xff_cfg->flags & XFF_EXTRADATA)) {
740  // reset xff_buffer so as not to log it
741  xff_buffer[0] = 0;
742  }
743  }
744 
745  SCJsonBuilder *jb =
746  CreateEveHeader(p, LOG_DIR_PACKET, "alert", &addr, json_output_ctx->eve_ctx);
747  if (unlikely(jb == NULL))
748  return TM_ECODE_OK;
749 
750 
751  /* alert */
752  AlertJsonHeader(p, pa, jb, json_output_ctx->flags, &addr, xff_buffer);
753 
754  if (PacketIsTunnel(p)) {
755  AlertJsonTunnel(p, jb, &json_output_ctx->eve_ctx->cfg);
756  }
757 
758  if (pa->s->flags & SIG_FLAG_FIREWALL) {
759  AlertJsonAddFirewall(jb, pa->s);
760  }
761 
762  if (p->flow != NULL) {
763  if (pa->flags & PACKET_ALERT_FLAG_TX) {
764  if (json_output_ctx->flags & LOG_JSON_APP_LAYER) {
765  AlertAddAppLayer(p, jb, pa->tx_id, json_output_ctx->flags);
766  }
767  /* including fileinfo data is configured by the metadata setting */
768  if (json_output_ctx->flags & LOG_JSON_RULE_METADATA) {
769  AlertAddFiles(p, jb, pa->tx_id);
770  }
771  }
772 
773  EveAddAppProto(p->flow, jb);
774 
775  if (p->flowflags & FLOW_PKT_TOSERVER) {
776  SCJbSetString(jb, "direction", "to_server");
777  } else {
778  SCJbSetString(jb, "direction", "to_client");
779  }
780 
781  if (json_output_ctx->flags & LOG_JSON_FLOW) {
782  SCJbOpenObject(jb, "flow");
783  EveAddFlow(p->flow, jb);
784  if (p->flowflags & FLOW_PKT_TOCLIENT) {
785  SCJbSetString(jb, "src_ip", addr.dst_ip);
786  SCJbSetString(jb, "dest_ip", addr.src_ip);
787  if (addr.sp > 0) {
788  SCJbSetUint(jb, "src_port", addr.dp);
789  SCJbSetUint(jb, "dest_port", addr.sp);
790  }
791  } else {
792  SCJbSetString(jb, "src_ip", addr.src_ip);
793  SCJbSetString(jb, "dest_ip", addr.dst_ip);
794  if (addr.sp > 0) {
795  SCJbSetUint(jb, "src_port", addr.sp);
796  SCJbSetUint(jb, "dest_port", addr.dp);
797  }
798  }
799  SCJbClose(jb);
800  }
801  }
802 
803  /* payload */
804  if (json_output_ctx->flags &
806  int stream = (p->proto == IPPROTO_TCP) ?
808  1 : 0) : 0;
809  // should be impossible, as stream implies flow
810  DEBUG_VALIDATE_BUG_ON(stream && p->flow == NULL);
811 
812  /* Is this a stream? If so, pack part of it into the payload field */
813  if (stream && p->flow != NULL) {
814  const bool stream_data_logged =
815  AlertJsonStreamData(json_output_ctx, aft, p->flow, p, jb);
816  if (!stream_data_logged && p->payload_len) {
817  /* Fallback on packet payload */
818  AlertAddPayload(json_output_ctx, jb, p);
819  }
820  } else {
821  /* This is a single packet and not a stream */
822  AlertAddPayload(json_output_ctx, jb, p);
823  }
824 
825  SCJbSetUint(jb, "stream", stream);
826  }
827 
828  if (pa->flags & PACKET_ALERT_FLAG_FRAME) {
829  AlertAddFrame(p, pa->frame_id, jb, aft->payload_buffer);
830  }
831 
832  /* base64-encoded full packet */
833  if (json_output_ctx->flags & LOG_JSON_PACKET) {
834  EvePacket(p, jb, 0);
835  }
836 
838  if (pcap_filename != NULL) {
839  SCJbSetString(jb, "capture_file", pcap_filename);
840  }
841 
842  if (json_output_ctx->flags & LOG_JSON_VERDICT) {
843  EveAddVerdict(jb, p, final_action & ACTION_PASS);
844  }
845 
846  OutputJsonBuilderBuffer(tv, p, p->flow, jb, aft->ctx);
847  SCJbFree(jb);
848  }
849 
850  if ((p->flags & PKT_HAS_TAG) && (json_output_ctx->flags &
852  SCJsonBuilder *packetjs =
853  CreateEveHeader(p, LOG_DIR_PACKET, "packet", NULL, json_output_ctx->eve_ctx);
854  if (unlikely(packetjs != NULL)) {
855  EvePacket(p, packetjs, 0);
856  OutputJsonBuilderBuffer(tv, p, p->flow, packetjs, aft->ctx);
857  SCJbFree(packetjs);
858  }
859  }
860 
861  return TM_ECODE_OK;
862 }
863 
864 static int AlertJsonDecoderEvent(ThreadVars *tv, JsonAlertLogThread *aft, const Packet *p)
865 {
866  AlertJsonOutputCtx *json_output_ctx = aft->json_output_ctx;
867 
868  if (p->alerts.cnt == 0)
869  return TM_ECODE_OK;
870 
871  const uint8_t final_action = p->alerts.alerts[p->alerts.cnt - 1].action;
872  for (int i = 0; i < p->alerts.cnt; i++) {
873  const PacketAlert *pa = &p->alerts.alerts[i];
874  if (unlikely(pa->s == NULL || (pa->action & ACTION_ALERT) == 0)) {
875  continue;
876  }
877 
878  SCJsonBuilder *jb =
879  CreateEveHeader(p, LOG_DIR_PACKET, "alert", NULL, json_output_ctx->eve_ctx);
880  if (unlikely(jb == NULL))
881  return TM_ECODE_OK;
882 
883  AlertJsonHeader(p, pa, jb, json_output_ctx->flags, NULL, NULL);
884 
885  if (PacketIsTunnel(p)) {
886  AlertJsonTunnel(p, jb, &json_output_ctx->eve_ctx->cfg);
887  }
888 
889  /* base64-encoded full packet */
890  if (json_output_ctx->flags & LOG_JSON_PACKET) {
891  EvePacket(p, jb, 0);
892  }
893 
895  if (pcap_filename != NULL) {
896  SCJbSetString(jb, "capture_file", pcap_filename);
897  }
898 
899  if (json_output_ctx->flags & LOG_JSON_VERDICT) {
900  EveAddVerdict(jb, p, final_action & ACTION_PASS);
901  }
902 
903  OutputJsonBuilderBuffer(tv, p, p->flow, jb, aft->ctx);
904  SCJbFree(jb);
905  }
906 
907  return TM_ECODE_OK;
908 }
909 
910 static int JsonAlertLogger(ThreadVars *tv, void *thread_data, const Packet *p)
911 {
912  JsonAlertLogThread *aft = thread_data;
913 
914  if (PacketIsIPv4(p) || PacketIsIPv6(p)) {
915  return AlertJson(tv, aft, p);
916  } else if (p->alerts.cnt > 0) {
917  return AlertJsonDecoderEvent(tv, aft, p);
918  }
919  return 0;
920 }
921 
922 static bool JsonAlertLogCondition(ThreadVars *tv, void *thread_data, const Packet *p)
923 {
924  return (p->alerts.cnt || (p->flags & PKT_HAS_TAG));
925 }
926 
927 static TmEcode JsonAlertLogThreadInit(ThreadVars *t, const void *initdata, void **data)
928 {
930  if (unlikely(aft == NULL))
931  return TM_ECODE_FAILED;
932 
933  if (initdata == NULL)
934  {
935  SCLogDebug("Error getting context for EveLogAlert. \"initdata\" argument NULL");
936  goto error_exit;
937  }
938 
939  /** Use the Output Context (file pointer and mutex) */
940  AlertJsonOutputCtx *json_output_ctx = ((OutputCtx *)initdata)->data;
941 
942  aft->payload_buffer = MemBufferCreateNew(json_output_ctx->payload_buffer_size);
943  if (aft->payload_buffer == NULL) {
944  goto error_exit;
945  }
946  aft->ctx = CreateEveThreadCtx(t, json_output_ctx->eve_ctx);
947  if (!aft->ctx) {
948  goto error_exit;
949  }
950 
951  aft->json_output_ctx = json_output_ctx;
952 
953  *data = (void *)aft;
954  return TM_ECODE_OK;
955 
956 error_exit:
957  if (aft->payload_buffer != NULL) {
959  }
960  SCFree(aft);
961  return TM_ECODE_FAILED;
962 }
963 
964 static TmEcode JsonAlertLogThreadDeinit(ThreadVars *t, void *data)
965 {
966  JsonAlertLogThread *aft = (JsonAlertLogThread *)data;
967  if (aft == NULL) {
968  return TM_ECODE_OK;
969  }
970 
972  FreeEveThreadCtx(aft->ctx);
973 
974  /* clear memory */
975  memset(aft, 0, sizeof(JsonAlertLogThread));
976 
977  SCFree(aft);
978  return TM_ECODE_OK;
979 }
980 
981 static void JsonAlertLogDeInitCtxSub(OutputCtx *output_ctx)
982 {
983  SCLogDebug("cleaning up sub output_ctx %p", output_ctx);
984 
985  AlertJsonOutputCtx *json_output_ctx = (AlertJsonOutputCtx *) output_ctx->data;
986 
987  if (json_output_ctx != NULL) {
988  HttpXFFCfg *xff_cfg = json_output_ctx->xff_cfg;
989  if (xff_cfg != NULL) {
990  SCFree(xff_cfg);
991  }
992  SCFree(json_output_ctx);
993  }
994  SCFree(output_ctx);
995 }
996 
997 static void SetFlag(const SCConfNode *conf, const char *name, uint16_t flag, uint16_t *out_flags)
998 {
999  DEBUG_VALIDATE_BUG_ON(conf == NULL);
1000  const char *setting = SCConfNodeLookupChildValue(conf, name);
1001  if (setting != NULL) {
1002  if (SCConfValIsTrue(setting)) {
1003  *out_flags |= flag;
1004  } else {
1005  *out_flags &= ~flag;
1006  }
1007  }
1008 }
1009 
1010 static void JsonAlertLogSetupMetadata(AlertJsonOutputCtx *json_output_ctx, SCConfNode *conf)
1011 {
1012  static bool warn_no_meta = false;
1013  uint32_t payload_buffer_size = JSON_STREAM_BUFFER_SIZE;
1014  uint16_t flags = METADATA_DEFAULTS;
1015 
1016  if (conf != NULL) {
1017  /* Check for metadata to enable/disable. */
1018  SCConfNode *metadata = SCConfNodeLookupChild(conf, "metadata");
1019  if (metadata != NULL) {
1020  if (metadata->val != NULL && SCConfValIsFalse(metadata->val)) {
1022  } else if (SCConfNodeHasChildren(metadata)) {
1023  SCConfNode *rule_metadata = SCConfNodeLookupChild(metadata, "rule");
1024  if (rule_metadata) {
1025  SetFlag(rule_metadata, "raw", LOG_JSON_RULE, &flags);
1026  SetFlag(rule_metadata, "metadata", LOG_JSON_RULE_METADATA,
1027  &flags);
1028  SetFlag(rule_metadata, "reference", LOG_JSON_REFERENCE, &flags);
1029  }
1030  SetFlag(metadata, "flow", LOG_JSON_FLOW, &flags);
1031  SetFlag(metadata, "app-layer", LOG_JSON_APP_LAYER, &flags);
1032  }
1033  }
1034 
1035  /* Non-metadata toggles. */
1036  SetFlag(conf, "payload", LOG_JSON_PAYLOAD_BASE64, &flags);
1037  SetFlag(conf, "packet", LOG_JSON_PACKET, &flags);
1038  SetFlag(conf, "tagged-packets", LOG_JSON_TAGGED_PACKETS, &flags);
1039  SetFlag(conf, "payload-printable", LOG_JSON_PAYLOAD, &flags);
1040  SetFlag(conf, "http-body-printable", LOG_JSON_HTTP_BODY, &flags);
1041  SetFlag(conf, "http-body", LOG_JSON_HTTP_BODY_BASE64, &flags);
1042  SetFlag(conf, "websocket-payload-printable", LOG_JSON_WEBSOCKET_PAYLOAD, &flags);
1043  SetFlag(conf, "websocket-payload", LOG_JSON_WEBSOCKET_PAYLOAD_BASE64, &flags);
1044  SetFlag(conf, "verdict", LOG_JSON_VERDICT, &flags);
1045  SetFlag(conf, "payload-length", LOG_JSON_PAYLOAD_LENGTH, &flags);
1046 
1047  /* Check for obsolete flags and warn that they have no effect. */
1048  static const char *deprecated_flags[] = { "http", "tls", "ssh", "smtp", "dnp3", "app-layer",
1049  "flow", NULL };
1050  for (int i = 0; deprecated_flags[i] != NULL; i++) {
1051  if (SCConfNodeLookupChildValue(conf, deprecated_flags[i]) != NULL) {
1052  SCLogWarning("Found deprecated eve-log.alert flag \"%s\", this flag has no effect",
1053  deprecated_flags[i]);
1054  }
1055  }
1056 
1057  const char *payload_buffer_value = SCConfNodeLookupChildValue(conf, "payload-buffer-size");
1058 
1059  if (payload_buffer_value != NULL) {
1060  uint32_t value;
1061  if (ParseSizeStringU32(payload_buffer_value, &value) < 0) {
1062  SCLogError("Error parsing "
1063  "payload-buffer-size - %s. Killing engine",
1064  payload_buffer_value);
1065  exit(EXIT_FAILURE);
1066  } else if (value == 0) {
1067  // you should not ask for payload if you want 0 of it
1068  SCLogError("Error payload-buffer-size should not be 0");
1069  exit(EXIT_FAILURE);
1070  } else {
1071  payload_buffer_size = value;
1072  }
1073  }
1074 
1075  if (!warn_no_meta && flags & JSON_BODY_LOGGING) {
1076  if (((flags & LOG_JSON_APP_LAYER) == 0)) {
1077  SCLogWarning("HTTP body logging has been configured, however, "
1078  "metadata logging has not been enabled. HTTP body logging will be "
1079  "disabled.");
1081  warn_no_meta = true;
1082  }
1083  }
1084  }
1085 
1086  if (flags & LOG_JSON_RULE_METADATA) {
1088  }
1089 
1090  json_output_ctx->payload_buffer_size = payload_buffer_size;
1091  json_output_ctx->flags |= flags;
1092 }
1093 
1094 static HttpXFFCfg *JsonAlertLogGetXffCfg(SCConfNode *conf)
1095 {
1096  HttpXFFCfg *xff_cfg = NULL;
1097  if (conf != NULL && SCConfNodeLookupChild(conf, "xff") != NULL) {
1098  xff_cfg = SCCalloc(1, sizeof(HttpXFFCfg));
1099  if (likely(xff_cfg != NULL)) {
1100  HttpXFFGetCfg(conf, xff_cfg);
1101  }
1102  }
1103  return xff_cfg;
1104 }
1105 
1106 /**
1107  * \brief Create a new LogFileCtx for "fast" output style.
1108  * \param conf The configuration node for this output.
1109  * \return A LogFileCtx pointer on success, NULL on failure.
1110  */
1111 static OutputInitResult JsonAlertLogInitCtxSub(SCConfNode *conf, OutputCtx *parent_ctx)
1112 {
1113  OutputInitResult result = { NULL, false };
1114  OutputJsonCtx *ajt = parent_ctx->data;
1115  AlertJsonOutputCtx *json_output_ctx = NULL;
1116 
1117  OutputCtx *output_ctx = SCCalloc(1, sizeof(OutputCtx));
1118  if (unlikely(output_ctx == NULL))
1119  return result;
1120 
1121  json_output_ctx = SCCalloc(1, sizeof(AlertJsonOutputCtx));
1122  if (unlikely(json_output_ctx == NULL)) {
1123  goto error;
1124  }
1125 
1126  json_output_ctx->file_ctx = ajt->file_ctx;
1127  json_output_ctx->eve_ctx = ajt;
1128 
1129  JsonAlertLogSetupMetadata(json_output_ctx, conf);
1130  json_output_ctx->xff_cfg = JsonAlertLogGetXffCfg(conf);
1131  if (json_output_ctx->xff_cfg == NULL) {
1132  json_output_ctx->parent_xff_cfg = ajt->xff_cfg;
1133  }
1134 
1135  output_ctx->data = json_output_ctx;
1136  output_ctx->DeInit = JsonAlertLogDeInitCtxSub;
1137 
1138  result.ctx = output_ctx;
1139  result.ok = true;
1140  return result;
1141 
1142 error:
1143  if (json_output_ctx != NULL) {
1144  SCFree(json_output_ctx);
1145  }
1146  if (output_ctx != NULL) {
1147  SCFree(output_ctx);
1148  }
1149 
1150  return result;
1151 }
1152 
1154 {
1155  OutputPacketLoggerFunctions output_logger_functions = {
1156  .LogFunc = JsonAlertLogger,
1157  .ConditionFunc = JsonAlertLogCondition,
1158  .ThreadInitFunc = JsonAlertLogThreadInit,
1159  .ThreadDeinitFunc = JsonAlertLogThreadDeinit,
1160  .ThreadExitPrintStatsFunc = NULL,
1161  };
1162 
1163  OutputRegisterPacketSubModule(LOGGER_JSON_ALERT, "eve-log", MODULE_NAME, "eve-log.alert",
1164  JsonAlertLogInitCtxSub, &output_logger_functions);
1165 }
XFF_MAXLEN
#define XFF_MAXLEN
Definition: app-layer-htp-xff.h:39
PacketCheckAction
bool PacketCheckAction(const Packet *p, const uint8_t a)
Definition: packet.c:50
PACKET_ALERT_FLAG_TX_GUESSED
#define PACKET_ALERT_FLAG_TX_GUESSED
Definition: decode.h:279
Packet_::proto
uint8_t proto
Definition: decode.h:537
TcpStream_
Definition: stream-tcp-private.h:106
FileContainer_
Definition: util-file.h:37
ts
uint64_t ts
Definition: source-erf-file.c:55
DetectMetadataHead::json_str
char * json_str
Definition: detect-metadata.h:40
SCConfValIsTrue
int SCConfValIsTrue(const char *val)
Check if a value is true.
Definition: conf.c:552
detect-engine.h
PacketAlert_::s
const struct Signature_ * s
Definition: decode.h:253
ALPROTO_IKE
@ ALPROTO_IKE
Definition: app-layer-protos.h:55
OutputJsonCtx_::xff_cfg
HttpXFFCfg * xff_cfg
Definition: output-json.h:81
MemBuffer_::buffer
uint8_t buffer[]
Definition: util-buffer.h:30
Signature_::sig_str
char * sig_str
Definition: detect.h:752
ALPROTO_DCERPC
@ ALPROTO_DCERPC
Definition: app-layer-protos.h:44
AppLayerParserGetStateNameById
const char * AppLayerParserGetStateNameById(uint8_t ipproto, AppProto alproto, const int id, const uint8_t direction)
Definition: app-layer-parser.c:1642
DETECT_TABLE_APP_FILTER
@ DETECT_TABLE_APP_FILTER
Definition: detect.h:562
XFF_EXTRADATA
#define XFF_EXTRADATA
Definition: app-layer-htp-xff.h:31
EveAddFlow
void EveAddFlow(Flow *f, SCJsonBuilder *js)
Definition: output-json-flow.c:203
stream-tcp.h
OutputJsonCtx_::cfg
OutputJsonCommonSettings cfg
Definition: output-json.h:80
HttpXFFGetCfg
void HttpXFFGetCfg(SCConfNode *conf, HttpXFFCfg *result)
Function to return XFF configuration from a configuration node.
Definition: app-layer-htp-xff.c:219
PACKET_ALERT_FLAG_STATE_MATCH
#define PACKET_ALERT_FLAG_STATE_MATCH
Definition: decode.h:269
unlikely
#define unlikely(expr)
Definition: util-optimize.h:35
EveHttpLogJSONBodyPrintable
void EveHttpLogJSONBodyPrintable(SCJsonBuilder *js, Flow *f, uint64_t tx_id)
Definition: output-json-http.c:384
ACTION_PASS
#define ACTION_PASS
Definition: action-globals.h:34
ACTION_REJECT
#define ACTION_REJECT
Definition: action-globals.h:31
Signature_::app_progress_hook
uint8_t app_progress_hook
Definition: detect.h:712
AppLayerFramesGetContainer
FramesContainer * AppLayerFramesGetContainer(const Flow *f)
Definition: app-layer-parser.c:184
PcapPacketCntGet
uint64_t PcapPacketCntGet(const Packet *p)
Definition: decode.c:1180
LOG_JSON_RULE
#define LOG_JSON_RULE
Definition: output-json-alert.c:84
Signature_::alproto
AppProto alproto
Definition: detect.h:680
DETECT_TABLE_PACKET_PRE_STREAM
@ DETECT_TABLE_PACKET_PRE_STREAM
Definition: detect.h:559
SCLogDebug
#define SCLogDebug(...)
Definition: util-debug.h:282
AlertJsonOutputCtx_::file_ctx
LogFileCtx * file_ctx
Definition: output-json-alert.c:102
name
const char * name
Definition: detect-engine-proto.c:48
AlertJsonOutputCtx_::parent_xff_cfg
HttpXFFCfg * parent_xff_cfg
Definition: output-json-alert.c:106
FreeEveThreadCtx
void FreeEveThreadCtx(OutputJsonThreadCtx *ctx)
Definition: output-json-common.c:58
Flow_::proto
uint8_t proto
Definition: flow.h:376
EveAddAppProto
void EveAddAppProto(Flow *f, SCJsonBuilder *js)
Definition: output-json-flow.c:183
AppProto
uint16_t AppProto
Definition: app-layer-protos.h:87
AlertJsonStreamDataCallbackData::last_re
uint64_t last_re
Definition: output-json-alert.c:597
Packet_::payload
uint8_t * payload
Definition: decode.h:619
PacketAlerts_::cnt
uint16_t cnt
Definition: decode.h:288
SIG_FLAG_DEST_IS_TARGET
#define SIG_FLAG_DEST_IS_TARGET
Definition: detect.h:284
AppLayerParserGetStateProgress
int AppLayerParserGetStateProgress(uint8_t ipproto, AppProto alproto, void *alstate, uint8_t flags)
get the progress value for a tx/protocol
Definition: app-layer-parser.c:1112
SCFlowGetAppProtocol
AppProto SCFlowGetAppProtocol(const Flow *f)
Definition: flow.c:1240
action-globals.h
FramesContainer::toserver
Frames toserver
Definition: app-layer-frames.h:72
Packet_::flags
uint32_t flags
Definition: decode.h:561
CreateEveHeader
SCJsonBuilder * CreateEveHeader(const Packet *p, enum SCOutputJsonLogDirection dir, const char *event_type, JsonAddrInfo *addr, OutputJsonCtx *eve_ctx)
Definition: output-json.c:819
LOGGER_JSON_ALERT
@ LOGGER_JSON_ALERT
Definition: suricata-common.h:504
OutputJsonCtx_
Definition: output-json.h:77
Frame
Definition: app-layer-frames.h:43
Flow_
Flow data structure.
Definition: flow.h:354
OutputJsonCommonSettings_
Definition: output-json.h:62
JsonAddrInfoInit
void JsonAddrInfoInit(const Packet *p, enum SCOutputJsonLogDirection dir, JsonAddrInfo *addr, OutputJsonCommonSettings *cfg)
Definition: output-json.c:467
AppProtoToString
const char * AppProtoToString(AppProto alproto)
Maps the ALPROTO_*, to its string equivalent.
Definition: app-layer-protos.c:41
LogFileCtx_
Definition: util-logopenfile.h:77
output-json-frame.h
AlertJsonHeader
void AlertJsonHeader(const Packet *p, const PacketAlert *pa, SCJsonBuilder *js, uint16_t flags, JsonAddrInfo *addr, char *xff_buffer)
Definition: output-json-alert.c:206
PacketAlerts_::alerts
PacketAlert * alerts
Definition: decode.h:292
CreateEveThreadCtx
OutputJsonThreadCtx * CreateEveThreadCtx(ThreadVars *t, OutputJsonCtx *ctx)
Definition: output-json-common.c:29
AlertJsonStreamDataCallbackData::payload
MemBuffer * payload
Definition: output-json-alert.c:596
json_addr_info_zero
const JsonAddrInfo json_addr_info_zero
Definition: output-json.c:81
FLOW_PKT_TOSERVER
#define FLOW_PKT_TOSERVER
Definition: flow.h:231
rust.h
Frames
Definition: app-layer-frames.h:58
ACTION_REJECT_ANY
#define ACTION_REJECT_ANY
Definition: action-globals.h:38
FramesContainer
Definition: app-layer-frames.h:71
SCConfValIsFalse
int SCConfValIsFalse(const char *val)
Check if a value is false.
Definition: conf.c:577
ACTION_DROP_REJECT
#define ACTION_DROP_REJECT
Definition: action-globals.h:40
OutputJsonBuilderBuffer
void OutputJsonBuilderBuffer(ThreadVars *tv, const Packet *p, Flow *f, SCJsonBuilder *js, OutputJsonThreadCtx *ctx)
Definition: output-json.c:1021
proto
uint8_t proto
Definition: decode-template.h:0
p
Packet * p
Definition: fuzz_iprep.c:21
SCConfNodeLookupChildValue
const char * SCConfNodeLookupChildValue(const SCConfNode *node, const char *name)
Lookup the value of a child configuration node by name.
Definition: conf.c:852
AlertJsonOutputCtx_::eve_ctx
OutputJsonCtx * eve_ctx
Definition: output-json-alert.c:107
app-layer-ftp.h
Packet_::flowflags
uint8_t flowflags
Definition: decode.h:546
EngineModeIsFirewall
bool EngineModeIsFirewall(void)
Definition: suricata.c:239
TM_ECODE_FAILED
@ TM_ECODE_FAILED
Definition: tm-threads-common.h:82
Flow_::protoctx
void * protoctx
Definition: flow.h:433
DetectFirewallPolicy::action
uint8_t action
Definition: detect.h:925
Packet_::payload_len
uint16_t payload_len
Definition: decode.h:620
SCConfNodeHasChildren
bool SCConfNodeHasChildren(const SCConfNode *node)
Check if a node has any children.
Definition: conf.c:808
Packet_::alerts
PacketAlerts alerts
Definition: decode.h:636
MemBuffer_::offset
uint32_t offset
Definition: util-buffer.h:29
EveHttpAddMetadata
bool EveHttpAddMetadata(const Flow *f, uint64_t tx_id, SCJsonBuilder *js)
Definition: output-json-http.c:488
HttpXFFGetIP
int HttpXFFGetIP(const Flow *f, HttpXFFCfg *xff_cfg, char *dstbuf, int dstbuflen)
Function to return XFF IP if any. The caller needs to lock the flow.
Definition: app-layer-htp-xff.c:183
OutputCtx_::data
void * data
Definition: tm-modules.h:91
TM_ECODE_OK
@ TM_ECODE_OK
Definition: tm-threads-common.h:81
PcapLogGetFilename
char * PcapLogGetFilename(void)
Definition: log-pcap.c:1826
AppLayerParserGetTxFiles
AppLayerGetFileState AppLayerParserGetTxFiles(const Flow *f, void *tx, const uint8_t direction)
Definition: app-layer-parser.c:897
PacketAlert_::tx_id
uint64_t tx_id
Definition: decode.h:254
EveSMBAddMetadata
bool EveSMBAddMetadata(const Flow *f, uint64_t tx_id, SCJsonBuilder *jb)
Definition: output-json-smb.c:34
OutputCtx_
Definition: tm-modules.h:88
app-layer-htp-xff.h
PacketAlert_::action
uint8_t action
Definition: decode.h:251
strlcpy
size_t strlcpy(char *dst, const char *src, size_t siz)
Definition: util-strlcpyu.c:43
JSON_BODY_LOGGING
#define JSON_BODY_LOGGING
Definition: output-json-alert.c:95
SIG_FLAG_FIREWALL
#define SIG_FLAG_FIREWALL
Definition: detect.h:245
OutputJsonThreadCtx_
Definition: output-json.h:85
Signature_::gid
uint32_t gid
Definition: detect.h:721
ACTION_REJECT_DST
#define ACTION_REJECT_DST
Definition: action-globals.h:32
EveIKEAddMetadata
bool EveIKEAddMetadata(const Flow *f, uint64_t tx_id, SCJsonBuilder *js)
Definition: output-json-ike.c:65
JsonAddrInfo_::dp
Port dp
Definition: output-json.h:45
SIG_FLAG_TOSERVER
#define SIG_FLAG_TOSERVER
Definition: detect.h:270
FramesContainer::toclient
Frames toclient
Definition: app-layer-frames.h:73
JsonAlertLogThread_::ctx
OutputJsonThreadCtx * ctx
Definition: output-json-alert.c:113
PacketAlert_::json_info
struct PacketContextData * json_info
Definition: decode.h:256
EveSMTPAddMetadata
bool EveSMTPAddMetadata(const Flow *f, uint64_t tx_id, SCJsonBuilder *js)
Definition: output-json-smtp.c:100
util-debug.h
JB_SET_STRING
#define JB_SET_STRING(jb, key, val)
Definition: rust.h:36
output-json-flow.h
MODULE_NAME
#define MODULE_NAME
Definition: output-json-alert.c:73
PKT_IS_TOSERVER
#define PKT_IS_TOSERVER(p)
Definition: decode.h:239
OutputInitResult_::ctx
OutputCtx * ctx
Definition: output.h:47
LOG_JSON_APP_LAYER
#define LOG_JSON_APP_LAYER
Definition: output-json-alert.c:79
LOG_JSON_WEBSOCKET_PAYLOAD
#define LOG_JSON_WEBSOCKET_PAYLOAD
Definition: output-json-alert.c:86
output-json.h
FrameGetById
Frame * FrameGetById(Frames *frames, const int64_t id)
Definition: app-layer-frames.c:125
DetectReference_::key_len
uint16_t key_len
Definition: detect-reference.h:40
ALPROTO_SMTP
@ ALPROTO_SMTP
Definition: app-layer-protos.h:38
LOG_JSON_PAYLOAD
#define LOG_JSON_PAYLOAD
Definition: output-json-alert.c:75
STREAM_BASE_OFFSET
#define STREAM_BASE_OFFSET(stream)
Definition: stream-tcp-private.h:144
PktSrcEnum
PktSrcEnum
Definition: decode.h:51
util-reference-config.h
AlertJsonOutputCtx_::flags
uint16_t flags
Definition: output-json-alert.c:103
util-print.h
EveNFSAddMetadata
bool EveNFSAddMetadata(const Flow *f, uint64_t tx_id, SCJsonBuilder *jb)
Definition: output-json-nfs.c:62
Signature_::references
DetectReference * references
Definition: detect.h:748
FileContainer_::head
File * head
Definition: util-file.h:38
detect.h
ThreadVars_
Per thread variable structure.
Definition: threadvars.h:58
PacketContextData
Definition: decode.h:242
DETECT_TABLE_PACKET_PRE_FLOW
@ DETECT_TABLE_PACKET_PRE_FLOW
Definition: detect.h:558
EveNFSAddMetadataRPC
bool EveNFSAddMetadataRPC(const Flow *f, uint64_t tx_id, SCJsonBuilder *jb)
Definition: output-json-nfs.c:50
PktSrcToString
const char * PktSrcToString(enum PktSrcEnum pkt_src)
Definition: decode.c:881
DETECT_TABLE_PACKET_FILTER
@ DETECT_TABLE_PACKET_FILTER
Definition: detect.h:560
DetectFirewallPolicyToString
void DetectFirewallPolicyToString(const struct DetectFirewallPolicy *p, char *out, size_t out_size)
Definition: detect-parse.c:3829
JsonAlertLogThread
struct JsonAlertLogThread_ JsonAlertLogThread
output-json-email-common.h
util-time.h
OutputInitResult_::ok
bool ok
Definition: output.h:48
SCLogWarning
#define SCLogWarning(...)
Macro used to log WARNING messages.
Definition: util-debug.h:262
app-layer-parser.h
JsonAlertLogThread_
Definition: output-json-alert.c:110
DetectReference_
Signature reference list.
Definition: detect-reference.h:30
Signature_::action
uint8_t action
Definition: detect.h:690
SCEveJsonSimpleGetLogger
EveJsonSimpleAppLayerLogger * SCEveJsonSimpleGetLogger(AppProto alproto)
Definition: output.c:911
Signature_::flags
uint32_t flags
Definition: detect.h:676
stream.h
DetectReference_::reference_len
uint16_t reference_len
Definition: detect-reference.h:41
JsonAddrInfo_
Definition: output-json.h:41
ACTION_ALERT
#define ACTION_ALERT
Definition: action-globals.h:29
Packet_
Definition: decode.h:515
EveFileInfo
void EveFileInfo(SCJsonBuilder *jb, const File *ff, const uint64_t tx_id, const uint16_t flags)
Definition: output-json.c:124
DetectReference_::reference
char * reference
Definition: detect-reference.h:34
JSON_STREAM_BUFFER_SIZE
#define JSON_STREAM_BUFFER_SIZE
Definition: output-json-alert.c:99
LOG_JSON_PAYLOAD_BASE64
#define LOG_JSON_PAYLOAD_BASE64
Definition: output-json-alert.c:77
conf.h
DETECT_MAX_RULE_SIZE
#define DETECT_MAX_RULE_SIZE
Definition: detect.h:46
SIG_FLAG_HAS_TARGET
#define SIG_FLAG_HAS_TARGET
Definition: detect.h:286
XFF_OVERWRITE
#define XFF_OVERWRITE
Definition: app-layer-htp-xff.h:33
LOG_JSON_PAYLOAD_LENGTH
#define LOG_JSON_PAYLOAD_LENGTH
Definition: output-json-alert.c:88
TmEcode
TmEcode
Definition: tm-threads-common.h:80
SIG_FLAG_SRC_IS_TARGET
#define SIG_FLAG_SRC_IS_TARGET
Definition: detect.h:282
HttpXFFCfg_
Definition: app-layer-htp-xff.h:41
AlertJsonOutputCtx_::payload_buffer_size
uint32_t payload_buffer_size
Definition: output-json-alert.c:104
EvePacket
void EvePacket(const Packet *p, SCJsonBuilder *js, uint32_t max_length)
Jsonify a packet.
Definition: output-json.c:422
MemBuffer_
Definition: util-buffer.h:27
FLOW_PKT_TOCLIENT
#define FLOW_PKT_TOCLIENT
Definition: flow.h:232
EveJsonSimpleAppLayerLogger
Definition: output-eve-bindgen.h:42
DetectReference_::next
struct DetectReference_ * next
Definition: detect-reference.h:43
LOG_JSON_TAGGED_PACKETS
#define LOG_JSON_TAGGED_PACKETS
Definition: output-json-alert.c:78
AppLayerParserGetTx
void * AppLayerParserGetTx(uint8_t ipproto, AppProto alproto, void *alstate, uint64_t tx_id)
Definition: app-layer-parser.c:1134
AlertJsonOutputCtx_::xff_cfg
HttpXFFCfg * xff_cfg
Definition: output-json-alert.c:105
PACKET_ALERT_FLAG_STREAM_MATCH
#define PACKET_ALERT_FLAG_STREAM_MATCH
Definition: decode.h:271
PACKET_ALERT_FLAG_FRAME
#define PACKET_ALERT_FLAG_FRAME
Definition: decode.h:277
log-pcap.h
PacketAlert_::frame_id
int64_t frame_id
Definition: decode.h:255
JsonAddrInfo_::proto
char proto[JSON_PROTO_LEN]
Definition: output-json.h:46
Signature_::class_msg
char * class_msg
Definition: detect.h:746
PacketAlert_::flags
uint8_t flags
Definition: decode.h:252
ACTION_REJECT_BOTH
#define ACTION_REJECT_BOTH
Definition: action-globals.h:33
File_::flags
uint16_t flags
Definition: util-file.h:147
SCConfNodeLookupChild
SCConfNode * SCConfNodeLookupChild(const SCConfNode *node, const char *name)
Lookup a child configuration node by name.
Definition: conf.c:824
File_
Definition: util-file.h:146
OutputInitResult_
Definition: output.h:46
app-layer-frames.h
Packet_::flow
struct Flow_ * flow
Definition: decode.h:563
Packet_::tenant_id
uint32_t tenant_id
Definition: decode.h:677
EveEmailAddMetadata
bool EveEmailAddMetadata(const Flow *f, uint64_t tx_id, SCJsonBuilder *js)
Definition: output-json-email-common.c:195
flags
uint8_t flags
Definition: decode-gre.h:0
AppLayerGetFileState
Definition: util-file.h:44
suricata-common.h
LOG_JSON_WEBSOCKET_PAYLOAD_BASE64
#define LOG_JSON_WEBSOCKET_PAYLOAD_BASE64
Definition: output-json-alert.c:87
JsonAddrInfo_::sp
Port sp
Definition: output-json.h:44
OutputCtx_::DeInit
void(* DeInit)(struct OutputCtx_ *)
Definition: tm-modules.h:94
AppLayerGetFileState::fc
FileContainer * fc
Definition: util-file.h:45
pcap_filename
char pcap_filename[PATH_MAX]
Definition: source-pcap-file-helper.c:166
EveJsonSimpleAppLayerLogger::LogTx
EveJsonSimpleTxLogFunc LogTx
Definition: output-eve-bindgen.h:43
JSON_ADDR_LEN
#define JSON_ADDR_LEN
Definition: output-json.h:37
AlertJsonOutputCtx_
Definition: output-json-alert.c:101
detect-metadata.h
Signature_::action_scope
uint8_t action_scope
Definition: detect.h:697
JsonAlertLogThread_::json_output_ctx
AlertJsonOutputCtx * json_output_ctx
Definition: output-json-alert.c:112
output-json-nfs.h
packet.h
ALPROTO_HTTP1
@ ALPROTO_HTTP1
Definition: app-layer-protos.h:36
MemBufferFree
void MemBufferFree(MemBuffer *buffer)
Definition: util-buffer.c:86
LOG_JSON_VERDICT
#define LOG_JSON_VERDICT
Definition: output-json-alert.c:85
File_::next
struct File_ * next
Definition: util-file.h:159
ACTION_DROP
#define ACTION_DROP
Definition: action-globals.h:30
OutputPacketLoggerFunctions_::LogFunc
PacketLogger LogFunc
Definition: output.h:86
PacketGetAction
uint8_t PacketGetAction(const Packet *p)
Definition: packet.c:61
Signature_::rev
uint32_t rev
Definition: detect.h:722
ALPROTO_WEBSOCKET
@ ALPROTO_WEBSOCKET
Definition: app-layer-protos.h:64
TcpSession_::client
TcpStream client
Definition: stream-tcp-private.h:297
PacketContextData::next
struct PacketContextData * next
Definition: decode.h:244
OutputRegisterPacketSubModule
void OutputRegisterPacketSubModule(LoggerId id, const char *parent_name, const char *name, const char *conf_name, OutputInitSubFunc InitFunc, OutputPacketLoggerFunctions *output_logger_functions)
Register a packet output sub-module.
Definition: output.c:230
tv
ThreadVars * tv
Definition: fuzz_decodepcapfile.c:33
Signature_::prio
int prio
Definition: detect.h:723
ParseSizeStringU32
int ParseSizeStringU32(const char *size, uint32_t *res)
Definition: util-misc.c:174
output-json-alert.h
util-optimize.h
threadvars.h
util-validate.h
Packet_::root
struct Packet_ * root
Definition: decode.h:665
TcpSession_::server
TcpStream server
Definition: stream-tcp-private.h:296
JsonAddrInfo_::src_ip
char src_ip[JSON_ADDR_LEN]
Definition: output-json.h:42
EveAddVerdict
void EveAddVerdict(SCJsonBuilder *jb, const Packet *p, const uint8_t alert_action)
Build verdict object.
Definition: output-json-alert.c:545
PACKET_ALERT_FLAG_RATE_FILTER_MODIFIED
#define PACKET_ALERT_FLAG_RATE_FILTER_MODIFIED
Definition: decode.h:275
HttpXFFCfg_::flags
uint8_t flags
Definition: app-layer-htp-xff.h:42
Signature_::metadata
DetectMetadataHead * metadata
Definition: detect.h:750
DetectFirewallPolicy
Definition: detect.h:924
SCLogError
#define SCLogError(...)
Macro used to log ERROR messages.
Definition: util-debug.h:274
EveHttpLogJSONBodyBase64
void EveHttpLogJSONBodyBase64(SCJsonBuilder *js, Flow *f, uint64_t tx_id)
Definition: output-json-http.c:413
AlertJsonOutputCtx
struct AlertJsonOutputCtx_ AlertJsonOutputCtx
JsonAlertLogThread_::payload_buffer
MemBuffer * payload_buffer
Definition: output-json-alert.c:111
SCFree
#define SCFree(p)
Definition: util-mem.h:61
Packet_::pkt_src
uint8_t pkt_src
Definition: decode.h:625
DetectReference_::key
char * key
Definition: detect-reference.h:32
util-logopenfile.h
Flow_::alstate
void * alstate
Definition: flow.h:479
Signature_::id
uint32_t id
Definition: detect.h:720
Packet_::recursion_level
uint8_t recursion_level
Definition: decode.h:540
LOG_JSON_HTTP_BODY_BASE64
#define LOG_JSON_HTTP_BODY_BASE64
Definition: output-json-alert.c:82
output-json-ike.h
detect-parse.h
FrameJsonLogOneFrame
void FrameJsonLogOneFrame(const uint8_t ipproto, const Frame *frame, Flow *f, const TcpStream *stream, const Packet *p, SCJsonBuilder *jb, MemBuffer *buffer)
log a single frame
Definition: output-json-frame.c:239
util-buffer.h
Signature_
Signature container.
Definition: detect.h:675
LOG_JSON_PACKET
#define LOG_JSON_PACKET
Definition: output-json-alert.c:76
flow-bindgen.h
PACKET_ALERT_FLAG_TX
#define PACKET_ALERT_FLAG_TX
Definition: decode.h:273
JsonAddrInfo_::dst_ip
char dst_ip[JSON_ADDR_LEN]
Definition: output-json.h:43
OutputJsonCtx_::file_ctx
LogFileCtx * file_ctx
Definition: output-json.h:78
LOG_JSON_HTTP_BODY
#define LOG_JSON_HTTP_BODY
Definition: output-json-alert.c:81
METADATA_DEFAULTS
#define METADATA_DEFAULTS
Definition: output-json-alert.c:91
ACTION_ACCEPT
#define ACTION_ACCEPT
Definition: action-globals.h:36
EngineModeIsIPS
int EngineModeIsIPS(void)
Definition: suricata.c:246
LOG_JSON_FLOW
#define LOG_JSON_FLOW
Definition: output-json-alert.c:80
MemBufferWriteRaw
uint32_t MemBufferWriteRaw(MemBuffer *dst, const uint8_t *raw, const uint32_t raw_len)
Write a raw buffer to the MemBuffer dst.
Definition: util-buffer.c:115
PacketAlert_
Definition: decode.h:249
MemBufferWriteString
void MemBufferWriteString(MemBuffer *dst, const char *fmt,...)
Definition: util-buffer.c:130
LOG_DIR_PACKET
@ LOG_DIR_PACKET
Definition: output-eve-bindgen.h:34
Signature_::detect_table
uint8_t detect_table
Definition: detect.h:709
output-json-smb.h
ALPROTO_SMB
@ ALPROTO_SMB
Definition: app-layer-protos.h:43
likely
#define likely(expr)
Definition: util-optimize.h:32
IPPROTO_SCTP
#define IPPROTO_SCTP
Definition: decode.h:1272
PacketContextData::json_string
char * json_string
Definition: decode.h:243
HttpXFFGetIPFromTx
int HttpXFFGetIPFromTx(const Flow *f, uint64_t tx_id, HttpXFFCfg *xff_cfg, char *dstbuf, int dstbuflen)
Function to return XFF IP if any in the selected transaction. The caller needs to lock the flow.
Definition: app-layer-htp-xff.c:152
output-json-smtp.h
TcpSession_
Definition: stream-tcp-private.h:283
output-json-http.h
util-misc.h
PKT_HAS_TAG
#define PKT_HAS_TAG
Definition: decode.h:1302
Signature_::msg
char * msg
Definition: detect.h:743
flow.h
DetectEngineSetParseMetadata
void DetectEngineSetParseMetadata(void)
Definition: detect-engine.c:5129
Flow_::alproto
AppProto alproto
application level protocol
Definition: flow.h:450
StreamReassembleLog
int StreamReassembleLog(const TcpSession *ssn, const TcpStream *stream, StreamReassembleRawFunc Callback, void *cb_data, const uint64_t progress_in, uint64_t *progress_out, const bool eof)
Definition: stream-tcp-reassemble.c:1968
SCCalloc
#define SCCalloc(nm, sz)
Definition: util-mem.h:53
SCConfNode_
Definition: conf.h:37
LOG_JSON_RULE_METADATA
#define LOG_JSON_RULE_METADATA
Definition: output-json-alert.c:83
OutputPacketLoggerFunctions_
Definition: output.h:85
SCConfNode_::val
char * val
Definition: conf.h:39
XFF_DISABLED
#define XFF_DISABLED
Definition: app-layer-htp-xff.h:29
DEBUG_VALIDATE_BUG_ON
#define DEBUG_VALIDATE_BUG_ON(exp)
Definition: util-validate.h:109
LOG_JSON_REFERENCE
#define LOG_JSON_REFERENCE
Definition: output-json-alert.c:89
ALPROTO_NFS
@ ALPROTO_NFS
Definition: app-layer-protos.h:51
MemBufferCreateNew
MemBuffer * MemBufferCreateNew(uint32_t size)
Definition: util-buffer.c:32
output.h
JsonAlertLogRegister
void JsonAlertLogRegister(void)
Definition: output-json-alert.c:1153
AlertJsonStreamDataCallbackData
Definition: output-json-alert.c:595