summaryrefslogtreecommitdiff
path: root/examples/py-flow-info/flow-info.py
diff options
context:
space:
mode:
authorToni Uhlig <matzeton@googlemail.com>2022-11-23 01:23:26 +0100
committerToni Uhlig <matzeton@googlemail.com>2022-12-03 01:23:26 +0100
commitced5f5d4b4f9617966e519fb234e2aaaf677e22b (patch)
tree48c0664c1c88a0163ac2634df70a4c113944d1b0 /examples/py-flow-info/flow-info.py
parent60741d5649ea08bf62c6e895515dc2625925fea0 (diff)
py-flow-info: ignore certain json lines that match various criteria
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.py42
1 files changed, 39 insertions, 3 deletions
diff --git a/examples/py-flow-info/flow-info.py b/examples/py-flow-info/flow-info.py
index b7de8c951..c4324ef53 100755
--- a/examples/py-flow-info/flow-info.py
+++ b/examples/py-flow-info/flow-info.py
@@ -312,15 +312,35 @@ def onJsonLineRecvd(json_dict, instance, current_flow, global_user_data):
if 'ndpi' in json_dict:
if 'proto' in json_dict['ndpi']:
+ if args.ignore_protocol is not None:
+ for proto in args.ignore_protocol:
+ if json_dict['ndpi']['proto'].lower().startswith(proto.lower()) is True:
+ stats.printStatus()
+ return True
ndpi_proto_categ_breed += '[' + str(json_dict['ndpi']['proto']) + ']'
if 'proto_by_ip' in json_dict['ndpi']:
+ if args.ignore_ip_protocol is not None:
+ for proto in args.ignore_ip_protocol:
+ if json_dict['ndpi']['proto_by_ip'].lower().startswith(proto.lower()) is True:
+ stats.printStatus()
+ return True
ndpi_proto_categ_breed += '[' + str(json_dict['ndpi']['proto_by_ip']) + ']'
if 'category' in json_dict['ndpi']:
+ if args.ignore_category is not None:
+ for cat in args.ignore_category:
+ if json_dict['ndpi']['category'].lower().startswith(cat.lower()) is True:
+ stats.printStatus()
+ return True
ndpi_proto_categ_breed += '[' + str(json_dict['ndpi']['category']) + ']'
if 'breed' in json_dict['ndpi']:
+ if args.ignore_breed is not None:
+ for breed in args.ignore_breed:
+ if json_dict['ndpi']['breed'].lower().startswith(breed.lower()) is True:
+ stats.printStatus()
+ return True
ndpi_proto_categ_breed += '[' + str(json_dict['ndpi']['breed']) + ']'
if 'flow_risk' in json_dict['ndpi']:
@@ -425,8 +445,14 @@ def onJsonLineRecvd(json_dict, instance, current_flow, global_user_data):
line_suffix += ']'
flow_event_name += '{}{:>16}{}'.format(flow_active_color, json_dict['flow_event_name'], TermColor.END)
- if args.print_hostname is True and 'ndpi' in json_dict and 'hostname' in json_dict['ndpi']:
- line_suffix += '[{}]'.format(json_dict['ndpi']['hostname'])
+ if 'ndpi' in json_dict and 'hostname' in json_dict['ndpi']:
+ if args.ignore_hostname is not None:
+ for hostname in args.ignore_hostname:
+ if json_dict['ndpi']['hostname'].lower().endswith(hostname.lower()) is True:
+ stats.printStatus()
+ return True
+ if args.print_hostname is True:
+ line_suffix += '[{}]'.format(json_dict['ndpi']['hostname'])
if json_dict['l3_proto'] == 'ip4':
print('{}{}{}{}{}: [{:.>6}] [{}][{:.>5}] [{:.>15}]{} -> [{:.>15}]{} {}{}' \
@@ -482,11 +508,16 @@ if __name__ == '__main__':
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('--analyse', action='store_true', default=False, help='Print only analyse flow events.')
- argparser.add_argument('--detection', action='store_true', default=False, help='Print only detected/detection-update flow events.')
+ argparser.add_argument('--detection', action='store_true', default=False, help='Print only detected/guessed/not-detected flow events.')
argparser.add_argument('--ipwhois', action='store_true', default=False, help='Use Python-IPWhois to print additional location information.')
argparser.add_argument('--print-hostname', action='store_true', default=False, help='Print detected hostnames if available.')
argparser.add_argument('--print-analyse-results', action='store_true', default=False,
help='Print detailed results of analyse events.')
+ argparser.add_argument('--ignore-protocol', action='append', help='Ignore printing lines with a certain protocol.')
+ argparser.add_argument('--ignore-ip-protocol', action='append', help='Ignore printing lines with a certain IP protocol.')
+ argparser.add_argument('--ignore-category', action='append', help='Ignore printing lines with a certain category.')
+ argparser.add_argument('--ignore-breed', action='append', help='Ignore printing lines with a certain breed.')
+ argparser.add_argument('--ignore-hostname', action='append', help='Ignore printing lines with a certain hostname.')
args = argparser.parse_args()
if args.no_color is True:
@@ -496,6 +527,11 @@ if __name__ == '__main__':
import dns, ipwhois
whois_db = dict()
+ if args.detection is True:
+ args.detected = True
+ args.guessed = True
+ args.not_detected = True
+
address = nDPIsrvd.validateAddress(args)
sys.stderr.write('Recv buffer size: {}\n'.format(nDPIsrvd.NETWORK_BUFFER_MAX_SIZE))