2013-02-14 15:32:17 +04:00
|
|
|
#!/usr/bin/env python
|
2008-10-15 19:38:22 +04:00
|
|
|
|
|
|
|
"""
|
2015-01-06 17:02:16 +03:00
|
|
|
Copyright (c) 2006-2015 sqlmap developers (http://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
|
|
|
"""
|
2010-05-30 18:53:13 +04:00
|
|
|
|
2010-05-28 18:04:34 +04:00
|
|
|
import codecs
|
2008-10-15 19:38:22 +04:00
|
|
|
|
2011-06-03 15:01:26 +04:00
|
|
|
from ConfigParser import MissingSectionHeaderError
|
2014-04-07 22:17:47 +04:00
|
|
|
from ConfigParser import ParsingError
|
2008-10-15 19:38:22 +04:00
|
|
|
|
|
|
|
from lib.core.common import checkFile
|
2014-12-15 15:36:08 +03:00
|
|
|
from lib.core.common import getUnicode
|
2014-11-26 15:38:21 +03:00
|
|
|
from lib.core.common import openFile
|
2012-04-03 18:46:09 +04:00
|
|
|
from lib.core.common import unArrayizeValue
|
2010-05-28 19:57:43 +04:00
|
|
|
from lib.core.common import UnicodeRawConfigParser
|
2011-02-02 17:06:40 +03:00
|
|
|
from lib.core.data import conf
|
2008-10-15 19:38:22 +04:00
|
|
|
from lib.core.data import logger
|
2012-12-06 17:14:19 +04:00
|
|
|
from lib.core.exception import SqlmapMissingMandatoryOptionException
|
|
|
|
from lib.core.exception import SqlmapSyntaxException
|
2008-10-15 19:38:22 +04:00
|
|
|
from lib.core.optiondict import optDict
|
2011-01-30 14:36:03 +03:00
|
|
|
from lib.core.settings import UNICODE_ENCODING
|
2008-10-15 19:38:22 +04:00
|
|
|
|
|
|
|
config = None
|
|
|
|
|
|
|
|
def configFileProxy(section, option, boolean=False, integer=False):
|
|
|
|
"""
|
|
|
|
Parse configuration file and save settings into the configuration
|
|
|
|
advanced dictionary.
|
|
|
|
"""
|
|
|
|
|
|
|
|
global config
|
|
|
|
|
|
|
|
if config.has_option(section, option):
|
2014-04-07 22:22:51 +04:00
|
|
|
try:
|
|
|
|
if boolean:
|
|
|
|
value = config.getboolean(section, option) if config.get(section, option) else False
|
|
|
|
elif integer:
|
|
|
|
value = config.getint(section, option) if config.get(section, option) else 0
|
|
|
|
else:
|
|
|
|
value = config.get(section, option)
|
|
|
|
except ValueError, ex:
|
|
|
|
errMsg = "error occurred while processing the option "
|
2014-12-15 15:36:08 +03:00
|
|
|
errMsg += "'%s' in provided configuration file ('%s')" % (option, getUnicode(ex))
|
2014-04-07 22:22:51 +04:00
|
|
|
raise SqlmapSyntaxException(errMsg)
|
2008-10-15 19:38:22 +04:00
|
|
|
|
|
|
|
if value:
|
|
|
|
conf[option] = value
|
|
|
|
else:
|
|
|
|
conf[option] = None
|
|
|
|
else:
|
2011-04-30 17:20:05 +04:00
|
|
|
debugMsg = "missing requested option '%s' (section " % option
|
2008-10-15 19:38:22 +04:00
|
|
|
debugMsg += "'%s') into the configuration file, " % section
|
|
|
|
debugMsg += "ignoring. Skipping to next."
|
|
|
|
logger.debug(debugMsg)
|
|
|
|
|
|
|
|
def configFileParser(configFile):
|
|
|
|
"""
|
|
|
|
Parse configuration file and save settings into the configuration
|
|
|
|
advanced dictionary.
|
|
|
|
"""
|
|
|
|
|
|
|
|
global config
|
|
|
|
|
|
|
|
debugMsg = "parsing configuration file"
|
|
|
|
logger.debug(debugMsg)
|
|
|
|
|
|
|
|
checkFile(configFile)
|
2014-11-26 15:38:21 +03:00
|
|
|
configFP = openFile(configFile, "rb")
|
2011-06-03 15:01:26 +04:00
|
|
|
|
|
|
|
try:
|
|
|
|
config = UnicodeRawConfigParser()
|
|
|
|
config.readfp(configFP)
|
2014-12-11 02:35:51 +03:00
|
|
|
except Exception, ex:
|
2014-12-15 15:36:08 +03:00
|
|
|
errMsg = "you have provided an invalid and/or unreadable configuration file ('%s')" % getUnicode(ex)
|
2013-01-04 02:20:55 +04:00
|
|
|
raise SqlmapSyntaxException(errMsg)
|
2008-10-15 19:38:22 +04:00
|
|
|
|
2008-12-04 20:40:03 +03:00
|
|
|
if not config.has_section("Target"):
|
2011-06-03 15:01:26 +04:00
|
|
|
errMsg = "missing a mandatory section 'Target' in the configuration file"
|
2013-01-04 02:20:55 +04:00
|
|
|
raise SqlmapMissingMandatoryOptionException(errMsg)
|
2008-10-15 19:38:22 +04:00
|
|
|
|
2014-04-06 18:45:25 +04:00
|
|
|
condition = not config.has_option("Target", "direct")
|
|
|
|
condition &= not config.has_option("Target", "url")
|
2011-05-11 12:46:40 +04:00
|
|
|
condition &= not config.has_option("Target", "logFile")
|
|
|
|
condition &= not config.has_option("Target", "bulkFile")
|
2008-12-04 20:40:03 +03:00
|
|
|
condition &= not config.has_option("Target", "googleDork")
|
2011-05-11 12:46:40 +04:00
|
|
|
condition &= not config.has_option("Target", "requestFile")
|
2014-07-03 00:27:51 +04:00
|
|
|
condition &= not config.has_option("Target", "sitemapUrl")
|
2011-05-11 12:46:40 +04:00
|
|
|
condition &= not config.has_option("Target", "wizard")
|
2008-12-04 20:40:03 +03:00
|
|
|
|
|
|
|
if condition:
|
2011-05-11 12:46:40 +04:00
|
|
|
errMsg = "missing a mandatory option in the configuration file "
|
2014-07-03 00:27:51 +04:00
|
|
|
errMsg += "(direct, url, logFile, bulkFile, googleDork, requestFile, sitemapUrl or wizard)"
|
2013-01-04 02:20:55 +04:00
|
|
|
raise SqlmapMissingMandatoryOptionException(errMsg)
|
2008-10-15 19:38:22 +04:00
|
|
|
|
|
|
|
for family, optionData in optDict.items():
|
2010-05-28 19:57:43 +04:00
|
|
|
for option, datatype in optionData.items():
|
2012-04-03 18:46:09 +04:00
|
|
|
datatype = unArrayizeValue(datatype)
|
2008-10-15 19:38:22 +04:00
|
|
|
|
2012-04-03 18:46:09 +04:00
|
|
|
boolean = datatype == "boolean"
|
|
|
|
integer = datatype == "integer"
|
2008-10-15 19:38:22 +04:00
|
|
|
|
|
|
|
configFileProxy(family, option, boolean, integer)
|