From bcfae99701e1c7193887b2bfa4d336fd49756b95 Mon Sep 17 00:00:00 2001 From: Miroslav Stampar Date: Fri, 8 Apr 2016 10:32:18 +0200 Subject: [PATCH] Adding new WAF script --- lib/core/settings.py | 2 +- waf/nsfocus.py | 24 ++++++++++++++++++++++++ 2 files changed, 25 insertions(+), 1 deletion(-) create mode 100644 waf/nsfocus.py diff --git a/lib/core/settings.py b/lib/core/settings.py index d44b18356..99eb7b8a4 100644 --- a/lib/core/settings.py +++ b/lib/core/settings.py @@ -20,7 +20,7 @@ from lib.core.enums import OS from lib.core.revision import getRevisionNumber # sqlmap version (...) -VERSION = "1.0.4.4" +VERSION = "1.0.4.6" REVISION = getRevisionNumber() STABLE = VERSION.count('.') <= 2 VERSION_STRING = "sqlmap/%s#%s" % (VERSION, "stable" if STABLE else "dev") diff --git a/waf/nsfocus.py b/waf/nsfocus.py new file mode 100644 index 000000000..4ab958194 --- /dev/null +++ b/waf/nsfocus.py @@ -0,0 +1,24 @@ +#!/usr/bin/env python + +""" +Copyright (c) 2006-2016 sqlmap developers (http://sqlmap.org/) +See the file 'doc/COPYING' for copying permission +""" + +import re + +from lib.core.enums import HTTP_HEADER +from lib.core.settings import WAF_ATTACK_VECTORS + +__product__ = "NSFOCUS Web Application Firewall (NSFOCUS)" + +def detect(get_page): + retval = False + + for vector in WAF_ATTACK_VECTORS: + _, headers, _ = get_page(get=vector) + retval = re.search(r"NSFocus", headers.get(HTTP_HEADER.SERVER, ""), re.I) is not None + if retval: + break + + return retval