2019-05-08 13:47:52 +03:00
#!/usr/bin/env python
2008-10-15 19:38:22 +04:00
"""
2019-01-05 23:38:52 +03:00
Copyright ( c ) 2006 - 2019 sqlmap developers ( http : / / sqlmap . org / )
2017-10-11 15:50:46 +03:00
See the file ' LICENSE ' for copying permission
2008-10-15 19:38:22 +04:00
"""
2019-01-22 03:20:27 +03:00
from __future__ import print_function
2013-09-11 16:57:38 +04:00
import os
2014-12-21 07:15:42 +03:00
import re
2014-09-16 16:12:43 +04:00
import shlex
2008-12-12 22:06:31 +03:00
import sys
2019-06-11 02:45:23 +03:00
try :
from optparse import OptionError as ArgumentError
from optparse import OptionGroup
from optparse import OptionParser as ArgumentParser
from optparse import SUPPRESS_HELP as SUPPRESS
ArgumentParser . add_argument = ArgumentParser . add_option
def _add_argument_group ( self , * args , * * kwargs ) :
return self . add_option_group ( OptionGroup ( self , * args , * * kwargs ) )
ArgumentParser . add_argument_group = _add_argument_group
def _add_argument ( self , * args , * * kwargs ) :
return self . add_option ( * args , * * kwargs )
OptionGroup . add_argument = _add_argument
except ImportError :
from argparse import ArgumentParser
from argparse import ArgumentError
from argparse import SUPPRESS
finally :
def get_actions ( instance ) :
for attr in ( " option_list " , " _group_actions " , " _actions " ) :
if hasattr ( instance , attr ) :
return getattr ( instance , attr )
def get_groups ( parser ) :
return getattr ( parser , " option_groups " , None ) or getattr ( parser , " _action_groups " )
2008-10-15 19:38:22 +04:00
2019-06-06 14:08:56 +03:00
from lib . core . common import checkOldOptions
2013-08-27 15:55:38 +04:00
from lib . core . common import checkSystemEncoding
2016-06-10 19:41:41 +03:00
from lib . core . common import dataToStdout
2011-06-15 15:58:50 +04:00
from lib . core . common import expandMnemonics
2019-05-03 01:48:46 +03:00
from lib . core . common import getSafeExString
2019-03-28 18:04:38 +03:00
from lib . core . compat import xrange
2019-05-06 01:54:21 +03:00
from lib . core . convert import getUnicode
2014-09-16 16:12:43 +04:00
from lib . core . data import cmdLineOptions
from lib . core . data import conf
2008-10-15 19:38:22 +04:00
from lib . core . data import logger
2011-06-16 15:42:13 +04:00
from lib . core . defaults import defaults
2019-06-06 14:08:56 +03:00
from lib . core . dicts import DEPRECATED_OPTIONS
2014-09-16 16:12:43 +04:00
from lib . core . enums import AUTOCOMPLETE_TYPE
from lib . core . exception import SqlmapShellQuitException
2014-12-15 11:11:40 +03:00
from lib . core . exception import SqlmapSyntaxException
2012-07-03 14:09:18 +04:00
from lib . core . settings import BASIC_HELP_ITEMS
2013-02-28 23:20:08 +04:00
from lib . core . settings import DUMMY_URL
2019-02-19 02:21:37 +03:00
from lib . core . settings import INFERENCE_UNKNOWN_CHAR
2011-03-29 03:09:19 +04:00
from lib . core . settings import IS_WIN
2012-07-24 17:43:29 +04:00
from lib . core . settings import MAX_HELP_OPTION_LENGTH
2013-03-20 14:44:09 +04:00
from lib . core . settings import VERSION_STRING
2014-09-16 16:12:43 +04:00
from lib . core . shell import autoCompletion
from lib . core . shell import clearHistory
from lib . core . shell import loadHistory
from lib . core . shell import saveHistory
2019-05-02 01:45:44 +03:00
from thirdparty . six . moves import input as _input
2008-10-15 19:38:22 +04:00
2015-09-10 16:01:30 +03:00
def cmdLineParser ( argv = None ) :
2008-10-15 19:38:22 +04:00
"""
This function parses the command line parameters and arguments
"""
2015-09-10 16:01:30 +03:00
if not argv :
argv = sys . argv
2013-08-27 15:55:38 +04:00
checkSystemEncoding ( )
2017-06-29 16:33:34 +03:00
# Reference: https://stackoverflow.com/a/4012683 (Note: previously used "...sys.getfilesystemencoding() or UNICODE_ENCODING")
_ = getUnicode ( os . path . basename ( argv [ 0 ] ) , encoding = sys . stdin . encoding )
2013-09-11 16:57:38 +04:00
2019-05-02 01:45:44 +03:00
usage = " %s %s [options] " % ( " %s " % os . path . basename ( sys . executable ) if not IS_WIN else " " , " \" %s \" " % _ if " " in _ else _ )
2019-06-11 02:45:23 +03:00
parser = ArgumentParser ( usage = usage )
2008-10-15 19:38:22 +04:00
try :
2019-06-11 02:45:23 +03:00
parser . add_argument ( " --hh " , dest = " advancedHelp " ,
2012-07-03 14:09:18 +04:00
action = " store_true " ,
2012-07-03 14:49:35 +04:00
help = " Show advanced help message and exit " )
2012-07-03 14:09:18 +04:00
2019-06-11 02:45:23 +03:00
parser . add_argument ( " --version " , dest = " showVersion " ,
2013-03-20 14:44:09 +04:00
action = " store_true " ,
2013-04-08 13:25:31 +04:00
help = " Show program ' s version number and exit " )
2013-03-20 14:44:09 +04:00
2019-06-11 02:45:23 +03:00
parser . add_argument ( " -v " , dest = " verbose " , type = int ,
2011-06-16 15:42:13 +04:00
help = " Verbosity level: 0-6 (default %d ) " % defaults . verbose )
2008-12-18 00:35:04 +03:00
2008-12-04 20:40:03 +03:00
# Target options
2019-06-11 02:45:23 +03:00
target = parser . add_argument_group ( " Target " , " At least one of these "
2014-04-01 18:38:50 +04:00
" options has to be provided to define the target(s) " )
2008-12-04 20:40:03 +03:00
2019-06-11 02:45:23 +03:00
target . add_argument ( " -d " , dest = " direct " , help = " Connection string "
2014-04-01 18:38:50 +04:00
" for direct database connection " )
2010-03-27 02:23:25 +03:00
2019-06-11 02:45:23 +03:00
target . add_argument ( " -u " , " --url " , dest = " url " , help = " Target URL (e.g. \" http://www.site.com/vuln.php?id=1 \" ) " )
2008-10-15 19:38:22 +04:00
2019-06-11 02:45:23 +03:00
target . add_argument ( " -l " , dest = " logFile " , help = " Parse target(s) from Burp "
2014-04-01 18:38:50 +04:00
" or WebScarab proxy log file " )
2008-10-15 19:38:22 +04:00
2019-06-11 02:45:23 +03:00
target . add_argument ( " -x " , dest = " sitemapUrl " , help = " Parse target(s) from remote sitemap(.xml) file " )
2014-07-03 00:31:18 +04:00
2019-06-11 02:45:23 +03:00
target . add_argument ( " -m " , dest = " bulkFile " , help = " Scan multiple targets given "
2014-04-01 18:38:50 +04:00
" in a textual file " )
2011-05-11 12:46:40 +04:00
2019-06-11 02:45:23 +03:00
target . add_argument ( " -r " , dest = " requestFile " ,
2010-01-14 23:42:45 +03:00
help = " Load HTTP request from a file " )
2019-06-11 02:45:23 +03:00
target . add_argument ( " -g " , dest = " googleDork " ,
2013-03-15 20:00:01 +04:00
help = " Process Google dork results as target URLs " )
2008-11-20 20:56:09 +03:00
2019-06-11 02:45:23 +03:00
target . add_argument ( " -c " , dest = " configFile " ,
2008-12-04 20:40:03 +03:00
help = " Load options from a configuration INI file " )
2010-01-14 23:42:45 +03:00
2008-12-04 20:40:03 +03:00
# Request options
2019-06-11 02:45:23 +03:00
request = parser . add_argument_group ( " Request " , " These options can be used "
2013-03-15 20:00:01 +04:00
" to specify how to connect to the target URL " )
2008-10-15 19:38:22 +04:00
2019-06-11 02:45:23 +03:00
request . add_argument ( " --method " , dest = " method " ,
2014-11-21 11:41:39 +03:00
help = " Force usage of given HTTP method (e.g. PUT) " )
2019-06-11 02:45:23 +03:00
request . add_argument ( " --data " , dest = " data " ,
2018-10-15 03:15:05 +03:00
help = " Data string to be sent through POST (e.g. \" id=1 \" ) " )
2008-10-15 19:38:22 +04:00
2019-06-11 02:45:23 +03:00
request . add_argument ( " --param-del " , dest = " paramDel " ,
2018-10-15 03:15:05 +03:00
help = " Character used for splitting parameter values (e.g. &) " )
2011-10-07 02:03:33 +04:00
2019-06-11 02:45:23 +03:00
request . add_argument ( " --cookie " , dest = " cookie " ,
2018-10-15 03:15:05 +03:00
help = " HTTP Cookie header value (e.g. \" PHPSESSID=a8d127e.. \" ) " )
2008-10-15 19:38:22 +04:00
2019-06-11 02:45:23 +03:00
request . add_argument ( " --cookie-del " , dest = " cookieDel " ,
2018-10-15 03:15:05 +03:00
help = " Character used for splitting cookie values (e.g. ;) " )
2013-07-31 22:41:19 +04:00
2019-06-11 02:45:23 +03:00
request . add_argument ( " --load-cookies " , dest = " loadCookies " ,
2012-03-07 18:48:45 +04:00
help = " File containing cookies in Netscape/wget format " )
2019-06-11 02:45:23 +03:00
request . add_argument ( " --drop-set-cookie " , dest = " dropSetCookie " , action = " store_true " ,
2010-01-02 05:02:12 +03:00
help = " Ignore Set-Cookie header from response " )
2008-10-15 19:38:22 +04:00
2019-06-11 02:45:23 +03:00
request . add_argument ( " --user-agent " , dest = " agent " ,
2014-04-01 18:38:50 +04:00
help = " HTTP User-Agent header value " )
2008-10-15 19:38:22 +04:00
2019-06-11 02:45:23 +03:00
request . add_argument ( " --random-agent " , dest = " randomAgent " , action = " store_true " ,
2014-04-01 18:38:50 +04:00
help = " Use randomly selected HTTP User-Agent header value " )
2008-10-15 19:38:22 +04:00
2019-06-11 02:45:23 +03:00
request . add_argument ( " --host " , dest = " host " ,
2014-04-01 18:38:50 +04:00
help = " HTTP Host header value " )
2011-12-20 16:52:41 +04:00
2019-06-11 02:45:23 +03:00
request . add_argument ( " --referer " , dest = " referer " ,
2014-04-01 18:38:50 +04:00
help = " HTTP Referer header value " )
2010-01-02 05:02:12 +03:00
2019-06-11 02:45:23 +03:00
request . add_argument ( " -H " , " --header " , dest = " header " ,
2015-07-07 10:24:16 +03:00
help = " Extra header (e.g. \" X-Forwarded-For: 127.0.0.1 \" ) " )
2019-06-11 02:45:23 +03:00
request . add_argument ( " --headers " , dest = " headers " ,
2012-01-07 19:26:54 +04:00
help = " Extra headers (e.g. \" Accept-Language: fr \\ nETag: 123 \" ) " )
2008-12-09 00:24:24 +03:00
2019-06-11 02:45:23 +03:00
request . add_argument ( " --auth-type " , dest = " authType " ,
2018-03-13 15:45:42 +03:00
help = " HTTP authentication type (Basic, Digest, NTLM or PKI) " )
2008-10-15 19:38:22 +04:00
2019-06-11 02:45:23 +03:00
request . add_argument ( " --auth-cred " , dest = " authCred " ,
2018-03-13 15:45:42 +03:00
help = " HTTP authentication credentials (name:password) " )
2010-07-30 16:49:25 +04:00
2019-06-11 02:45:23 +03:00
request . add_argument ( " --auth-file " , dest = " authFile " ,
2015-09-27 16:59:17 +03:00
help = " HTTP authentication PEM cert/private key file " )
2008-10-15 19:38:22 +04:00
2019-06-11 02:45:23 +03:00
request . add_argument ( " --ignore-code " , dest = " ignoreCode " , type = int ,
2018-10-15 03:15:05 +03:00
help = " Ignore (problematic) HTTP error code (e.g. 401) " )
2014-10-13 11:19:25 +04:00
2019-06-11 02:45:23 +03:00
request . add_argument ( " --ignore-proxy " , dest = " ignoreProxy " , action = " store_true " ,
2016-10-14 00:17:54 +03:00
help = " Ignore system default proxy settings " )
2019-06-11 02:45:23 +03:00
request . add_argument ( " --ignore-redirects " , dest = " ignoreRedirects " , action = " store_true " ,
2018-03-13 15:45:42 +03:00
help = " Ignore redirection attempts " )
2016-11-25 15:32:28 +03:00
2019-06-11 02:45:23 +03:00
request . add_argument ( " --ignore-timeouts " , dest = " ignoreTimeouts " , action = " store_true " ,
2018-03-13 15:45:42 +03:00
help = " Ignore connection timeouts " )
2016-10-14 00:17:54 +03:00
2019-06-11 02:45:23 +03:00
request . add_argument ( " --proxy " , dest = " proxy " ,
2013-08-09 15:58:42 +04:00
help = " Use a proxy to connect to the target URL " )
2008-10-15 19:38:22 +04:00
2019-06-11 02:45:23 +03:00
request . add_argument ( " --proxy-cred " , dest = " proxyCred " ,
2018-03-13 15:45:42 +03:00
help = " Proxy authentication credentials (name:password) " )
2010-09-27 17:23:29 +04:00
2019-06-11 02:45:23 +03:00
request . add_argument ( " --proxy-file " , dest = " proxyFile " ,
2013-08-09 16:13:48 +04:00
help = " Load proxy list from a file " )
2019-06-11 02:45:23 +03:00
request . add_argument ( " --tor " , dest = " tor " , action = " store_true " ,
2018-03-13 15:45:42 +03:00
help = " Use Tor anonymity network " )
2013-04-30 16:11:56 +04:00
2019-06-11 02:45:23 +03:00
request . add_argument ( " --tor-port " , dest = " torPort " ,
2018-03-13 15:45:42 +03:00
help = " Set Tor proxy port other than default " )
2013-04-30 16:11:56 +04:00
2019-06-11 02:45:23 +03:00
request . add_argument ( " --tor-type " , dest = " torType " ,
2018-03-13 15:45:42 +03:00
help = " Set Tor proxy type (HTTP, SOCKS4 or SOCKS5 (default)) " )
2013-04-30 16:11:56 +04:00
2019-06-11 02:45:23 +03:00
request . add_argument ( " --check-tor " , dest = " checkTor " , action = " store_true " ,
2018-03-13 15:45:42 +03:00
help = " Check to see if Tor is used properly " )
2013-04-30 16:11:56 +04:00
2019-06-11 02:45:23 +03:00
request . add_argument ( " --delay " , dest = " delay " , type = float ,
2008-11-09 19:57:47 +03:00
help = " Delay in seconds between each HTTP request " )
2019-06-11 02:45:23 +03:00
request . add_argument ( " --timeout " , dest = " timeout " , type = float ,
2018-03-13 15:45:42 +03:00
help = " Seconds to wait before timeout connection (default %d ) " % defaults . timeout )
2008-12-04 20:40:03 +03:00
2019-06-11 02:45:23 +03:00
request . add_argument ( " --retries " , dest = " retries " , type = int ,
2018-03-13 15:45:42 +03:00
help = " Retries when the connection timeouts (default %d ) " % defaults . retries )
2010-01-10 00:08:47 +03:00
2019-06-11 02:45:23 +03:00
request . add_argument ( " --randomize " , dest = " rParam " ,
2013-04-02 19:34:56 +04:00
help = " Randomly change value for given parameter(s) " )
2019-06-11 02:45:23 +03:00
request . add_argument ( " --safe-url " , dest = " safeUrl " ,
2013-03-15 20:00:01 +04:00
help = " URL address to visit frequently during testing " )
2010-04-16 16:44:47 +04:00
2019-06-11 02:45:23 +03:00
request . add_argument ( " --safe-post " , dest = " safePost " ,
2015-04-21 00:55:59 +03:00
help = " POST data to send to a safe URL " )
2019-06-11 02:45:23 +03:00
request . add_argument ( " --safe-req " , dest = " safeReqFile " ,
2015-04-22 17:28:54 +03:00
help = " Load safe HTTP request from a file " )
2019-06-11 02:45:23 +03:00
request . add_argument ( " --safe-freq " , dest = " safeFreq " , type = int ,
2013-03-15 20:00:01 +04:00
help = " Test requests between two visits to a given safe URL " )
2010-04-16 16:44:47 +04:00
2019-06-11 02:45:23 +03:00
request . add_argument ( " --skip-urlencode " , dest = " skipUrlEncode " , action = " store_true " ,
2012-09-26 17:25:01 +04:00
help = " Skip URL encoding of payload data " )
2012-05-25 03:30:33 +04:00
2019-06-11 02:45:23 +03:00
request . add_argument ( " --csrf-token " , dest = " csrfToken " ,
2014-11-17 13:50:05 +03:00
help = " Parameter used to hold anti-CSRF token " )
2014-10-23 13:23:53 +04:00
2019-06-11 02:45:23 +03:00
request . add_argument ( " --csrf-url " , dest = " csrfUrl " ,
2018-09-18 23:05:52 +03:00
help = " URL address to visit for extraction of anti-CSRF token " )
2014-10-23 13:23:53 +04:00
2019-06-11 02:45:23 +03:00
request . add_argument ( " --force-ssl " , dest = " forceSSL " , action = " store_true " ,
2013-04-30 15:56:38 +04:00
help = " Force usage of SSL/HTTPS " )
2019-06-11 02:45:23 +03:00
request . add_argument ( " --chunked " , dest = " chunked " , action = " store_true " ,
2019-03-19 16:48:12 +03:00
help = " Use HTTP chunked transfer encoded (POST) requests " )
2019-03-19 16:07:39 +03:00
2019-06-11 02:45:23 +03:00
request . add_argument ( " --hpp " , dest = " hpp " , action = " store_true " ,
2018-03-13 15:45:42 +03:00
help = " Use HTTP parameter pollution method " )
2013-04-30 16:32:11 +04:00
2019-06-11 02:45:23 +03:00
request . add_argument ( " --eval " , dest = " evalCode " ,
2013-04-30 15:59:44 +04:00
help = " Evaluate provided Python code before the request (e.g. \" import hashlib;id2=hashlib.md5(id).hexdigest() \" ) " )
2019-04-19 14:54:48 +03:00
2010-10-17 01:52:16 +04:00
# Optimization options
2019-06-11 02:45:23 +03:00
optimization = parser . add_argument_group ( " Optimization " , " These options can be used to optimize the performance of sqlmap " )
2010-10-17 01:52:16 +04:00
2019-06-11 02:45:23 +03:00
optimization . add_argument ( " -o " , dest = " optimize " , action = " store_true " ,
2018-03-13 15:45:42 +03:00
help = " Turn on all optimization switches " )
2010-10-17 01:52:16 +04:00
2019-06-11 02:45:23 +03:00
optimization . add_argument ( " --predict-output " , dest = " predictOutput " , action = " store_true " ,
2018-03-13 15:45:42 +03:00
help = " Predict common queries output " )
2010-10-17 01:52:16 +04:00
2019-06-11 02:45:23 +03:00
optimization . add_argument ( " --keep-alive " , dest = " keepAlive " , action = " store_true " ,
2018-03-13 15:45:42 +03:00
help = " Use persistent HTTP(s) connections " )
2010-10-17 01:52:16 +04:00
2019-06-11 02:45:23 +03:00
optimization . add_argument ( " --null-connection " , dest = " nullConnection " , action = " store_true " ,
2018-03-13 15:45:42 +03:00
help = " Retrieve page length without actual HTTP response body " )
2010-10-17 01:52:16 +04:00
2019-06-11 02:45:23 +03:00
optimization . add_argument ( " --threads " , dest = " threads " , type = int ,
2018-03-13 15:45:42 +03:00
help = " Max number of concurrent HTTP(s) "
2011-06-16 15:42:13 +04:00
" requests (default %d ) " % defaults . threads )
2010-10-17 01:52:16 +04:00
2008-10-15 19:38:22 +04:00
# Injection options
2019-06-11 02:45:23 +03:00
injection = parser . add_argument_group ( " Injection " , " These options can be used to specify which parameters to test for, provide custom injection payloads and optional tampering scripts " )
2008-10-15 19:38:22 +04:00
2019-06-11 02:45:23 +03:00
injection . add_argument ( " -p " , dest = " testParameter " ,
2008-12-04 20:40:03 +03:00
help = " Testable parameter(s) " )
2019-06-11 02:45:23 +03:00
injection . add_argument ( " --skip " , dest = " skip " ,
2013-04-04 16:21:57 +04:00
help = " Skip testing for given parameter(s) " )
2019-06-11 02:45:23 +03:00
injection . add_argument ( " --skip-static " , dest = " skipStatic " , action = " store_true " ,
2016-10-26 22:41:57 +03:00
help = " Skip testing parameters that not appear to be dynamic " )
2015-05-18 21:57:15 +03:00
2019-06-11 02:45:23 +03:00
injection . add_argument ( " --param-exclude " , dest = " paramExclude " ,
2018-03-13 15:45:42 +03:00
help = " Regexp to exclude parameters from testing (e.g. \" ses \" ) " )
2016-12-26 01:16:44 +03:00
2019-06-11 02:45:23 +03:00
injection . add_argument ( " --param-filter " , dest = " paramFilter " ,
2019-05-17 12:00:51 +03:00
help = " Select testable parameter(s) by place (e.g. \" POST \" ) " )
2019-06-11 02:45:23 +03:00
injection . add_argument ( " --dbms " , dest = " dbms " ,
2018-06-07 01:24:29 +03:00
help = " Force back-end DBMS to provided value " )
2008-12-05 18:34:13 +03:00
2019-06-11 02:45:23 +03:00
injection . add_argument ( " --dbms-cred " , dest = " dbmsCred " ,
2018-03-13 15:45:42 +03:00
help = " DBMS authentication credentials (user:password) " )
2013-04-30 16:05:50 +04:00
2019-06-11 02:45:23 +03:00
injection . add_argument ( " --os " , dest = " os " ,
2018-06-07 01:24:29 +03:00
help = " Force back-end DBMS operating system to provided value " )
2009-04-22 15:48:07 +04:00
2019-06-11 02:45:23 +03:00
injection . add_argument ( " --invalid-bignum " , dest = " invalidBignum " , action = " store_true " ,
2012-04-26 00:29:07 +04:00
help = " Use big numbers for invalidating values " )
2008-12-09 00:24:24 +03:00
2019-06-11 02:45:23 +03:00
injection . add_argument ( " --invalid-logical " , dest = " invalidLogical " , action = " store_true " ,
2012-04-26 00:29:07 +04:00
help = " Use logical operations for invalidating values " )
2012-03-30 14:50:01 +04:00
2019-06-11 02:45:23 +03:00
injection . add_argument ( " --invalid-string " , dest = " invalidString " , action = " store_true " ,
2014-01-24 00:56:06 +04:00
help = " Use random strings for invalidating values " )
2019-06-11 02:45:23 +03:00
injection . add_argument ( " --no-cast " , dest = " noCast " , action = " store_true " ,
2012-03-30 14:50:01 +04:00
help = " Turn off payload casting mechanism " )
2011-10-24 04:40:06 +04:00
2019-06-11 02:45:23 +03:00
injection . add_argument ( " --no-escape " , dest = " noEscape " , action = " store_true " ,
2013-01-18 18:40:37 +04:00
help = " Turn off string escaping mechanism " )
2012-07-16 13:07:47 +04:00
2019-06-11 02:45:23 +03:00
injection . add_argument ( " --prefix " , dest = " prefix " ,
2012-04-26 00:29:07 +04:00
help = " Injection payload prefix string " )
2019-06-11 02:45:23 +03:00
injection . add_argument ( " --suffix " , dest = " suffix " ,
2012-04-26 00:29:07 +04:00
help = " Injection payload suffix string " )
2019-06-11 02:45:23 +03:00
injection . add_argument ( " --tamper " , dest = " tamper " ,
2010-11-08 13:11:43 +03:00
help = " Use given script(s) for tampering injection data " )
# Detection options
2019-06-11 02:45:23 +03:00
detection = parser . add_argument_group ( " Detection " , " These options can be used to customize the detection phase " )
2010-11-08 13:11:43 +03:00
2019-06-11 02:45:23 +03:00
detection . add_argument ( " --level " , dest = " level " , type = int ,
2018-03-13 15:45:42 +03:00
help = " Level of tests to perform (1-5, default %d ) " % defaults . level )
2010-11-28 21:10:54 +03:00
2019-06-11 02:45:23 +03:00
detection . add_argument ( " --risk " , dest = " risk " , type = int ,
2018-03-13 15:45:42 +03:00
help = " Risk of tests to perform (1-3, default %d ) " % defaults . risk )
2010-11-28 21:10:54 +03:00
2019-06-11 02:45:23 +03:00
detection . add_argument ( " --string " , dest = " string " ,
2018-03-13 15:45:42 +03:00
help = " String to match when query is evaluated to True " )
2008-10-15 19:38:22 +04:00
2019-06-11 02:45:23 +03:00
detection . add_argument ( " --not-string " , dest = " notString " ,
2018-03-13 15:45:42 +03:00
help = " String to match when query is evaluated to False " )
2012-07-26 14:06:02 +04:00
2019-06-11 02:45:23 +03:00
detection . add_argument ( " --regexp " , dest = " regexp " ,
2018-03-13 15:45:42 +03:00
help = " Regexp to match when query is evaluated to True " )
2008-12-05 18:34:13 +03:00
2019-06-11 02:45:23 +03:00
detection . add_argument ( " --code " , dest = " code " , type = int ,
2018-03-13 15:45:42 +03:00
help = " HTTP code to match when query is evaluated to True " )
2011-08-12 20:48:11 +04:00
2019-06-11 02:45:23 +03:00
detection . add_argument ( " --text-only " , dest = " textOnly " , action = " store_true " ,
2011-03-08 01:04:17 +03:00
help = " Compare pages based only on the textual content " )
2010-10-12 23:41:29 +04:00
2019-06-11 02:45:23 +03:00
detection . add_argument ( " --titles " , dest = " titles " , action = " store_true " ,
2011-06-11 03:18:43 +04:00
help = " Compare pages based only on their titles " )
2008-11-12 03:36:50 +03:00
# Techniques options
2019-06-11 02:45:23 +03:00
techniques = parser . add_argument_group ( " Techniques " , " These options can be used to tweak testing of specific SQL injection techniques " )
2008-11-12 03:36:50 +03:00
2019-06-11 02:45:23 +03:00
techniques . add_argument ( " --technique " , dest = " technique " ,
2019-06-07 01:21:43 +03:00
help = " SQL injection techniques to use (default \" %s \" ) " % defaults . technique )
2011-04-06 18:41:44 +04:00
2019-06-11 02:45:23 +03:00
techniques . add_argument ( " --time-sec " , dest = " timeSec " , type = int ,
2018-03-13 15:45:42 +03:00
help = " Seconds to delay the DBMS response (default %d ) " % defaults . timeSec )
2009-04-22 15:48:07 +04:00
2019-06-11 02:45:23 +03:00
techniques . add_argument ( " --union-cols " , dest = " uCols " ,
2010-11-19 18:48:24 +03:00
help = " Range of columns to test for UNION query SQL injection " )
2010-11-14 02:24:41 +03:00
2019-06-11 02:45:23 +03:00
techniques . add_argument ( " --union-char " , dest = " uChar " ,
2011-03-08 01:04:17 +03:00
help = " Character to use for bruteforcing number of columns " )
2010-11-19 17:56:20 +03:00
2019-06-11 02:45:23 +03:00
techniques . add_argument ( " --union-from " , dest = " uFrom " ,
2013-03-21 14:28:44 +04:00
help = " Table to use in FROM part of UNION query SQL injection " )
2019-06-11 02:45:23 +03:00
techniques . add_argument ( " --dns-domain " , dest = " dnsDomain " ,
2012-05-27 22:41:06 +04:00
help = " Domain name used for DNS exfiltration attack " )
2019-06-11 02:45:23 +03:00
techniques . add_argument ( " --second-url " , dest = " secondUrl " ,
2018-03-13 15:45:42 +03:00
help = " Resulting page URL searched for second-order response " )
2012-07-26 16:07:05 +04:00
2019-06-11 02:45:23 +03:00
techniques . add_argument ( " --second-req " , dest = " secondReq " ,
2018-06-19 17:23:17 +03:00
help = " Load second-order HTTP request from file " )
2008-10-15 19:38:22 +04:00
# Fingerprint options
2019-06-11 02:45:23 +03:00
fingerprint = parser . add_argument_group ( " Fingerprint " )
2008-10-15 19:38:22 +04:00
2019-06-11 02:45:23 +03:00
fingerprint . add_argument ( " -f " , " --fingerprint " , dest = " extensiveFp " , action = " store_true " ,
2008-11-16 02:41:31 +03:00
help = " Perform an extensive DBMS version fingerprint " )
2008-10-15 19:38:22 +04:00
# Enumeration options
2019-06-11 02:45:23 +03:00
enumeration = parser . add_argument_group ( " Enumeration " , " These options can be used to enumerate the back-end database management system information, structure and data contained in the tables. Moreover you can run your own SQL statements " )
2008-10-15 19:38:22 +04:00
2019-06-11 02:45:23 +03:00
enumeration . add_argument ( " -a " , " --all " , dest = " getAll " , action = " store_true " ,
2018-03-13 15:45:42 +03:00
help = " Retrieve everything " )
2012-10-05 12:24:09 +04:00
2019-06-11 02:45:23 +03:00
enumeration . add_argument ( " -b " , " --banner " , dest = " getBanner " , action = " store_true " ,
2018-03-13 15:45:42 +03:00
help = " Retrieve DBMS banner " )
2008-10-15 19:38:22 +04:00
2019-06-11 02:45:23 +03:00
enumeration . add_argument ( " --current-user " , dest = " getCurrentUser " , action = " store_true " ,
2008-10-15 19:38:22 +04:00
help = " Retrieve DBMS current user " )
2019-06-11 02:45:23 +03:00
enumeration . add_argument ( " --current-db " , dest = " getCurrentDb " , action = " store_true " ,
2008-10-15 19:38:22 +04:00
help = " Retrieve DBMS current database " )
2019-06-11 02:45:23 +03:00
enumeration . add_argument ( " --hostname " , dest = " getHostname " , action = " store_true " ,
2012-07-12 03:01:57 +04:00
help = " Retrieve DBMS server hostname " )
2019-06-11 02:45:23 +03:00
enumeration . add_argument ( " --is-dba " , dest = " isDba " , action = " store_true " ,
2008-12-18 23:41:11 +03:00
help = " Detect if the DBMS current user is DBA " )
2019-06-11 02:45:23 +03:00
enumeration . add_argument ( " --users " , dest = " getUsers " , action = " store_true " ,
2011-06-16 15:42:13 +04:00
help = " Enumerate DBMS users " )
2008-10-15 19:38:22 +04:00
2019-06-11 02:45:23 +03:00
enumeration . add_argument ( " --passwords " , dest = " getPasswordHashes " , action = " store_true " ,
2010-03-03 21:57:09 +03:00
help = " Enumerate DBMS users password hashes " )
2008-10-15 19:38:22 +04:00
2019-06-11 02:45:23 +03:00
enumeration . add_argument ( " --privileges " , dest = " getPrivileges " , action = " store_true " ,
2010-03-03 21:57:09 +03:00
help = " Enumerate DBMS users privileges " )
2008-10-15 19:38:22 +04:00
2019-06-11 02:45:23 +03:00
enumeration . add_argument ( " --roles " , dest = " getRoles " , action = " store_true " ,
2010-03-25 18:46:06 +03:00
help = " Enumerate DBMS users roles " )
2019-06-11 02:45:23 +03:00
enumeration . add_argument ( " --dbs " , dest = " getDbs " , action = " store_true " ,
2011-06-16 15:42:13 +04:00
help = " Enumerate DBMS databases " )
2008-10-15 19:38:22 +04:00
2019-06-11 02:45:23 +03:00
enumeration . add_argument ( " --tables " , dest = " getTables " , action = " store_true " ,
2011-06-16 15:42:13 +04:00
help = " Enumerate DBMS database tables " )
2008-10-15 19:38:22 +04:00
2019-06-11 02:45:23 +03:00
enumeration . add_argument ( " --columns " , dest = " getColumns " , action = " store_true " ,
2011-06-16 15:42:13 +04:00
help = " Enumerate DBMS database table columns " )
2008-10-15 19:38:22 +04:00
2019-06-11 02:45:23 +03:00
enumeration . add_argument ( " --schema " , dest = " getSchema " , action = " store_true " ,
2011-06-16 15:42:13 +04:00
help = " Enumerate DBMS schema " )
2011-04-29 03:59:00 +04:00
2019-06-11 02:45:23 +03:00
enumeration . add_argument ( " --count " , dest = " getCount " , action = " store_true " ,
2011-06-16 15:42:13 +04:00
help = " Retrieve number of entries for table(s) " )
2011-04-30 04:22:22 +04:00
2019-06-11 02:45:23 +03:00
enumeration . add_argument ( " --dump " , dest = " dumpTable " , action = " store_true " ,
2011-06-16 15:42:13 +04:00
help = " Dump DBMS database table entries " )
2008-10-15 19:38:22 +04:00
2019-06-11 02:45:23 +03:00
enumeration . add_argument ( " --dump-all " , dest = " dumpAll " , action = " store_true " ,
2011-06-16 15:42:13 +04:00
help = " Dump all DBMS databases tables entries " )
2008-10-15 19:38:22 +04:00
2019-06-11 02:45:23 +03:00
enumeration . add_argument ( " --search " , dest = " search " , action = " store_true " ,
2011-06-16 15:42:13 +04:00
help = " Search column(s), table(s) and/or database name(s) " )
2010-05-07 17:40:57 +04:00
2019-06-11 02:45:23 +03:00
enumeration . add_argument ( " --comments " , dest = " getComments " , action = " store_true " ,
2018-06-07 01:46:54 +03:00
help = " Check for DBMS comments during enumeration " )
2013-07-29 20:25:27 +04:00
2019-06-11 02:45:23 +03:00
enumeration . add_argument ( " --statements " , dest = " getStatements " , action = " store_true " ,
2019-05-29 16:52:33 +03:00
help = " Retrieve SQL statements being run on DBMS " )
2019-06-11 02:45:23 +03:00
enumeration . add_argument ( " -D " , dest = " db " ,
2008-10-15 19:38:22 +04:00
help = " DBMS database to enumerate " )
2019-06-11 02:45:23 +03:00
enumeration . add_argument ( " -T " , dest = " tbl " ,
2014-01-13 13:05:49 +04:00
help = " DBMS database table(s) to enumerate " )
2008-10-15 19:38:22 +04:00
2019-06-11 02:45:23 +03:00
enumeration . add_argument ( " -C " , dest = " col " ,
2014-01-13 13:05:49 +04:00
help = " DBMS database table column(s) to enumerate " )
2019-06-11 02:45:23 +03:00
enumeration . add_argument ( " -X " , dest = " exclude " ,
2018-02-13 17:53:50 +03:00
help = " DBMS database identifier(s) to not enumerate " )
2008-10-15 19:38:22 +04:00
2019-06-11 02:45:23 +03:00
enumeration . add_argument ( " -U " , dest = " user " ,
2008-10-15 19:38:22 +04:00
help = " DBMS user to enumerate " )
2019-06-11 02:45:23 +03:00
enumeration . add_argument ( " --exclude-sysdbs " , dest = " excludeSysDbs " , action = " store_true " ,
2018-03-13 15:45:42 +03:00
help = " Exclude DBMS system databases when enumerating tables " )
2008-10-15 19:38:22 +04:00
2019-06-11 02:45:23 +03:00
enumeration . add_argument ( " --pivot-column " , dest = " pivotColumn " ,
2016-05-03 13:37:10 +03:00
help = " Pivot column name " )
2019-06-11 02:45:23 +03:00
enumeration . add_argument ( " --where " , dest = " dumpWhere " ,
2014-02-11 19:20:45 +04:00
help = " Use WHERE condition while table dumping " )
2019-06-11 02:45:23 +03:00
enumeration . add_argument ( " --start " , dest = " limitStart " , type = int ,
2017-03-01 13:09:55 +03:00
help = " First dump table entry to retrieve " )
2008-10-15 19:38:22 +04:00
2019-06-11 02:45:23 +03:00
enumeration . add_argument ( " --stop " , dest = " limitStop " , type = int ,
2017-03-01 13:09:55 +03:00
help = " Last dump table entry to retrieve " )
2008-10-15 19:38:22 +04:00
2019-06-11 02:45:23 +03:00
enumeration . add_argument ( " --first " , dest = " firstChar " , type = int ,
2009-09-26 03:03:45 +04:00
help = " First query output word character to retrieve " )
2019-06-11 02:45:23 +03:00
enumeration . add_argument ( " --last " , dest = " lastChar " , type = int ,
2009-09-26 03:03:45 +04:00
help = " Last query output word character to retrieve " )
2019-06-11 02:45:23 +03:00
enumeration . add_argument ( " --sql-query " , dest = " sqlQuery " ,
2008-12-21 19:35:03 +03:00
help = " SQL statement to be executed " )
2008-10-15 19:38:22 +04:00
2019-06-11 02:45:23 +03:00
enumeration . add_argument ( " --sql-shell " , dest = " sqlShell " , action = " store_true " ,
2008-10-15 19:38:22 +04:00
help = " Prompt for an interactive SQL shell " )
2019-06-11 02:45:23 +03:00
enumeration . add_argument ( " --sql-file " , dest = " sqlFile " ,
2012-07-10 03:27:08 +04:00
help = " Execute SQL statements from given file(s) " )
2014-12-15 15:07:38 +03:00
# Brute force options
2019-06-11 02:45:23 +03:00
brute = parser . add_argument_group ( " Brute force " , " These options can be used to run brute force checks " )
2010-11-09 19:15:55 +03:00
2019-06-11 02:45:23 +03:00
brute . add_argument ( " --common-tables " , dest = " commonTables " , action = " store_true " ,
2018-03-13 15:45:42 +03:00
help = " Check existence of common tables " )
2010-09-30 16:35:45 +04:00
2019-06-11 02:45:23 +03:00
brute . add_argument ( " --common-columns " , dest = " commonColumns " , action = " store_true " ,
2018-03-13 15:45:42 +03:00
help = " Check existence of common columns " )
2010-09-30 16:35:45 +04:00
2019-06-27 18:28:43 +03:00
brute . add_argument ( " --common-files " , dest = " commonFiles " , action = " store_true " ,
help = " Check existence of common files " )
2009-09-26 03:03:45 +04:00
# User-defined function options
2019-06-11 02:45:23 +03:00
udf = parser . add_argument_group ( " User-defined function injection " , " These options can be used to create custom user-defined functions " )
2009-09-26 03:03:45 +04:00
2019-06-11 02:45:23 +03:00
udf . add_argument ( " --udf-inject " , dest = " udfInject " , action = " store_true " ,
2011-06-16 15:42:13 +04:00
help = " Inject custom user-defined functions " )
2009-09-26 03:03:45 +04:00
2019-06-11 02:45:23 +03:00
udf . add_argument ( " --shared-lib " , dest = " shLib " ,
2009-09-26 03:03:45 +04:00
help = " Local path of the shared library " )
2008-12-09 00:24:24 +03:00
2008-10-15 19:38:22 +04:00
# File system options
2019-06-11 02:45:23 +03:00
filesystem = parser . add_argument_group ( " File system access " , " These options can be used to access the back-end database management system underlying file system " )
2008-10-15 19:38:22 +04:00
2019-06-11 02:45:23 +03:00
filesystem . add_argument ( " --file-read " , dest = " fileRead " ,
2018-03-13 15:45:42 +03:00
help = " Read a file from the back-end DBMS file system " )
2008-10-15 19:38:22 +04:00
2019-06-11 02:45:23 +03:00
filesystem . add_argument ( " --file-write " , dest = " fileWrite " ,
2018-03-13 15:45:42 +03:00
help = " Write a local file on the back-end DBMS file system " )
2008-10-15 19:38:22 +04:00
2019-06-11 02:45:23 +03:00
filesystem . add_argument ( " --file-dest " , dest = " fileDest " ,
2018-03-13 15:45:42 +03:00
help = " Back-end DBMS absolute filepath to write to " )
2008-12-09 00:24:24 +03:00
2008-10-15 19:38:22 +04:00
# Takeover options
2019-06-11 02:45:23 +03:00
takeover = parser . add_argument_group ( " Operating system access " , " These options can be used to access the back-end database management system underlying operating system " )
2009-04-22 15:48:07 +04:00
2019-06-11 02:45:23 +03:00
takeover . add_argument ( " --os-cmd " , dest = " osCmd " ,
2009-04-22 15:48:07 +04:00
help = " Execute an operating system command " )
2008-10-15 19:38:22 +04:00
2019-06-11 02:45:23 +03:00
takeover . add_argument ( " --os-shell " , dest = " osShell " , action = " store_true " ,
2018-03-13 15:45:42 +03:00
help = " Prompt for an interactive operating system shell " )
2009-04-22 15:48:07 +04:00
2019-06-11 02:45:23 +03:00
takeover . add_argument ( " --os-pwn " , dest = " osPwn " , action = " store_true " ,
2018-03-13 15:45:42 +03:00
help = " Prompt for an OOB shell, Meterpreter or VNC " )
2009-04-22 15:48:07 +04:00
2019-06-11 02:45:23 +03:00
takeover . add_argument ( " --os-smbrelay " , dest = " osSmb " , action = " store_true " ,
2018-03-13 15:45:42 +03:00
help = " One click prompt for an OOB shell, Meterpreter or VNC " )
2009-04-22 15:48:07 +04:00
2019-06-11 02:45:23 +03:00
takeover . add_argument ( " --os-bof " , dest = " osBof " , action = " store_true " ,
2009-04-22 15:48:07 +04:00
help = " Stored procedure buffer overflow "
" exploitation " )
2019-06-11 02:45:23 +03:00
takeover . add_argument ( " --priv-esc " , dest = " privEsc " , action = " store_true " ,
2013-05-21 00:18:12 +04:00
help = " Database process user privilege escalation " )
2009-04-22 15:48:07 +04:00
2019-06-11 02:45:23 +03:00
takeover . add_argument ( " --msf-path " , dest = " msfPath " ,
2018-03-13 15:45:42 +03:00
help = " Local path where Metasploit Framework is installed " )
2008-10-15 19:38:22 +04:00
2019-06-11 02:45:23 +03:00
takeover . add_argument ( " --tmp-path " , dest = " tmpPath " ,
2018-03-13 15:45:42 +03:00
help = " Remote absolute path of temporary files directory " )
2008-12-09 00:24:24 +03:00
2009-09-26 03:03:45 +04:00
# Windows registry options
2019-06-11 02:45:23 +03:00
windows = parser . add_argument_group ( " Windows registry access " , " These options can be used to access the back-end database management system Windows registry " )
2009-09-26 03:03:45 +04:00
2019-06-11 02:45:23 +03:00
windows . add_argument ( " --reg-read " , dest = " regRead " , action = " store_true " ,
2018-03-13 15:45:42 +03:00
help = " Read a Windows registry key value " )
2009-09-26 03:03:45 +04:00
2019-06-11 02:45:23 +03:00
windows . add_argument ( " --reg-add " , dest = " regAdd " , action = " store_true " ,
2018-03-13 15:45:42 +03:00
help = " Write a Windows registry key value data " )
2009-09-26 03:03:45 +04:00
2019-06-11 02:45:23 +03:00
windows . add_argument ( " --reg-del " , dest = " regDel " , action = " store_true " ,
2018-03-13 15:45:42 +03:00
help = " Delete a Windows registry key value " )
2009-09-26 03:03:45 +04:00
2019-06-11 02:45:23 +03:00
windows . add_argument ( " --reg-key " , dest = " regKey " ,
2018-03-13 15:45:42 +03:00
help = " Windows registry key " )
2009-09-26 03:03:45 +04:00
2019-06-11 02:45:23 +03:00
windows . add_argument ( " --reg-value " , dest = " regVal " ,
2018-03-13 15:45:42 +03:00
help = " Windows registry key value " )
2009-09-26 03:03:45 +04:00
2019-06-11 02:45:23 +03:00
windows . add_argument ( " --reg-data " , dest = " regData " ,
2018-03-13 15:45:42 +03:00
help = " Windows registry key value data " )
2009-09-26 03:03:45 +04:00
2019-06-11 02:45:23 +03:00
windows . add_argument ( " --reg-type " , dest = " regType " ,
2018-03-13 15:45:42 +03:00
help = " Windows registry key value type " )
2009-09-26 03:03:45 +04:00
2010-11-16 17:11:32 +03:00
# General options
2019-06-11 02:45:23 +03:00
general = parser . add_argument_group ( " General " , " These options can be used to set some general working parameters " )
2010-11-16 17:11:32 +03:00
2019-06-11 02:45:23 +03:00
general . add_argument ( " -s " , dest = " sessionFile " ,
2018-03-13 15:45:42 +03:00
help = " Load session from a stored (.sqlite) file " )
2013-03-15 20:22:33 +04:00
2019-06-11 02:45:23 +03:00
general . add_argument ( " -t " , dest = " trafficFile " ,
2018-03-13 15:45:42 +03:00
help = " Log all HTTP traffic into a textual file " )
2010-11-16 17:11:32 +03:00
2019-06-11 02:45:23 +03:00
general . add_argument ( " --batch " , dest = " batch " , action = " store_true " ,
2018-03-13 15:45:42 +03:00
help = " Never ask for user input, use the default behavior " )
2011-05-18 02:55:22 +04:00
2019-06-11 02:45:23 +03:00
general . add_argument ( " --binary-fields " , dest = " binaryFields " ,
2018-03-13 15:45:42 +03:00
help = " Result fields having binary values (e.g. \" digest \" ) " )
2016-05-03 13:52:46 +03:00
2019-06-11 02:45:23 +03:00
general . add_argument ( " --check-internet " , dest = " checkInternet " , action = " store_true " ,
2018-03-13 15:45:42 +03:00
help = " Check Internet connection before assessing the target " )
2017-05-08 00:12:42 +03:00
2019-06-11 02:45:23 +03:00
general . add_argument ( " --crawl " , dest = " crawlDepth " , type = int ,
2018-03-13 15:45:42 +03:00
help = " Crawl the website starting from the target URL " )
2015-04-06 23:07:22 +03:00
2019-06-11 02:45:23 +03:00
general . add_argument ( " --crawl-exclude " , dest = " crawlExclude " ,
2015-04-06 23:07:22 +03:00
help = " Regexp to exclude pages from crawling (e.g. \" logout \" ) " )
2011-07-06 09:44:47 +04:00
2019-06-11 02:45:23 +03:00
general . add_argument ( " --csv-del " , dest = " csvDel " ,
2018-03-13 15:45:42 +03:00
help = " Delimiting character used in CSV output (default \" %s \" ) " % defaults . csvDel )
2011-11-30 21:39:41 +04:00
2019-06-11 02:45:23 +03:00
general . add_argument ( " --charset " , dest = " charset " ,
2017-09-21 15:35:24 +03:00
help = " Blind SQL injection charset (e.g. \" 0123456789abcdef \" ) " )
2019-06-11 02:45:23 +03:00
general . add_argument ( " --dump-format " , dest = " dumpFormat " ,
2018-03-13 15:45:42 +03:00
help = " Format of dumped data (CSV (default), HTML or SQLITE) " )
2012-11-28 13:58:18 +04:00
2019-06-11 02:45:23 +03:00
general . add_argument ( " --encoding " , dest = " encoding " ,
2018-03-13 15:45:42 +03:00
help = " Character encoding used for data retrieval (e.g. GBK) " )
2017-09-21 15:35:24 +03:00
2019-06-11 02:45:23 +03:00
general . add_argument ( " --eta " , dest = " eta " , action = " store_true " ,
2018-03-13 15:45:42 +03:00
help = " Display for each output the estimated time of arrival " )
2010-11-16 17:11:32 +03:00
2019-06-11 02:45:23 +03:00
general . add_argument ( " --flush-session " , dest = " flushSession " , action = " store_true " ,
2018-03-13 15:45:42 +03:00
help = " Flush session files for current target " )
2011-05-18 02:55:22 +04:00
2019-06-11 02:45:23 +03:00
general . add_argument ( " --forms " , dest = " forms " , action = " store_true " ,
2018-03-13 15:45:42 +03:00
help = " Parse and test forms on target URL " )
2011-07-06 09:44:47 +04:00
2019-06-11 02:45:23 +03:00
general . add_argument ( " --fresh-queries " , dest = " freshQueries " , action = " store_true " ,
2018-03-13 15:45:42 +03:00
help = " Ignore query results stored in session file " )
2010-11-16 17:11:32 +03:00
2019-06-11 02:45:23 +03:00
general . add_argument ( " --har " , dest = " harFile " ,
2017-07-03 17:55:24 +03:00
help = " Log all HTTP traffic into a HAR file " )
2019-06-11 02:45:23 +03:00
general . add_argument ( " --hex " , dest = " hexConvert " , action = " store_true " ,
2018-06-07 01:46:54 +03:00
help = " Use hex conversion during data retrieval " )
2012-02-21 15:44:48 +04:00
2019-06-11 02:45:23 +03:00
general . add_argument ( " --output-dir " , dest = " outputDir " , action = " store " ,
2018-03-13 15:45:42 +03:00
help = " Custom output directory path " )
2012-07-03 02:50:23 +04:00
2019-06-11 02:45:23 +03:00
general . add_argument ( " --parse-errors " , dest = " parseErrors " , action = " store_true " ,
2018-03-13 15:45:42 +03:00
help = " Parse and display DBMS error messages from responses " )
2011-07-06 09:44:47 +04:00
2019-06-11 02:45:23 +03:00
general . add_argument ( " --preprocess " , dest = " preprocess " ,
2019-04-19 14:54:48 +03:00
help = " Use given script(s) for preprocessing of response data " )
2019-03-04 17:24:12 +03:00
2019-06-11 02:45:23 +03:00
general . add_argument ( " --repair " , dest = " repair " , action = " store_true " ,
2019-02-19 02:21:37 +03:00
help = " Redump entries having unknown character marker ( %s ) " % INFERENCE_UNKNOWN_CHAR )
2019-06-11 02:45:23 +03:00
general . add_argument ( " --save " , dest = " saveConfig " ,
2018-03-13 15:45:42 +03:00
help = " Save options to a configuration INI file " )
2010-11-16 17:11:32 +03:00
2019-06-11 02:45:23 +03:00
general . add_argument ( " --scope " , dest = " scope " ,
2013-04-30 16:32:11 +04:00
help = " Regexp to filter targets from provided proxy log " )
2019-06-11 02:45:23 +03:00
general . add_argument ( " --test-filter " , dest = " testFilter " ,
2013-04-30 16:32:11 +04:00
help = " Select tests by payloads and/or titles (e.g. ROW) " )
2019-06-11 02:45:23 +03:00
general . add_argument ( " --test-skip " , dest = " testSkip " ,
2015-10-01 12:57:33 +03:00
help = " Skip tests by payloads and/or titles (e.g. BENCHMARK) " )
2019-06-11 02:45:23 +03:00
general . add_argument ( " --update " , dest = " updateAll " , action = " store_true " ,
2018-03-13 15:45:42 +03:00
help = " Update sqlmap " )
2010-11-16 17:11:32 +03:00
2010-10-16 03:26:48 +04:00
# Miscellaneous options
2019-06-11 02:45:23 +03:00
miscellaneous = parser . add_argument_group ( " Miscellaneous " )
2010-09-16 14:23:51 +04:00
2019-06-11 02:45:23 +03:00
miscellaneous . add_argument ( " -z " , dest = " mnemonics " ,
2018-03-13 15:45:42 +03:00
help = " Use short mnemonics (e.g. \" flu,bat,ban,tec=EU \" ) " )
2011-06-15 15:58:50 +04:00
2019-06-11 02:45:23 +03:00
miscellaneous . add_argument ( " --alert " , dest = " alert " ,
2018-03-13 15:45:42 +03:00
help = " Run host OS command(s) when SQL injection is found " )
2012-12-11 15:48:58 +04:00
2019-06-11 02:45:23 +03:00
miscellaneous . add_argument ( " --answers " , dest = " answers " ,
2018-10-15 03:15:05 +03:00
help = " Set predefined answers (e.g. \" quit=N,follow=N \" ) " )
2012-11-21 13:16:13 +04:00
2019-06-11 02:45:23 +03:00
miscellaneous . add_argument ( " --beep " , dest = " beep " , action = " store_true " ,
2018-03-13 15:45:42 +03:00
help = " Beep on question and/or when SQL injection is found " )
2012-12-11 15:02:06 +04:00
2019-06-11 02:45:23 +03:00
miscellaneous . add_argument ( " --cleanup " , dest = " cleanup " , action = " store_true " ,
2018-03-13 15:45:42 +03:00
help = " Clean up the DBMS from sqlmap specific UDF and tables " )
2010-05-21 13:35:36 +04:00
2019-06-11 02:45:23 +03:00
miscellaneous . add_argument ( " --dependencies " , dest = " dependencies " , action = " store_true " ,
2018-10-15 01:56:23 +03:00
help = " Check for missing (optional) sqlmap dependencies " )
2011-06-27 12:21:33 +04:00
2019-06-11 02:45:23 +03:00
miscellaneous . add_argument ( " --disable-coloring " , dest = " disableColoring " , action = " store_true " ,
2018-03-13 15:45:42 +03:00
help = " Disable console output coloring " )
2012-08-16 00:31:25 +04:00
2019-06-11 02:45:23 +03:00
miscellaneous . add_argument ( " --gpage " , dest = " googlePage " , type = int ,
2018-03-13 15:45:42 +03:00
help = " Use Google dork results from specified page number " )
2011-03-23 14:57:57 +03:00
2019-06-11 02:45:23 +03:00
miscellaneous . add_argument ( " --list-tampers " , dest = " listTampers " , action = " store_true " ,
2018-07-31 03:18:33 +03:00
help = " Display list of available tamper scripts " )
2019-06-11 02:45:23 +03:00
miscellaneous . add_argument ( " --mobile " , dest = " mobile " , action = " store_true " ,
2018-03-13 15:45:42 +03:00
help = " Imitate smartphone through HTTP User-Agent header " )
2011-04-29 23:27:23 +04:00
2019-06-11 02:45:23 +03:00
miscellaneous . add_argument ( " --offline " , dest = " offline " , action = " store_true " ,
2018-03-13 15:45:42 +03:00
help = " Work in offline mode (only use session data) " )
2015-07-10 17:10:24 +03:00
2019-06-11 02:45:23 +03:00
miscellaneous . add_argument ( " --purge " , dest = " purge " , action = " store_true " ,
2018-06-21 00:52:08 +03:00
help = " Safely remove all content from sqlmap data directory " )
2012-04-23 18:24:23 +04:00
2019-06-11 02:45:23 +03:00
miscellaneous . add_argument ( " --skip-waf " , dest = " skipWaf " , action = " store_true " ,
2018-09-14 11:01:31 +03:00
help = " Skip heuristic detection of WAF/IPS protection " )
2016-05-31 15:55:56 +03:00
2019-06-11 02:45:23 +03:00
miscellaneous . add_argument ( " --smart " , dest = " smart " , action = " store_true " ,
2018-03-13 15:45:42 +03:00
help = " Conduct thorough tests only if positive heuristic(s) " )
2011-07-10 19:16:58 +04:00
2019-06-11 02:45:23 +03:00
miscellaneous . add_argument ( " --sqlmap-shell " , dest = " sqlmapShell " , action = " store_true " ,
2018-03-13 15:45:42 +03:00
help = " Prompt for an interactive sqlmap shell " )
2016-05-31 15:55:56 +03:00
2019-06-11 02:45:23 +03:00
miscellaneous . add_argument ( " --tmp-dir " , dest = " tmpDir " ,
2018-03-13 15:45:42 +03:00
help = " Local directory for storing temporary files " )
2014-09-16 16:12:43 +04:00
2019-06-11 02:45:23 +03:00
miscellaneous . add_argument ( " --web-root " , dest = " webRoot " ,
2018-03-13 15:45:42 +03:00
help = " Web server document root directory (e.g. \" /var/www \" ) " )
2017-03-01 12:07:26 +03:00
2019-06-11 02:45:23 +03:00
miscellaneous . add_argument ( " --wizard " , dest = " wizard " , action = " store_true " ,
2018-03-13 15:45:42 +03:00
help = " Simple wizard interface for beginner users " )
2011-03-29 15:42:55 +04:00
2010-05-21 13:35:36 +04:00
# Hidden and/or experimental options
2019-06-11 02:45:23 +03:00
parser . add_argument ( " --base64 " , dest = " base64Parameter " ,
help = SUPPRESS )
2019-04-17 15:22:36 +03:00
# help="Parameter(s) containing Base64 encoded values")
2019-06-11 02:45:23 +03:00
parser . add_argument ( " --crack " , dest = " hashFile " ,
help = SUPPRESS )
2018-12-17 19:48:22 +03:00
# help="Load and crack hashes from a file (standalone)")
2018-12-17 19:38:47 +03:00
2019-06-11 02:45:23 +03:00
parser . add_argument ( " --dummy " , dest = " dummy " , action = " store_true " ,
help = SUPPRESS )
2013-02-28 23:20:08 +04:00
2019-06-11 02:45:23 +03:00
parser . add_argument ( " --murphy-rate " , dest = " murphyRate " , type = int ,
help = SUPPRESS )
2016-09-27 15:03:59 +03:00
2019-06-11 02:45:23 +03:00
parser . add_argument ( " --debug " , dest = " debug " , action = " store_true " ,
help = SUPPRESS )
2019-05-08 13:28:50 +03:00
2019-06-11 02:45:23 +03:00
parser . add_argument ( " --disable-precon " , dest = " disablePrecon " , action = " store_true " ,
help = SUPPRESS )
2015-12-02 14:05:40 +03:00
2019-06-11 02:45:23 +03:00
parser . add_argument ( " --disable-stats " , dest = " disableStats " , action = " store_true " ,
help = SUPPRESS )
2017-02-14 15:14:35 +03:00
2019-06-11 02:45:23 +03:00
parser . add_argument ( " --profile " , dest = " profile " , action = " store_true " ,
help = SUPPRESS )
2010-05-21 13:35:36 +04:00
2019-06-11 02:45:23 +03:00
parser . add_argument ( " --force-dbms " , dest = " forceDbms " ,
help = SUPPRESS )
2017-08-28 13:30:42 +03:00
2019-06-11 02:45:23 +03:00
parser . add_argument ( " --force-dns " , dest = " forceDns " , action = " store_true " ,
help = SUPPRESS )
2010-05-21 13:35:36 +04:00
2019-06-11 02:45:23 +03:00
parser . add_argument ( " --force-pivoting " , dest = " forcePivoting " , action = " store_true " ,
help = SUPPRESS )
2018-04-17 18:08:57 +03:00
2019-06-11 02:45:23 +03:00
parser . add_argument ( " --smoke-test " , dest = " smokeTest " , action = " store_true " ,
help = SUPPRESS )
2010-07-30 16:49:25 +04:00
2019-06-11 02:45:23 +03:00
parser . add_argument ( " --live-test " , dest = " liveTest " , action = " store_true " ,
help = SUPPRESS )
2010-09-15 17:59:55 +04:00
2019-06-11 02:45:23 +03:00
parser . add_argument ( " --vuln-test " , dest = " vulnTest " , action = " store_true " ,
help = SUPPRESS )
2019-04-19 14:28:11 +03:00
2019-06-11 02:45:23 +03:00
parser . add_argument ( " --stop-fail " , dest = " stopFail " , action = " store_true " ,
help = SUPPRESS )
2012-12-17 15:41:43 +04:00
2019-06-11 02:45:23 +03:00
parser . add_argument ( " --run-case " , dest = " runCase " , help = SUPPRESS )
2011-03-24 15:07:47 +03:00
2017-04-10 15:50:17 +03:00
# API options
2019-06-11 02:45:23 +03:00
parser . add_argument ( " --api " , dest = " api " , action = " store_true " ,
help = SUPPRESS )
2008-10-15 19:38:22 +04:00
2019-06-11 02:45:23 +03:00
parser . add_argument ( " --taskid " , dest = " taskid " , help = SUPPRESS )
parser . add_argument ( " --database " , dest = " database " , help = SUPPRESS )
2012-07-24 17:34:50 +04:00
2019-06-11 02:45:23 +03:00
# Dirty hack to display longer options without breaking into two lines
if hasattr ( parser , " formatter " ) :
def _ ( self , * args ) :
retVal = parser . formatter . _format_option_strings ( * args )
if len ( retVal ) > MAX_HELP_OPTION_LENGTH :
retVal = ( " %% . %d s.. " % ( MAX_HELP_OPTION_LENGTH - parser . formatter . indent_increment ) ) % retVal
return retVal
parser . formatter . _format_option_strings = parser . formatter . format_option_strings
parser . formatter . format_option_strings = type ( parser . formatter . format_option_strings ) ( _ , parser )
else :
def _format_action_invocation ( self , action ) :
retVal = self . __format_action_invocation ( action )
if len ( retVal ) > MAX_HELP_OPTION_LENGTH :
retVal = ( " %% . %d s.. " % ( MAX_HELP_OPTION_LENGTH - self . _indent_increment ) ) % retVal
return retVal
parser . formatter_class . __format_action_invocation = parser . formatter_class . _format_action_invocation
parser . formatter_class . _format_action_invocation = _format_action_invocation
2012-07-24 17:34:50 +04:00
2016-05-24 16:18:19 +03:00
# Dirty hack for making a short option '-hh'
2019-06-11 02:45:23 +03:00
if hasattr ( parser , " get_option " ) :
option = parser . get_option ( " --hh " )
option . _short_opts = [ " -hh " ]
option . _long_opts = [ ]
else :
for action in get_actions ( parser ) :
if action . option_strings == [ " --hh " ] :
action . option_strings = [ " -hh " ]
break
2012-07-03 14:09:18 +04:00
2019-06-11 02:45:23 +03:00
## Dirty hack for inherent help message of switch '-h'
if hasattr ( parser , " get_option " ) :
option = parser . get_option ( " -h " )
option . help = option . help . capitalize ( ) . replace ( " this help " , " basic help " )
else :
for action in get_actions ( parser ) :
if action . option_strings == [ " -h " , " --help " ] :
action . help = action . help . capitalize ( ) . replace ( " this help " , " basic help " )
break
2012-07-03 14:49:35 +04:00
2015-09-10 16:01:30 +03:00
_ = [ ]
2014-09-16 16:12:43 +04:00
prompt = False
2012-07-03 14:29:42 +04:00
advancedHelp = True
2015-07-07 10:24:16 +03:00
extraHeaders = [ ]
2018-09-24 15:00:58 +03:00
tamperIndex = None
2011-02-20 00:06:24 +03:00
2017-06-29 16:33:34 +03:00
# Reference: https://stackoverflow.com/a/4012683 (Note: previously used "...sys.getfilesystemencoding() or UNICODE_ENCODING")
2015-09-10 16:01:30 +03:00
for arg in argv :
2017-06-29 16:33:34 +03:00
_ . append ( getUnicode ( arg , encoding = sys . stdin . encoding ) )
2011-02-20 00:06:24 +03:00
2015-09-10 16:01:30 +03:00
argv = _
2019-06-06 14:08:56 +03:00
checkOldOptions ( argv )
2012-11-28 14:10:57 +04:00
2014-09-16 18:18:13 +04:00
prompt = " --sqlmap-shell " in argv
2012-07-03 14:09:18 +04:00
2014-09-16 16:12:43 +04:00
if prompt :
2014-09-16 18:21:29 +04:00
parser . usage = " "
2014-09-16 16:12:43 +04:00
cmdLineOptions . sqlmapShell = True
_ = [ " x " , " q " , " exit " , " quit " , " clear " ]
2014-09-16 18:18:13 +04:00
2019-06-11 02:45:23 +03:00
for option in get_actions ( parser ) :
2014-09-16 18:18:13 +04:00
_ . extend ( option . _long_opts )
_ . extend ( option . _short_opts )
2019-06-11 02:45:23 +03:00
for group in get_groups ( parser ) :
for option in get_actions ( group ) :
2014-09-16 16:12:43 +04:00
_ . extend ( option . _long_opts )
_ . extend ( option . _short_opts )
autoCompletion ( AUTOCOMPLETE_TYPE . SQLMAP , commands = _ )
while True :
command = None
try :
2019-05-14 17:08:12 +03:00
# Note: in Python2 command should not be converted to Unicode before passing to shlex (Reference: https://bugs.python.org/issue1170)
2019-05-02 01:45:44 +03:00
command = _input ( " sqlmap-shell> " ) . strip ( )
2014-09-16 16:12:43 +04:00
except ( KeyboardInterrupt , EOFError ) :
2019-01-22 03:28:24 +03:00
print ( )
2014-09-16 16:12:43 +04:00
raise SqlmapShellQuitException
if not command :
continue
elif command . lower ( ) == " clear " :
2016-02-23 11:57:06 +03:00
clearHistory ( )
2016-06-10 19:41:41 +03:00
dataToStdout ( " [i] history cleared \n " )
2014-09-16 17:17:50 +04:00
saveHistory ( AUTOCOMPLETE_TYPE . SQLMAP )
2014-09-16 16:12:43 +04:00
elif command . lower ( ) in ( " x " , " q " , " exit " , " quit " ) :
raise SqlmapShellQuitException
elif command [ 0 ] != ' - ' :
2016-06-10 19:41:41 +03:00
dataToStdout ( " [!] invalid option(s) provided \n " )
dataToStdout ( " [i] proper example: ' -u http://www.site.com/vuln.php?id=1 --banner ' \n " )
2014-09-16 16:12:43 +04:00
else :
2014-09-16 17:17:50 +04:00
saveHistory ( AUTOCOMPLETE_TYPE . SQLMAP )
loadHistory ( AUTOCOMPLETE_TYPE . SQLMAP )
2014-09-16 16:12:43 +04:00
break
2014-12-15 11:11:40 +03:00
try :
for arg in shlex . split ( command ) :
argv . append ( getUnicode ( arg , encoding = sys . stdin . encoding ) )
2019-01-22 02:40:48 +03:00
except ValueError as ex :
2019-05-03 01:48:46 +03:00
raise SqlmapSyntaxException ( " something went wrong during command line parsing ( ' %s ' ) " % getSafeExString ( ex ) )
2014-09-16 16:12:43 +04:00
2014-09-16 18:18:13 +04:00
for i in xrange ( len ( argv ) ) :
if argv [ i ] == " -hh " :
argv [ i ] = " -h "
2016-11-18 00:34:10 +03:00
elif len ( argv [ i ] ) > 1 and all ( ord ( _ ) in xrange ( 0x2018 , 0x2020 ) for _ in ( ( argv [ i ] . split ( ' = ' , 1 ) [ - 1 ] . strip ( ) or ' ' ) [ 0 ] , argv [ i ] [ - 1 ] ) ) :
2016-10-14 00:07:11 +03:00
dataToStdout ( " [!] copy-pasting illegal (non-console) quote characters from Internet is, well, illegal ( %s ) \n " % argv [ i ] )
raise SystemExit
2017-01-16 15:53:46 +03:00
elif len ( argv [ i ] ) > 1 and u " \uff0c " in argv [ i ] . split ( ' = ' , 1 ) [ - 1 ] :
dataToStdout ( " [!] copy-pasting illegal (non-console) comma characters from Internet is, well, illegal ( %s ) \n " % argv [ i ] )
raise SystemExit
2015-08-19 22:00:16 +03:00
elif re . search ( r " \ A- \ w=.+ " , argv [ i ] ) :
2016-06-10 19:41:41 +03:00
dataToStdout ( " [!] potentially miswritten (illegal ' = ' ) short option detected ( ' %s ' ) \n " % argv [ i ] )
raise SystemExit
2019-06-06 14:08:56 +03:00
elif argv [ i ] in DEPRECATED_OPTIONS :
argv [ i ] = " "
2018-09-24 15:00:58 +03:00
elif argv [ i ] . startswith ( " --tamper " ) :
if tamperIndex is None :
tamperIndex = i if ' = ' in argv [ i ] else ( i + 1 if i + 1 < len ( argv ) and not argv [ i + 1 ] . startswith ( ' - ' ) else None )
else :
argv [ tamperIndex ] = " %s , %s " % ( argv [ tamperIndex ] , argv [ i ] . split ( ' = ' ) [ 1 ] if ' = ' in argv [ i ] else ( argv [ i + 1 ] if i + 1 < len ( argv ) and not argv [ i + 1 ] . startswith ( ' - ' ) else " " ) )
argv [ i ] = " "
2015-07-07 10:24:16 +03:00
elif argv [ i ] == " -H " :
if i + 1 < len ( argv ) :
extraHeaders . append ( argv [ i + 1 ] )
2019-04-18 12:18:00 +03:00
elif argv [ i ] == " -r " :
for j in xrange ( i + 2 , len ( argv ) ) :
value = argv [ j ]
if os . path . isfile ( value ) :
argv [ i + 1 ] + = " , %s " % value
argv [ j ] = ' '
else :
break
2014-12-21 07:15:42 +03:00
elif re . match ( r " \ A \ d+! \ Z " , argv [ i ] ) and argv [ max ( 0 , i - 1 ) ] == " --threads " or re . match ( r " \ A--threads.+ \ d+! \ Z " , argv [ i ] ) :
argv [ i ] = argv [ i ] [ : - 1 ]
conf . skipThreadCheck = True
2014-09-16 18:18:13 +04:00
elif argv [ i ] == " --version " :
2019-01-22 03:20:27 +03:00
print ( VERSION_STRING . split ( ' / ' ) [ - 1 ] )
2014-09-16 18:18:13 +04:00
raise SystemExit
2016-10-05 18:01:58 +03:00
elif argv [ i ] in ( " -h " , " --help " ) :
2014-09-16 18:18:13 +04:00
advancedHelp = False
2019-06-11 02:45:23 +03:00
for group in get_groups ( parser ) [ : ] :
2014-09-16 18:18:13 +04:00
found = False
2019-06-11 02:45:23 +03:00
for option in get_actions ( group ) :
2014-09-16 18:18:13 +04:00
if option . dest not in BASIC_HELP_ITEMS :
2019-06-11 02:45:23 +03:00
option . help = SUPPRESS
2014-09-16 18:18:13 +04:00
else :
found = True
if not found :
2019-06-11 02:45:23 +03:00
get_groups ( parser ) . remove ( group )
2014-09-16 18:18:13 +04:00
2016-09-29 12:19:25 +03:00
for verbosity in ( _ for _ in argv if re . search ( r " \ A \ -v+ \ Z " , _ ) ) :
try :
if argv . index ( verbosity ) == len ( argv ) - 1 or not argv [ argv . index ( verbosity ) + 1 ] . isdigit ( ) :
conf . verbose = verbosity . count ( ' v ' ) + 1
del argv [ argv . index ( verbosity ) ]
except ( IndexError , ValueError ) :
pass
2012-07-03 14:21:40 +04:00
try :
2019-06-11 02:45:23 +03:00
( args , _ ) = parser . parse_known_args ( argv ) if hasattr ( parser , " parse_known_args " ) else parser . parse_args ( argv )
2019-01-22 02:40:48 +03:00
except UnicodeEncodeError as ex :
2019-05-15 01:12:00 +03:00
dataToStdout ( " \n [!] %s \n " % getUnicode ( ex . object . encode ( " unicode-escape " ) ) )
2014-10-31 03:01:35 +03:00
raise SystemExit
2012-07-03 14:21:40 +04:00
except SystemExit :
2014-09-16 18:18:13 +04:00
if " -h " in argv and not advancedHelp :
2016-06-10 19:41:41 +03:00
dataToStdout ( " \n [!] to see full list of options run with ' -hh ' \n " )
2012-07-03 14:21:40 +04:00
raise
2008-10-15 19:38:22 +04:00
2015-07-07 10:24:16 +03:00
if extraHeaders :
if not args . headers :
args . headers = " "
delimiter = " \\ n " if " \\ n " in args . headers else " \n "
args . headers + = delimiter + delimiter . join ( extraHeaders )
2012-07-03 14:09:18 +04:00
# Expand given mnemonic options (e.g. -z "ign,flu,bat")
2014-09-16 16:12:43 +04:00
for i in xrange ( len ( argv ) - 1 ) :
if argv [ i ] == " -z " :
expandMnemonics ( argv [ i + 1 ] , parser , args )
2011-06-15 15:58:50 +04:00
2013-02-28 23:20:08 +04:00
if args . dummy :
args . url = args . url or DUMMY_URL
2019-04-19 14:28:11 +03:00
if not any ( ( args . direct , args . url , args . logFile , args . bulkFile , args . googleDork , args . configFile , args . requestFile , args . updateAll , args . smokeTest , args . vulnTest , args . liveTest , args . wizard , args . dependencies , args . purge , args . sitemapUrl , args . listTampers , args . hashFile ) ) :
2018-07-31 03:18:33 +03:00
errMsg = " missing a mandatory option (-d, -u, -l, -m, -r, -g, -c, -x, --list-tampers, --wizard, --update, --purge or --dependencies). "
errMsg + = " Use -h for basic and -hh for advanced help \n "
2008-10-15 19:38:22 +04:00
parser . error ( errMsg )
return args
2011-03-29 03:09:19 +04:00
2019-06-11 02:45:23 +03:00
except ( ArgumentError , TypeError ) as ex :
2019-01-22 04:08:02 +03:00
parser . error ( ex )
2008-10-15 19:38:22 +04:00
2012-02-22 14:40:11 +04:00
except SystemExit :
2011-03-29 03:12:04 +04:00
# Protection against Windows dummy double clicking
2011-03-29 03:09:19 +04:00
if IS_WIN :
2016-06-10 19:41:41 +03:00
dataToStdout ( " \n Press Enter to continue... " )
2019-05-02 01:45:44 +03:00
_input ( )
2011-03-29 03:09:19 +04:00
raise
2008-10-15 19:38:22 +04:00
debugMsg = " parsing command line "
logger . debug ( debugMsg )