Go to the documentation of this file.
66 #define DEFAULT_LOG_FILENAME "eve.json"
67 #define MODULE_NAME "OutputJSON"
69 #define MAX_JSON_SIZE 2048
71 static void OutputJsonDeInitCtx(
OutputCtx *);
72 static void CreateEveCommunityFlowId(SCJsonBuilder *js,
const Flow *f,
const uint16_t seed);
73 static int CreateJSONEther(
76 static const char *TRAFFIC_ID_PREFIX =
"traffic/id/";
77 static const char *TRAFFIC_LABEL_PREFIX =
"traffic/label/";
78 static size_t traffic_id_prefix_len = 0;
79 static size_t traffic_label_prefix_len = 0;
87 traffic_id_prefix_len = strlen(TRAFFIC_ID_PREFIX);
88 traffic_label_prefix_len = strlen(TRAFFIC_LABEL_PREFIX);
101 json_t * retval = json_string(val);
103 if (retval == NULL) {
106 for (u = 0; u < strlen(val); u++) {
107 if (isprint(val[u])) {
116 retval = json_string(retbuf);
122 static int64_t sensor_id = -1;
126 SCJbSetStringFromBytes(jb,
"filename", ff->
name, ff->
name_len);
129 SCJbOpenArray(jb,
"sid");
130 for (uint32_t i = 0; ff->
sid != NULL && i < ff->
sid_cnt; i++) {
131 SCJbAppendUint(jb, ff->
sid[i]);
138 SCJbSetString(jb,
"magic", (
char *)ff->magic);
145 SCJbSetHex(jb,
"md5", (uint8_t *)ff->
md5, (uint32_t)
sizeof(ff->
md5));
148 SCJbSetHex(jb,
"sha1", (uint8_t *)ff->
sha1, (uint32_t)
sizeof(ff->
sha1));
163 SCJbSetHex(jb,
"sha256", (uint8_t *)ff->
sha256, (uint32_t)
sizeof(ff->
sha256));
178 SCJbSetUint(jb,
"start", ff->
start);
179 SCJbSetUint(jb,
"end", ff->
end);
181 SCJbSetUint(jb,
"tx_id", tx_id);
184 static void EveAddPacketVars(
const Packet *p, SCJsonBuilder *js_vars)
186 if (p == NULL || p->
pktvar == NULL) {
192 if (pv->
key || pv->
id > 0) {
194 SCJbOpenArray(js_vars,
"pktvars");
197 SCJbStartObject(js_vars);
199 if (pv->
key != NULL) {
201 uint8_t keybuf[pv->
key_len + 1];
203 SCJbSetPrintAsciiString(js_vars, (
char *)keybuf, pv->
value, pv->
value_len);
206 SCJbSetPrintAsciiString(js_vars, varname, pv->
value, pv->
value_len);
225 static bool SCStringHasPrefix(
const char *s,
const char *prefix)
227 if (strncmp(s, prefix, strlen(prefix)) == 0) {
233 static void EveAddFlowVars(
const Flow *f, SCJsonBuilder *js_root, SCJsonBuilder **js_traffic)
235 if (f == NULL || f->
flowvar == NULL) {
238 SCJsonBuilder *js_flowvars = NULL;
239 SCJsonBuilder *js_traffic_id = NULL;
240 SCJsonBuilder *js_traffic_label = NULL;
241 SCJsonBuilder *js_flowints = NULL;
242 SCJsonBuilder *js_entropyvals = NULL;
243 SCJsonBuilder *js_flowbits = NULL;
252 if (js_flowvars == NULL) {
253 js_flowvars = SCJbNewArray();
254 if (js_flowvars == NULL)
258 SCJbStartObject(js_flowvars);
259 SCJbSetPrintAsciiString(
261 SCJbClose(js_flowvars);
264 if (js_flowvars == NULL) {
265 js_flowvars = SCJbNewArray();
266 if (js_flowvars == NULL)
270 uint8_t keybuf[fv->
keylen + 1];
274 SCJbStartObject(js_flowvars);
275 SCJbSetPrintAsciiString(js_flowvars, (
const char *)keybuf, fv->
data.
fv_str.
value,
277 SCJbClose(js_flowvars);
281 if (js_entropyvals == NULL) {
282 js_entropyvals = SCJbNewObject();
283 if (js_entropyvals == NULL)
293 if (js_flowints == NULL) {
294 js_flowints = SCJbNewObject();
295 if (js_flowints == NULL)
306 if (SCStringHasPrefix(varname, TRAFFIC_ID_PREFIX)) {
307 if (js_traffic_id == NULL) {
308 js_traffic_id = SCJbNewArray();
309 if (
unlikely(js_traffic_id == NULL)) {
313 SCJbAppendString(js_traffic_id, &varname[traffic_id_prefix_len]);
314 }
else if (SCStringHasPrefix(varname, TRAFFIC_LABEL_PREFIX)) {
315 if (js_traffic_label == NULL) {
316 js_traffic_label = SCJbNewArray();
317 if (
unlikely(js_traffic_label == NULL)) {
321 SCJbAppendString(js_traffic_label, &varname[traffic_label_prefix_len]);
323 if (js_flowbits == NULL) {
324 js_flowbits = SCJbNewArray();
328 SCJbAppendString(js_flowbits, varname);
335 SCJbClose(js_flowbits);
336 SCJbSetObject(js_root,
"flowbits", js_flowbits);
337 SCJbFree(js_flowbits);
340 SCJbClose(js_flowints);
341 SCJbSetObject(js_root,
"flowints", js_flowints);
342 SCJbFree(js_flowints);
344 if (js_entropyvals) {
345 SCJbClose(js_entropyvals);
346 SCJbSetObject(js_root,
"entropy", js_entropyvals);
347 SCJbFree(js_entropyvals);
350 SCJbClose(js_flowvars);
351 SCJbSetObject(js_root,
"flowvars", js_flowvars);
352 SCJbFree(js_flowvars);
355 if (js_traffic_id != NULL || js_traffic_label != NULL) {
356 *js_traffic = SCJbNewObject();
357 if (
likely(*js_traffic != NULL)) {
358 if (js_traffic_id != NULL) {
359 SCJbClose(js_traffic_id);
360 SCJbSetObject(*js_traffic,
"id", js_traffic_id);
361 SCJbFree(js_traffic_id);
363 if (js_traffic_label != NULL) {
364 SCJbClose(js_traffic_label);
365 SCJbSetObject(*js_traffic,
"label", js_traffic_label);
366 SCJbFree(js_traffic_label);
368 SCJbClose(*js_traffic);
376 SCJsonBuilder *js_vars = SCJbNewObject();
379 SCJsonBuilder *js_traffic = NULL;
380 EveAddFlowVars(f, js_vars, &js_traffic);
381 if (js_traffic != NULL) {
382 SCJbSetObject(js,
"traffic", js_traffic);
383 SCJbFree(js_traffic);
387 EveAddPacketVars(p, js_vars);
390 SCJbSetObject(js,
"metadata", js_vars);
400 SCJbSetString(js,
"suricata_version",
PROG_VER);
406 CreateJSONEther(js, p, f, dir);
412 SCJbSetUint(js,
"tenant_id", f->
tenant_id);
425 uint32_t max_len = max_length == 0 ?
GET_PKT_LEN(p) : max_length;
428 if (!SCJbOpenObject(js,
"packet_info")) {
431 if (!SCJbSetUint(js,
"linktype", p->
datalink)) {
440 (void)SCJbSetString(js,
"linktype_name", dl_name == NULL ?
"n/a" : dl_name);
470 char srcip[46] = {0}, dstip[46] = {0};
475 if (PacketIsIPv4(p)) {
477 srcip,
sizeof(srcip));
479 dstip,
sizeof(dstip));
480 }
else if (PacketIsIPv6(p)) {
482 srcip,
sizeof(srcip));
484 dstip,
sizeof(dstip));
495 if (PacketIsIPv4(p)) {
497 srcip,
sizeof(srcip));
499 dstip,
sizeof(dstip));
500 }
else if (PacketIsIPv6(p)) {
502 srcip,
sizeof(srcip));
504 dstip,
sizeof(dstip));
509 if (PacketIsIPv4(p)) {
511 srcip,
sizeof(srcip));
513 dstip,
sizeof(dstip));
514 }
else if (PacketIsIPv6(p)) {
516 srcip,
sizeof(srcip));
518 dstip,
sizeof(dstip));
526 if (PacketIsIPv4(p)) {
528 srcip,
sizeof(srcip));
530 dstip,
sizeof(dstip));
531 }
else if (PacketIsIPv6(p)) {
533 srcip,
sizeof(srcip));
535 dstip,
sizeof(dstip));
540 if (PacketIsIPv4(p)) {
542 srcip,
sizeof(srcip));
544 dstip,
sizeof(dstip));
545 }
else if (PacketIsIPv6(p)) {
547 srcip,
sizeof(srcip));
549 dstip,
sizeof(dstip));
579 snprintf(addr->
proto,
sizeof(addr->
proto),
"%" PRIu32, PacketGetIPProto(p));
583 #define COMMUNITY_ID_BUF_SIZE 64
585 static bool CalculateCommunityFlowIdv4(
const Flow *f,
586 const uint16_t seed,
unsigned char *base64buf)
598 uint32_t
src = f->
src.addr_data32[0];
599 uint32_t
dst = f->
dst.addr_data32[0];
601 if (f->
proto == IPPROTO_ICMP)
605 if (f->
proto == IPPROTO_ICMP)
609 ipv4.seed = htons(seed);
610 if (ntohl(
src) < ntohl(
dst) || (
src ==
dst && ntohs(sp) < ntohs(dp))) {
621 ipv4.proto = f->
proto;
625 if (SCSha1HashBuffer((
const uint8_t *)&ipv4,
sizeof(ipv4), hash,
sizeof(hash)) == 1) {
628 if (SCBase64Encode(hash,
sizeof(hash), base64buf + 2, &out_len) == SC_BASE64_OK) {
635 static bool CalculateCommunityFlowIdv6(
const Flow *f,
636 const uint16_t seed,
unsigned char *base64buf)
649 if (f->
proto == IPPROTO_ICMPV6)
653 if (f->
proto == IPPROTO_ICMPV6)
657 ipv6.seed = htons(seed);
658 int cmp_r = memcmp(&f->
src, &f->
dst,
sizeof(f->
src));
659 if ((cmp_r < 0) || (cmp_r == 0 && ntohs(sp) < ntohs(dp))) {
660 memcpy(&ipv6.src, &f->
src.addr_data32, 16);
661 memcpy(&ipv6.dst, &f->
dst.addr_data32, 16);
665 memcpy(&ipv6.src, &f->
dst.addr_data32, 16);
666 memcpy(&ipv6.dst, &f->
src.addr_data32, 16);
670 ipv6.proto = f->
proto;
674 if (SCSha1HashBuffer((
const uint8_t *)&ipv6,
sizeof(ipv6), hash,
sizeof(hash)) == 1) {
677 if (SCBase64Encode(hash,
sizeof(hash), base64buf + 2, &out_len) == SC_BASE64_OK) {
684 static void CreateEveCommunityFlowId(SCJsonBuilder *js,
const Flow *f,
const uint16_t seed)
688 if (CalculateCommunityFlowIdv4(f, seed, buf)) {
689 SCJbSetString(js,
"community_id", (
const char *)buf);
692 if (CalculateCommunityFlowIdv6(f, seed, buf)) {
693 SCJbSetString(js,
"community_id", (
const char *)buf);
703 uint64_t flow_id = FlowGetId(f);
704 SCJbSetUint(js,
"flow_id", flow_id);
706 SCJbSetUint(js,
"parent_id", f->
parent_id);
713 (void) snprintf(eth_addr, 19,
"%02x:%02x:%02x:%02x:%02x:%02x",
714 val[0], val[1], val[2], val[3], val[4], val[5]);
716 SCJbAppendString(js, eth_addr);
718 SCJbSetString(js, key, eth_addr);
727 static int MacSetIterateToJSON(uint8_t *val,
MacSetSide side,
void *data)
738 static int CreateJSONEther(
743 if (PacketIsEthernet(p)) {
744 const EthernetHdr *ethh = PacketGetEthernet(p);
745 SCJbOpenObject(js,
"ether");
746 SCJbSetUint(js,
"ether_type",
SCNtohs(ethh->eth_type));
779 }
else if (f != NULL) {
788 if (
dst != NULL &&
src != NULL) {
789 SCJbOpenObject(js,
"ether");
796 }
else if (f != NULL) {
801 SCJbOpenObject(js,
"ether");
803 info.
dst = SCJbNewArray();
804 info.
src = SCJbNewArray();
817 SCJbSetObject(js,
"dest_macs", info.
src);
818 SCJbSetObject(js,
"src_macs", info.
dst);
821 SCJbSetObject(js,
"dest_macs", info.
dst);
822 SCJbSetObject(js,
"src_macs", info.
src);
838 SCJsonBuilder *js = SCJbNewObject();
845 SCJbSetString(js,
"timestamp", timebuf);
850 if (sensor_id >= 0) {
851 SCJbSetUint(js,
"sensor_id", sensor_id);
856 SCJbSetString(js,
"in_iface", p->
livedev->
dev);
861 SCJbSetUint(js,
"pcap_cnt", p->
pcap_cnt);
865 SCJbSetString(js,
"event_type", event_type);
870 SCJbOpenArray(js,
"vlan");
871 SCJbAppendUint(js, p->
vlan_id[0]);
873 SCJbAppendUint(js, p->
vlan_id[1]);
876 SCJbAppendUint(js, p->
vlan_id[2]);
887 if (addr->
src_ip[0] !=
'\0') {
888 SCJbSetString(js,
"src_ip", addr->
src_ip);
891 SCJbSetUint(js,
"src_port", addr->
sp);
893 if (addr->
dst_ip[0] !=
'\0') {
894 SCJbSetString(js,
"dest_ip", addr->
dst_ip);
897 SCJbSetUint(js,
"dest_port", addr->
dp);
899 if (addr->
proto[0] !=
'\0') {
900 SCJbSetString(js,
"proto", addr->
proto);
904 if (PacketIsIPv4(p)) {
905 SCJbSetUint(js,
"ip_v", 4);
906 }
else if (PacketIsIPv6(p)) {
907 SCJbSetUint(js,
"ip_v", 6);
913 if (PacketIsICMPv4(p)) {
914 SCJbSetUint(js,
"icmp_type", p->
icmp_s.type);
915 SCJbSetUint(js,
"icmp_code", p->
icmp_s.code);
919 if (PacketIsICMPv6(p)) {
920 SCJbSetUint(js,
"icmp_type", PacketGetICMPv6(p)->
type);
921 SCJbSetUint(js,
"icmp_code", PacketGetICMPv6(p)->code);
928 if (eve_ctx != NULL) {
938 SCJsonBuilder *js =
CreateEveHeader(p, dir, event_type, addr, eve_ctx);
943 SCJbSetUint(js,
"tx_id", tx_id);
965 json_object_set_new(js,
"host",
1014 MemBufferReset(*buffer);
1020 size_t jslen = SCJbLen(js);
1023 if (jslen >= remaining) {
1024 size_t expand_by = jslen + 1 - remaining;
1026 if (!
ctx->too_large_warning) {
1030 size_t partial_len =
MIN(
sizeof(partial), jslen);
1031 memcpy(partial, SCJbPtr(js), partial_len - 1);
1032 partial[partial_len - 1] =
'\0';
1033 SCLogWarning(
"Formatted JSON EVE record too large, will be dropped: %s", partial);
1034 ctx->too_large_warning =
true;
1044 static inline enum LogFileType FileTypeFromConf(
const char *typestr)
1048 if (typestr == NULL) {
1050 }
else if (strcmp(typestr,
"file") == 0 || strcmp(typestr,
"regular") == 0) {
1052 }
else if (strcmp(typestr,
"unix_dgram") == 0) {
1054 }
else if (strcmp(typestr,
"unix_stream") == 0) {
1056 }
else if (strcmp(typestr,
"redis") == 0) {
1057 #ifdef HAVE_LIBHIREDIS
1060 FatalError(
"redis JSON output option is not compiled");
1063 SCLogDebug(
"type %s, file type value %d", typestr, log_filetype);
1064 return log_filetype;
1067 static int LogFileTypePrepare(
1077 #ifdef HAVE_LIBHIREDIS
1082 char hostname[1024];
1083 gethostname(hostname, 1023);
1090 if (SCConfLogOpenRedis(redis_node, json_ctx->
file_ctx) < 0) {
1130 SCLogDebug(
"could not create new OutputJsonCtx");
1137 if (sensor_name != NULL) {
1138 SCLogWarning(
"Found deprecated eve-log setting \"sensor-name\". "
1139 "Please set sensor-name globally.");
1142 (void)
SCConfGet(
"sensor-name", &sensor_name);
1147 SCLogDebug(
"AlertJsonInitCtx: Could not create new LogFileCtx");
1161 if (
unlikely(output_ctx == NULL)) {
1165 output_ctx->
data = json_ctx;
1166 output_ctx->
DeInit = OutputJsonDeInitCtx;
1171 if (output_s == NULL) {
1175 enum LogFileType log_filetype = FileTypeFromConf(output_s);
1178 if (filetype != NULL) {
1182 FatalError(
"Invalid JSON output option: %s", output_s);
1188 SCLogInfo(
"Using prefix '%s' for JSON messages", prefix);
1192 FatalError(
"Failed to allocate memory for eve-log.prefix setting.");
1205 if (LogFileTypePrepare(json_ctx, log_filetype, conf) < 0) {
1210 if (sensor_id_s != NULL) {
1212 FatalError(
"Failed to initialize JSON output, "
1213 "invalid sensor-id: %s",
1230 SCLogConfig(
"Enabling Ethernet MAC address logging.");
1238 SCLogConfig(
"Enabling Suricata version logging.");
1247 SCLogConfig(
"Enabling eve community_id logging.");
1253 if (cid_seed != NULL) {
1255 10, 0, cid_seed) < 0)
1257 FatalError(
"Failed to initialize JSON output, "
1258 "invalid community-id-seed: %s",
1280 SCLogDebug(
"returning output_ctx %p", output_ctx);
1282 result.
ctx = output_ctx;
1301 static void OutputJsonDeInitCtx(
OutputCtx *output_ctx)
1305 if (logfile_ctx->dropped) {
1306 SCLogWarning(
"%" PRIu64
" events were dropped due to slow or "
1307 "disconnected socket",
1308 logfile_ctx->dropped);
1310 if (json_ctx->
xff_cfg != NULL) {
#define PKT_IS_TOCLIENT(p)
FlowVarTypeFloat fv_float
void OutputJsonFlush(OutputJsonThreadCtx *ctx)
int SCConfValIsTrue(const char *val)
Check if a value is true.
void CreateIsoTimeString(const SCTime_t ts, char *str, size_t size)
OutputJsonCommonSettings cfg
void HttpXFFGetCfg(SCConfNode *conf, HttpXFFCfg *result)
Function to return XFF configuration from a configuration node.
LogFileCtx * LogFileNewCtx(void)
LogFileNewCtx() Get a new LogFileCtx.
int MemBufferExpand(MemBuffer **buffer, uint32_t expand_by)
expand membuffer by size of 'expand_by'
void LogFileFlush(LogFileCtx *file_ctx)
SCJsonBuilder * CreateEveHeader(const Packet *p, enum SCOutputJsonLogDirection dir, const char *event_type, JsonAddrInfo *addr, OutputJsonCtx *eve_ctx)
struct Flow_::@129::@135 icmp_d
#define JSON_OUTPUT_BUFFER_SIZE
int StringParseUint16(uint16_t *res, int base, size_t len, const char *str)
int SCConfGet(const char *name, const char **vptr)
Retrieve the value of a configuration node.
bool SCProtoNameValid(uint16_t proto)
Function to check if the received protocol number is valid and do we have corresponding name entry fo...
void EveTcpFlags(const uint8_t flags, SCJsonBuilder *js)
jsonify tcp flags field Only add 'true' fields in an attempt to keep things reasonably compact.
const JsonAddrInfo json_addr_info_zero
#define COMMUNITY_ID_BUF_SIZE
bool include_community_id
int SCConfValIsFalse(const char *val)
Check if a value is false.
const char * known_proto[256]
void OutputJsonBuilderBuffer(ThreadVars *tv, const Packet *p, Flow *f, SCJsonBuilder *js, OutputJsonThreadCtx *ctx)
void CreateEveFlowId(SCJsonBuilder *js, const Flow *f)
const char * SCConfNodeLookupChildValue(const SCConfNode *node, const char *name)
Lookup the value of a child configuration node by name.
struct Packet_::@33::@40 icmp_s
struct JSONMACAddrInfo JSONMACAddrInfo
uint8_t sha1[SC_SHA1_LEN]
#define GET_IPV6_DST_ADDR(p)
json_t * SCJsonString(const char *val)
bool include_suricata_version
void PrintStringsToBuffer(uint8_t *dst_buf, uint32_t *dst_buf_offset_ptr, uint32_t dst_buf_size, const uint8_t *src_buf, const uint32_t src_buf_len)
void OutputJsonRegister(void)
size_t strlcpy(char *dst, const char *src, size_t siz)
void JsonAddrInfoInit(const Packet *p, enum SCOutputJsonLogDirection dir, JsonAddrInfo *addr)
SCRunMode SCRunmodeGet(void)
Get the current run mode.
int LogFileWrite(LogFileCtx *file_ctx, MemBuffer *buffer)
#define JB_SET_STRING(jb, key, val)
struct GenericVar_ * next
#define GET_IPV4_DST_ADDR_PTR(p)
#define PKT_IS_TOSERVER(p)
#define DEFAULT_LOG_FILENAME
void EveAddCommonOptions(const OutputJsonCommonSettings *cfg, const Packet *p, const Flow *f, SCJsonBuilder *js, enum SCOutputJsonLogDirection dir)
void OutputRegisterModule(const char *, const char *, OutputInitFunc)
OutputInitResult OutputJsonInitCtx(SCConfNode *conf)
Create a new LogFileCtx for "fast" output style.
Per thread variable structure.
const char * PrintInet(int af, const void *src, char *dst, socklen_t size)
uint64_t FileTrackedSize(const File *file)
get the size of the file
const char * PktSrcToString(enum PktSrcEnum pkt_src)
#define JB_SET_TRUE(jb, key)
#define SCLogWarning(...)
Macro used to log WARNING messages.
void SyslogInitialize(void)
void NullLogInitialize(void)
void EveFileInfo(SCJsonBuilder *jb, const File *ff, const uint64_t tx_id, const uint16_t flags)
union FlowVar_::@122 data
void JSONFormatAndAddMACAddr(SCJsonBuilder *js, const char *key, const uint8_t *val, bool is_array)
struct LiveDevice_ * livedev
@ LOGFILE_TYPE_UNIX_DGRAM
FlowStorageId MacSetGetFlowStorageID(void)
bool SCLogOpenThreadedFile(const char *log_path, const char *append, LogFileCtx *parent_ctx)
typedef __attribute__
DNP3 application header.
@ LOGFILE_TYPE_UNIX_STREAM
void EvePacket(const Packet *p, SCJsonBuilder *js, uint32_t max_length)
Jsonify a packet.
#define SCLogInfo(...)
Macro used to log INFORMATIONAL messages.
void * FlowGetStorageById(const Flow *f, FlowStorageId id)
void EveAddMetadata(const Packet *p, const Flow *f, SCJsonBuilder *js)
int(* Init)(const SCConfNode *conf, const bool threaded, void **init_data)
Function to initialize this filetype.
char proto[JSON_PROTO_LEN]
SCConfNode * SCConfNodeLookupChild(const SCConfNode *node, const char *name)
Lookup a child configuration node by name.
int StringParseUint64(uint64_t *res, int base, size_t len, const char *str)
#define GET_IPV4_SRC_ADDR_PTR(p)
#define PrintBufferData(buf, buf_offset_ptr, buf_size,...)
void(* DeInit)(struct OutputCtx_ *)
const char * VarNameStoreLookupById(const uint32_t id, const enum VarTypes type)
find name for id+type at packet time. As the active store won't be modified, we don't need locks.
int MacSetSize(const MacSet *ms)
#define FLOWVAR_TYPE_FLOAT
int LogFileFreeCtx(LogFileCtx *lf_ctx)
LogFileFreeCtx() Destroy a LogFileCtx (Close the file and free memory)
SCJsonBuilder * CreateEveHeaderWithTxId(const Packet *p, enum SCOutputJsonLogDirection dir, const char *event_type, JsonAddrInfo *addr, uint64_t tx_id, OutputJsonCtx *eve_ctx)
uint8_t sha256[SC_SHA256_LEN]
#define JB_SET_FALSE(jb, key)
struct SCLogConfig_ SCLogConfig
Holds the config state used by the logging api.
char src_ip[JSON_ADDR_LEN]
int SCConfLogOpenGeneric(SCConfNode *conf, LogFileCtx *log_ctx, const char *default_filename, int rotate)
open a generic output "log file", which may be a regular file or a socket
#define GET_IPV6_SRC_ADDR(p)
uint8_t * MacSetGetFirst(const MacSet *ms, MacSetSide side)
#define MEMBUFFER_SIZE(mem_buffer)
Get the MemBuffers current size.
int MacSetForEach(const MacSet *ms, MacSetIteratorFunc IterFunc, void *data)
char dst_ip[JSON_ADDR_LEN]
const char * PcapFileGetFilename(void)
struct Flow_::@127::@133 icmp_s
int OutputJSONMemBufferCallback(const char *str, size_t size, void *data)
int OutputJSONBuffer(json_t *js, LogFileCtx *file_ctx, MemBuffer **buffer)
uint32_t MemBufferWriteRaw(MemBuffer *dst, const uint8_t *raw, const uint32_t raw_len)
Write a raw buffer to the MemBuffer dst.
SCEveFileType * SCEveFindFileType(const char *name)
uint16_t vlan_id[VLAN_MAX_LAYERS]
int(* ThreadInit)(const void *init_data, const ThreadId thread_id, void **thread_data)
Initialize thread specific data.
uint16_t community_id_seed
#define MEMBUFFER_OFFSET(mem_buffer)
Get the MemBuffers current offset.
const char * DatalinkValueToName(int datalink_value)
#define DEBUG_VALIDATE_BUG_ON(exp)
void SCEveRunCallbacks(ThreadVars *tv, const Packet *p, Flow *f, SCJsonBuilder *jb)
Structure used to define an EVE output file type.