aboutsummaryrefslogtreecommitdiff
path: root/schema/flow_event_schema.json
blob: 65ef899fcd921da37bf830419cf9ff5307fce63c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
{
    "type": "object",
    "required": [
        "alias",
        "source",
        "thread_id",
        "packet_id",
        "flow_event_id",
        "flow_event_name",
        "flow_id",
        "flow_packets_processed",
        "flow_first_seen",
        "flow_last_seen",
        "flow_idle_time",
        "flow_min_l4_payload_len",
        "flow_max_l4_payload_len",
        "flow_tot_l4_payload_len",
        "flow_avg_l4_payload_len",
        "l3_proto",
        "l4_proto",
        "midstream",
        "ts_msec",
        "src_ip",
        "dst_ip"
    ],
    "if": {
        "properties": { "flow_event_name": { "const": "update" } }
    },
    "then": {
        "required": [ "flow_datalink", "flow_max_packets" ]
    },
    "if": {
        "properties": { "flow_event_name": { "const": "not-detected" } }
    },
    "then": {
        "required": [ "ndpi" ]
    },
    "if": {
        "properties": { "flow_event_name": { "const": "guessed" } }
    },
    "then": {
        "required": [ "ndpi" ]
    },
    "if": {
        "properties": { "flow_event_name": { "const": "detected" } }
    },
    "then": {
        "required": [ "ndpi" ]
    },
    "if": {
        "properties": { "flow_event_name": { "const": "detection-update" } }
    },
    "then": {
        "required": [ "ndpi" ]
    },
    "properties": {
        "alias": {
            "type": "string"
        },
        "source": {
            "type": "string"
        },
        "thread_id": {
            "type": "number",
            "minimum": 0,
            "maximum": 31
        },
        "packet_id": {
            "type": "number",
            "minimum": 0
        },
        "flow_event_id": {
            "type": "number",
            "minimum": 0,
            "maximum": 8
        },
        "flow_event_name": {
            "type": "string",
            "enum": [
                "invalid",
                "new",
                "end",
                "idle",
                "update",
                "guessed",
                "detected",
                "detection-update",
                "not-detected"
            ]
        },
        "flow_id": {
            "type": "number",
            "minimum": 1
        },
        "flow_datalink": {
            "type": "number",
            "minimum": 0,
            "maximum": 265
        },
        "flow_packets_processed": {
            "type": "number"
        },
        "flow_max_packets": {
            "type": "number",
            "minimum": 0
        },
        "flow_first_seen": {
            "type": "number",
            "minimum": 24710
        },
        "flow_last_seen": {
            "type": "number",
            "minimum": 24710
        },
        "flow_idle_time": {
            "type": "number",
            "minimum": 1
        },
        "flow_min_l4_payload_len": {
            "type": "number"
        },
        "flow_max_l4_payload_len": {
            "type": "number"
        },
        "flow_tot_l4_payload_len": {
            "type": "number"
        },
        "flow_avg_l4_payload_len": {
            "type": "number"
        },
        "l3_proto": {
            "type": "string",
            "enum": [
                "ip4",
                "ip6",
                "unknown"
            ]
        },
        "l4_proto": {
            "oneOf": [
                {
                    "type": "number"
                },
                {
                    "type": "string",
                    "enum": [
                        "tcp",
                        "udp",
                        "icmp",
                        "icmp6"
                    ]
                }
            ]
        },
        "midstream": {
            "type": "number",
            "minimum": 0,
            "maximum": 1
        },
        "ts_msec": {
            "type": "number",
            "minimum": 0
        },
        "src_ip": {
            "type": "string",
            "anyOf" : [
                { "format": "ipv4" },
                { "format": "ipv6" }
            ]
        },
        "dst_ip": {
            "type": "string",
            "anyOf" : [
                { "format": "ipv4" },
                { "format": "ipv6" }
            ]
        },
        "src_port": {
            "type": "number",
            "minimum": 1,
            "maximum": 65535
        },
        "dst_port": {
            "type": "number",
            "minimum": 1,
            "maximum": 65535
        },
        "ndpi": {
            "type": "object"
        },
        "dhcp": {
            "type": "object"
        },
        "bittorrent": {
            "type": "object"
        },
        "mdns": {
            "type": "object"
        },
        "ubntac2": {
            "type": "object"
        },
        "kerberos": {
            "type": "object"
        },
        "telnet": {
            "type": "object"
        },
        "tls": {
            "type": "object"
        },
        "quic": {
            "type": "object"
        },
        "imap": {
            "type": "object"
        },
        "http": {
            "type": "object"
        },
        "pop": {
            "type": "object"
        },
        "smtp": {
            "type": "object"
        },
        "dns": {
            "type": "object"
        },
        "ftp": {
            "type": "object"
        },
        "ssh": {
            "type": "object"
        }
    },
    "additionalProperties": false
}