2008-10-15 19:38:22 +04:00
|
|
|
#!/usr/bin/env python
|
|
|
|
|
|
|
|
"""
|
2008-10-15 19:56:32 +04:00
|
|
|
$Id$
|
2008-10-15 19:38:22 +04:00
|
|
|
|
2012-01-11 18:59:46 +04:00
|
|
|
Copyright (c) 2006-2012 sqlmap developers (http://www.sqlmap.org/)
|
2010-10-15 03:18:29 +04:00
|
|
|
See the file 'doc/COPYING' for copying permission
|
2008-10-15 19:38:22 +04:00
|
|
|
"""
|
|
|
|
|
|
|
|
import re
|
|
|
|
|
2011-01-28 19:36:09 +03:00
|
|
|
from lib.core.common import Backend
|
|
|
|
from lib.core.common import Format
|
2008-10-15 19:38:22 +04:00
|
|
|
from lib.core.common import dataToSessionFile
|
2011-02-18 00:39:16 +03:00
|
|
|
from lib.core.common import intersect
|
2008-10-15 19:38:22 +04:00
|
|
|
from lib.core.common import readInput
|
2011-07-08 13:32:58 +04:00
|
|
|
from lib.core.common import singleTimeWarnMessage
|
2010-12-01 20:09:52 +03:00
|
|
|
from lib.core.convert import base64pickle
|
|
|
|
from lib.core.convert import base64unpickle
|
2008-10-15 19:38:22 +04:00
|
|
|
from lib.core.data import conf
|
|
|
|
from lib.core.data import kb
|
|
|
|
from lib.core.data import logger
|
2011-04-23 20:25:09 +04:00
|
|
|
from lib.core.enums import OS
|
2011-01-24 14:04:32 +03:00
|
|
|
from lib.core.settings import SUPPORTED_DBMS
|
2010-12-18 00:29:09 +03:00
|
|
|
from lib.core.settings import UNKNOWN_DBMS_VERSION
|
2008-10-15 19:38:22 +04:00
|
|
|
|
2010-10-11 00:51:11 +04:00
|
|
|
def safeFormatString(value):
|
|
|
|
retVal = value
|
|
|
|
if retVal:
|
|
|
|
retVal = retVal.replace("[", "__LEFT_SQUARE_BRACKET__").replace("]", "__RIGHT_SQUARE_BRACKET__")
|
|
|
|
return retVal
|
|
|
|
|
|
|
|
def unSafeFormatString(value):
|
|
|
|
retVal = value
|
|
|
|
if retVal:
|
|
|
|
retVal = retVal.replace("__LEFT_SQUARE_BRACKET__", "[").replace("__RIGHT_SQUARE_BRACKET__", "]")
|
|
|
|
return retVal
|
|
|
|
|
2008-10-15 19:38:22 +04:00
|
|
|
def setDbms(dbms):
|
|
|
|
"""
|
|
|
|
@param dbms: database management system to be set into the knowledge
|
|
|
|
base as fingerprint.
|
|
|
|
@type dbms: C{str}
|
|
|
|
"""
|
|
|
|
condition = (
|
2008-10-16 19:31:02 +04:00
|
|
|
not kb.resumedQueries
|
2008-10-15 19:38:22 +04:00
|
|
|
or ( kb.resumedQueries.has_key(conf.url) and
|
2008-10-16 19:31:02 +04:00
|
|
|
not kb.resumedQueries[conf.url].has_key("DBMS") )
|
2008-10-15 19:38:22 +04:00
|
|
|
)
|
|
|
|
|
|
|
|
if condition:
|
2010-11-28 21:10:54 +03:00
|
|
|
dataToSessionFile("[%s][%s][%s][DBMS][%s]\n" % (conf.url, kb.injection.place, safeFormatString(conf.parameters[kb.injection.place]), safeFormatString(dbms)))
|
2008-10-15 19:38:22 +04:00
|
|
|
|
2011-01-24 14:04:32 +03:00
|
|
|
firstRegExp = "(%s)" % ("|".join([alias for alias in SUPPORTED_DBMS]))
|
2008-10-15 19:38:22 +04:00
|
|
|
dbmsRegExp = re.search("^%s" % firstRegExp, dbms, re.I)
|
|
|
|
|
|
|
|
if dbmsRegExp:
|
|
|
|
dbms = dbmsRegExp.group(1)
|
|
|
|
|
2011-01-28 19:36:09 +03:00
|
|
|
Backend.setDbms(dbms)
|
2008-10-15 19:38:22 +04:00
|
|
|
|
2011-01-28 19:36:09 +03:00
|
|
|
logger.info("the back-end DBMS is %s" % Backend.getDbms())
|
2008-12-31 00:24:01 +03:00
|
|
|
|
2009-04-22 15:48:07 +04:00
|
|
|
def setOs():
|
|
|
|
"""
|
|
|
|
Example of kb.bannerFp dictionary:
|
|
|
|
|
|
|
|
{
|
|
|
|
'sp': set(['Service Pack 4']),
|
|
|
|
'dbmsVersion': '8.00.194',
|
|
|
|
'dbmsServicePack': '0',
|
|
|
|
'distrib': set(['2000']),
|
|
|
|
'dbmsRelease': '2000',
|
|
|
|
'type': set(['Windows'])
|
|
|
|
}
|
|
|
|
"""
|
|
|
|
|
2011-04-30 17:20:05 +04:00
|
|
|
infoMsg = ""
|
2009-04-22 15:48:07 +04:00
|
|
|
condition = (
|
|
|
|
not kb.resumedQueries
|
|
|
|
or ( kb.resumedQueries.has_key(conf.url) and
|
|
|
|
not kb.resumedQueries[conf.url].has_key("OS") )
|
|
|
|
)
|
|
|
|
|
|
|
|
if not kb.bannerFp:
|
|
|
|
return
|
|
|
|
|
|
|
|
if "type" in kb.bannerFp:
|
2011-04-23 20:25:09 +04:00
|
|
|
Backend.setOs(Format.humanize(kb.bannerFp["type"]))
|
|
|
|
infoMsg = "the back-end DBMS operating system is %s" % Backend.getOs()
|
2009-04-22 15:48:07 +04:00
|
|
|
|
|
|
|
if "distrib" in kb.bannerFp:
|
2011-01-28 19:36:09 +03:00
|
|
|
kb.osVersion = Format.humanize(kb.bannerFp["distrib"])
|
2011-01-20 02:06:15 +03:00
|
|
|
infoMsg += " %s" % kb.osVersion
|
2009-04-22 15:48:07 +04:00
|
|
|
|
|
|
|
if "sp" in kb.bannerFp:
|
2011-01-28 19:36:09 +03:00
|
|
|
kb.osSP = int(Format.humanize(kb.bannerFp["sp"]).replace("Service Pack ", ""))
|
2009-04-22 15:48:07 +04:00
|
|
|
|
2011-04-23 20:25:09 +04:00
|
|
|
elif "sp" not in kb.bannerFp and Backend.isOs(OS.WINDOWS):
|
2009-04-22 15:48:07 +04:00
|
|
|
kb.osSP = 0
|
|
|
|
|
2011-04-23 20:25:09 +04:00
|
|
|
if Backend.getOs() and kb.osVersion and kb.osSP:
|
2009-04-22 15:48:07 +04:00
|
|
|
infoMsg += " Service Pack %d" % kb.osSP
|
|
|
|
|
|
|
|
if infoMsg:
|
|
|
|
logger.info(infoMsg)
|
|
|
|
|
|
|
|
if condition:
|
2011-04-23 20:25:09 +04:00
|
|
|
dataToSessionFile("[%s][%s][%s][OS][%s]\n" % (conf.url, kb.injection.place, safeFormatString(conf.parameters[kb.injection.place]), Backend.getOs()))
|
2009-04-22 15:48:07 +04:00
|
|
|
|
2012-02-27 17:44:07 +04:00
|
|
|
def resumeConfKb(expression, url, value):
|
|
|
|
if expression == "Dynamic markings" and url == conf.url:
|
2010-12-29 22:48:19 +03:00
|
|
|
kb.dynamicMarkings = base64unpickle(value[:-1])
|
2011-04-30 19:29:59 +04:00
|
|
|
infoMsg = "resuming dynamic markings from session file"
|
|
|
|
logger.info(infoMsg)
|
2010-12-29 22:48:19 +03:00
|
|
|
|
2008-10-15 19:38:22 +04:00
|
|
|
elif expression == "DBMS" and url == conf.url:
|
2011-04-30 17:20:05 +04:00
|
|
|
dbms = unSafeFormatString(value[:-1])
|
|
|
|
dbms = dbms.lower()
|
2010-12-18 00:29:09 +03:00
|
|
|
dbmsVersion = [UNKNOWN_DBMS_VERSION]
|
2008-10-15 19:38:22 +04:00
|
|
|
|
2011-04-30 19:29:59 +04:00
|
|
|
infoMsg = "resuming back-end DBMS '%s' " % dbms
|
|
|
|
infoMsg += "from session file"
|
|
|
|
logger.info(infoMsg)
|
2008-10-15 19:38:22 +04:00
|
|
|
|
2011-01-24 14:04:32 +03:00
|
|
|
firstRegExp = "(%s)" % ("|".join([alias for alias in SUPPORTED_DBMS]))
|
2008-10-15 19:38:22 +04:00
|
|
|
dbmsRegExp = re.search("%s ([\d\.]+)" % firstRegExp, dbms)
|
|
|
|
|
|
|
|
if dbmsRegExp:
|
2011-04-30 17:20:05 +04:00
|
|
|
dbms = dbmsRegExp.group(1)
|
2009-07-09 15:05:24 +04:00
|
|
|
dbmsVersion = [ dbmsRegExp.group(2) ]
|
2008-10-15 19:38:22 +04:00
|
|
|
|
|
|
|
if conf.dbms and conf.dbms.lower() != dbms:
|
2011-04-30 17:20:05 +04:00
|
|
|
message = "you provided '%s' as back-end DBMS, " % conf.dbms
|
2008-10-15 19:38:22 +04:00
|
|
|
message += "but from a past scan information on the target URL "
|
|
|
|
message += "sqlmap assumes the back-end DBMS is %s. " % dbms
|
|
|
|
message += "Do you really want to force the back-end "
|
|
|
|
message += "DBMS value? [y/N] "
|
|
|
|
test = readInput(message, default="N")
|
|
|
|
|
|
|
|
if not test or test[0] in ("n", "N"):
|
2011-06-22 19:48:44 +04:00
|
|
|
conf.dbms = None
|
2011-01-28 19:36:09 +03:00
|
|
|
Backend.setDbms(dbms)
|
|
|
|
Backend.setVersionList(dbmsVersion)
|
2008-10-15 19:38:22 +04:00
|
|
|
else:
|
2011-01-28 19:36:09 +03:00
|
|
|
Backend.setDbms(dbms)
|
|
|
|
Backend.setVersionList(dbmsVersion)
|
2008-10-15 19:38:22 +04:00
|
|
|
|
2009-04-22 15:48:07 +04:00
|
|
|
elif expression == "OS" and url == conf.url:
|
2010-10-11 00:51:11 +04:00
|
|
|
os = unSafeFormatString(value[:-1])
|
2009-04-22 15:48:07 +04:00
|
|
|
|
2011-01-02 11:08:38 +03:00
|
|
|
if os and os != 'None':
|
2011-04-30 19:29:59 +04:00
|
|
|
infoMsg = "resuming back-end DBMS operating system '%s' " % os
|
|
|
|
infoMsg += "from session file"
|
|
|
|
logger.info(infoMsg)
|
2011-01-02 11:08:38 +03:00
|
|
|
|
|
|
|
if conf.os and conf.os.lower() != os.lower():
|
2011-04-30 17:20:05 +04:00
|
|
|
message = "you provided '%s' as back-end DBMS operating " % conf.os
|
2011-01-02 11:08:38 +03:00
|
|
|
message += "system, but from a past scan information on the "
|
|
|
|
message += "target URL sqlmap assumes the back-end DBMS "
|
|
|
|
message += "operating system is %s. " % os
|
|
|
|
message += "Do you really want to force the back-end DBMS "
|
|
|
|
message += "OS value? [y/N] "
|
|
|
|
test = readInput(message, default="N")
|
|
|
|
|
|
|
|
if not test or test[0] in ("n", "N"):
|
|
|
|
conf.os = os
|
|
|
|
else:
|
2009-04-22 15:48:07 +04:00
|
|
|
conf.os = os
|
|
|
|
|
2011-04-23 20:25:09 +04:00
|
|
|
Backend.setOs(conf.os)
|
|
|
|
|
2011-04-21 18:05:37 +04:00
|
|
|
elif expression == "Remote temp path" and url == conf.url and conf.tmpPath is None:
|
2011-01-16 02:11:36 +03:00
|
|
|
conf.tmpPath = unSafeFormatString(value[:-1])
|
|
|
|
|
2011-04-30 19:29:59 +04:00
|
|
|
infoMsg = "resuming remote absolute path of temporary "
|
|
|
|
infoMsg += "files directory '%s' from session file" % conf.tmpPath
|
|
|
|
logger.info(infoMsg)
|
2011-01-16 02:11:36 +03:00
|
|
|
|
2011-06-28 01:48:26 +04:00
|
|
|
elif conf.freshQueries:
|
|
|
|
pass
|
|
|
|
|
2011-04-21 18:25:04 +04:00
|
|
|
elif expression == "xp_cmdshell availability" and url == conf.url:
|
|
|
|
kb.xpCmdshellAvailable = True if unSafeFormatString(value[:-1]).lower() == "true" else False
|
2011-04-30 19:29:59 +04:00
|
|
|
infoMsg = "resuming xp_cmdshell availability"
|
|
|
|
logger.info(infoMsg)
|