2008-12-17 00:30:24 +03:00
|
|
|
#!/usr/bin/env python
|
|
|
|
|
|
|
|
"""
|
|
|
|
$Id$
|
|
|
|
|
2010-10-14 18:41:14 +04:00
|
|
|
Copyright (c) 2006-2010 sqlmap developers (http://sqlmap.sourceforge.net/)
|
2010-10-15 03:18:29 +04:00
|
|
|
See the file 'doc/COPYING' for copying permission
|
2008-12-17 00:30:24 +03:00
|
|
|
"""
|
|
|
|
|
|
|
|
import time
|
|
|
|
|
2010-05-13 15:05:35 +04:00
|
|
|
from lib.core.common import calculateDeltaSeconds
|
2009-04-22 15:48:07 +04:00
|
|
|
from lib.core.common import getDelayQuery
|
|
|
|
from lib.core.data import conf
|
2008-12-17 00:30:24 +03:00
|
|
|
from lib.core.data import kb
|
|
|
|
from lib.core.data import logger
|
2009-04-22 15:48:07 +04:00
|
|
|
from lib.core.session import setStacked
|
2008-12-17 00:30:24 +03:00
|
|
|
from lib.request import inject
|
|
|
|
|
|
|
|
def stackedTest():
|
2010-03-27 02:23:25 +03:00
|
|
|
if conf.direct:
|
|
|
|
return
|
|
|
|
|
2010-01-02 05:02:12 +03:00
|
|
|
if kb.stackedTest is not None:
|
2009-04-22 15:48:07 +04:00
|
|
|
return kb.stackedTest
|
|
|
|
|
2008-12-17 00:30:24 +03:00
|
|
|
infoMsg = "testing stacked queries support on parameter "
|
|
|
|
infoMsg += "'%s'" % kb.injParameter
|
|
|
|
logger.info(infoMsg)
|
|
|
|
|
2009-04-22 15:48:07 +04:00
|
|
|
query = getDelayQuery()
|
|
|
|
start = time.time()
|
|
|
|
payload, _ = inject.goStacked(query)
|
2010-05-13 15:05:35 +04:00
|
|
|
duration = calculateDeltaSeconds(start)
|
2008-12-17 00:30:24 +03:00
|
|
|
|
2009-04-22 15:48:07 +04:00
|
|
|
if duration >= conf.timeSec:
|
2008-12-17 00:30:24 +03:00
|
|
|
infoMsg = "the web application supports stacked queries "
|
|
|
|
infoMsg += "on parameter '%s'" % kb.injParameter
|
|
|
|
logger.info(infoMsg)
|
|
|
|
|
|
|
|
kb.stackedTest = payload
|
|
|
|
else:
|
|
|
|
warnMsg = "the web application does not support stacked queries "
|
|
|
|
warnMsg += "on parameter '%s'" % kb.injParameter
|
|
|
|
logger.warn(warnMsg)
|
|
|
|
|
|
|
|
kb.stackedTest = False
|
|
|
|
|
2009-04-22 15:48:07 +04:00
|
|
|
setStacked()
|
|
|
|
|
2008-12-17 00:30:24 +03:00
|
|
|
return kb.stackedTest
|