summaryrefslogtreecommitdiff
path: root/examples/py-flow-info/flow-info.py
diff options
context:
space:
mode:
authorToni Uhlig <matzeton@googlemail.com>2022-09-13 20:33:15 +0200
committerToni Uhlig <matzeton@googlemail.com>2022-09-13 22:05:08 +0200
commitd4633c11927683865d8b7bec5e0e4162bae82a60 (patch)
tree12e0d78562254e297b7ef9c0f9d4cc3c8fa53874 /examples/py-flow-info/flow-info.py
parentaca1615dc13bac949d507c493e9cef80fd2402ef (diff)
New flow event: 'analysis'.
* The goal was to provide a separate event for extracted feature that are not required and only useful for a few (e.g. someone who wants do ML). * Increased network buffer size to 32kB (8192 * 4). * Switched timestamp precision from ms to us for *ALL* timestamps. Signed-off-by: Toni Uhlig <matzeton@googlemail.com>
Diffstat (limited to 'examples/py-flow-info/flow-info.py')
-rwxr-xr-xexamples/py-flow-info/flow-info.py25
1 files changed, 15 insertions, 10 deletions
diff --git a/examples/py-flow-info/flow-info.py b/examples/py-flow-info/flow-info.py
index d341f6c26..770058978 100755
--- a/examples/py-flow-info/flow-info.py
+++ b/examples/py-flow-info/flow-info.py
@@ -182,7 +182,7 @@ def checkEventFilter(json_dict):
'guessed': args.guessed, 'detected': args.detected,
'detection-update': args.detection_update,
'not-detected': args.not_detected,
- 'update': args.update}
+ 'update': args.update, 'analysis': args.analysis}
if flow_events[json_dict['flow_event_name']] is True:
return True
@@ -237,26 +237,27 @@ def onJsonLineRecvd(json_dict, instance, current_flow, global_user_data):
basic_daemon_event_prefix = ''
timestamp = ''
if args.print_timestamp is True:
- if 'thread_ts_msec' in json_dict:
+ if 'thread_ts_usec' in json_dict:
timestamp += '[{}]'.format(time.strftime('%H:%M:%S',
- time.localtime(json_dict['thread_ts_msec'] / 1000)))
- elif 'global_ts_msec' in json_dict:
+ time.localtime(nDPIsrvd.toSeconds(json_dict['thread_ts_usec']))))
+ elif 'global_ts_usec' in json_dict:
timestamp += '[{}]'.format(time.strftime('%H:%M:%S',
- time.localtime(json_dict['global_ts_msec'] / 1000)))
+ time.localtime(nDPIsrvd.toSeconds(json_dict['global_ts_usec']))))
first_seen = ''
if args.print_first_seen is True:
basic_daemon_event_prefix += ' ' * 11
if 'flow_first_seen' in json_dict:
- first_seen = '[' + prettifyTimediff(json_dict['flow_first_seen'] / 1000,
- json_dict['thread_ts_msec'] / 1000) + ']'
+ first_seen = '[' + prettifyTimediff(nDPIsrvd.toSeconds(json_dict['flow_first_seen']),
+ nDPIsrvd.toSeconds(json_dict['thread_ts_usec']) + ']'
last_seen = ''
if args.print_last_seen is True:
basic_daemon_event_prefix += ' ' * 11
- if 'flow_last_seen' in json_dict:
- last_seen = '[' + prettifyTimediff(json_dict['flow_last_seen'] / 1000,
- json_dict['thread_ts_msec'] / 1000) + ']'
+ if current_flow is not None:
+ flow_last_seen = nDPIsrvd.FlowManager.getLastPacketTime(instance, current_flow.flow_id, json_dict)
+ last_seen = '[' + prettifyTimediff(nDPIsrvd.toSeconds(flow_last_seen),
+ nDPIsrvd.toSeconds(json_dict['thread_ts_usec']) + ']'
if 'daemon_event_id' in json_dict:
if json_dict['daemon_event_name'] == 'status':
@@ -345,6 +346,9 @@ def onJsonLineRecvd(json_dict, instance, current_flow, global_user_data):
elif json_dict['flow_event_name'] == 'not-detected':
flow_event_name += '{}{:>16}{}'.format(TermColor.WARNING + TermColor.BOLD + TermColor.BLINK,
json_dict['flow_event_name'], TermColor.END)
+ elif json_dict['flow_event_name'] == 'analysis':
+ flow_event_name += '{}{:>16}{}'.format(TermColor.WARNING + TermColor.BLINK,
+ json_dict['flow_event_name'], TermColor.END)
else:
if json_dict['flow_event_name'] == 'new':
line_suffix = ''
@@ -414,6 +418,7 @@ if __name__ == '__main__':
argparser.add_argument('--end', action='store_true', default=False, help='Print only end flow events.')
argparser.add_argument('--idle', action='store_true', default=False, help='Print only idle flow events.')
argparser.add_argument('--update', action='store_true', default=False, help='Print only update flow events.')
+ argparser.add_argument('--analysis', action='store_true', default=False, help='Print only analysis flow events.')
argparser.add_argument('--detection', action='store_true', default=False, help='Print only detected/detection-update flow events.')
argparser.add_argument('--ipwhois', action='store_true', default=False, help='Use Python-IPWhois to print additional location information.')
args = argparser.parse_args()