From 2d197ffadf91c2522b87ee5b8bfdfe5aee47a323 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Fr=C3=A9d=C3=A9ric=20MOHIER?= Date: Fri, 21 Dec 2018 17:12:12 +0100 Subject: [PATCH] Closes #699 - enhance plain text search engine --- module/datamanager.py | 18 ++++++++++-------- 1 file changed, 10 insertions(+), 8 deletions(-) diff --git a/module/datamanager.py b/module/datamanager.py index 9c9858fd..f52a6661 100644 --- a/module/datamanager.py +++ b/module/datamanager.py @@ -409,21 +409,23 @@ def search_hosts_and_services(self, search, user, get_impacts=True, sorter=None, # Case insensitive pat = re.compile(s, re.IGNORECASE) new_items = [] + # Ordered search in all the items for: displa_name, alias, name and notes for i in items: - if (pat.search(i.get_full_name()) - or (i.__class__.my_type == 'host' and i.alias and pat.search(i.alias))): + if (pat.search(getattr(i, 'display_name', '')) or pat.search(getattr(i, 'alias', '')) + or pat.search(i.get_full_name()) or pat.search(getattr(i, 'notes', ''))): new_items.append(i) - else: - for j in i.impacts + i.source_problems: - if (pat.search(j.get_full_name()) - or (j.__class__.my_type == 'host' and j.alias and pat.search(j.alias))): - new_items.append(i) + # Nothing found in all the items if not new_items: for i in items: + # Search in the last check output if pat.search(i.output): new_items.append(i) - else: + + if not new_items: + # Nothing found in the checks output + for i in items: + # Search in the impacts and source problems last check output for j in i.impacts + i.source_problems: if pat.search(j.output): new_items.append(i)