From 334e77e18eeb1922fb6532cd6d0fe00fb9b59fa9 Mon Sep 17 00:00:00 2001 From: Chris Horsley Date: Fri, 31 Oct 2014 04:34:20 +1000 Subject: [PATCH] Add setup.py, autopep8 --- drivers/python_raw/wappalyzer.py | 19 +++++++++++++------ 1 file changed, 13 insertions(+), 6 deletions(-) diff --git a/drivers/python_raw/wappalyzer.py b/drivers/python_raw/wappalyzer.py index 73df758f2..d4bb34760 100755 --- a/drivers/python_raw/wappalyzer.py +++ b/drivers/python_raw/wappalyzer.py @@ -14,6 +14,7 @@ except ImportError: class Application(object): + def __init__(self, app): self.app = app self.confidence = {} @@ -21,7 +22,8 @@ class Application(object): def set_detected(self, pattern, type, value, key=None): self.detected = True - self.confidence[type + ' ' + (key + ' ' if key else '') + pattern.str] = pattern.confidence + self.confidence[ + type + ' ' + (key + ' ' if key else '') + pattern.str] = pattern.confidence # todo: detect version @@ -31,6 +33,7 @@ class Application(object): class Wappalyzer(object): + def __init__(self, data=None, datafile_path=None): data = data or self.load_data(datafile_path) self.categories = data['categories'] @@ -76,18 +79,22 @@ class Wappalyzer(object): if detection_type in ['url', 'html']: for pattern in self.parse_patterns(patterns): if pattern.regex.search(data[detection_type]): - application.set_detected(pattern, detection_type, data[detection_type]) + application.set_detected( + pattern, detection_type, data[detection_type]) elif detection_type in ['meta', 'headers']: for hm_name, hm_pattern in patterns.iteritems(): for pattern in self.parse_patterns(hm_pattern): - value = data[detection_type].get(hm_name.lower()) + value = data[detection_type].get( + hm_name.lower()) if value and pattern.regex.search(value): - application.set_detected(pattern, detection_type, value, hm_name) + application.set_detected( + pattern, detection_type, value, hm_name) elif detection_type in ['script']: for script in data[detection_type]: for pattern in self.parse_patterns(patterns): if pattern.regex.search(script): - application.set_detected(pattern, detection_type, script) + application.set_detected( + pattern, detection_type, script) elif detection_type in ['website', 'excludes', 'cats', 'implies', 'env']: pass else: @@ -101,12 +108,12 @@ class Wappalyzer(object): return detected_apps class Pattern: + def __init__(self, str): self.str = str self.regex = re.compile(str, re.I) self.confidence = 100 - def parse_patterns(self, patterns): if isinstance(patterns, basestring): patterns = [patterns]