sqlmap/lib/core/patch.py

103 lines
3.5 KiB
Python
Raw Normal View History

2019-05-08 13:47:52 +03:00
#!/usr/bin/env python
2018-06-13 00:02:38 +03:00
"""
2020-01-01 15:25:15 +03:00
Copyright (c) 2006-2020 sqlmap developers (http://sqlmap.org/)
2018-06-13 00:02:38 +03:00
See the file 'LICENSE' for copying permission
"""
import codecs
2019-05-06 01:54:21 +03:00
import lib.controller.checks
import lib.core.common
import lib.core.convert
import lib.core.option
2019-06-04 15:48:51 +03:00
import lib.core.threads
2019-05-06 01:54:21 +03:00
import lib.request.connect
import lib.utils.search
2019-05-19 08:52:38 +03:00
import lib.utils.sqlalchemy
2019-05-06 01:54:21 +03:00
import thirdparty.ansistrm.ansistrm
import thirdparty.chardet.universaldetector
2019-05-06 01:54:21 +03:00
from lib.core.common import filterNone
2019-05-19 08:52:38 +03:00
from lib.core.common import getSafeExString
2019-10-07 15:20:18 +03:00
from lib.core.common import isDigit
2019-05-06 01:54:21 +03:00
from lib.core.common import isListLike
from lib.core.common import readInput
2019-05-21 15:18:14 +03:00
from lib.core.common import shellExec
2019-06-04 15:44:06 +03:00
from lib.core.common import singleTimeWarnMessage
2019-05-20 12:21:31 +03:00
from lib.core.convert import stdoutEncode
from lib.core.data import conf
2019-05-06 01:54:21 +03:00
from lib.core.option import _setHTTPHandlers
from lib.core.option import setVerbosity
2018-06-13 00:02:38 +03:00
from lib.core.settings import IS_WIN
2019-06-04 15:44:06 +03:00
from lib.request.templates import getPageTemplate
from thirdparty import six
from thirdparty.six.moves import http_client as _http_client
2018-06-13 00:02:38 +03:00
def dirtyPatches():
"""
Place for "dirty" Python related patches
"""
# accept overly long result lines (e.g. SQLi results in HTTP header responses)
_http_client._MAXLINE = 1 * 1024 * 1024
2018-06-13 00:02:38 +03:00
# prevent double chunked encoding in case of sqlmap chunking (Note: Python3 does it automatically if 'Content-length' is missing)
if six.PY3:
if not hasattr(_http_client.HTTPConnection, "__send_output"):
_http_client.HTTPConnection.__send_output = _http_client.HTTPConnection._send_output
def _send_output(self, *args, **kwargs):
if conf.chunked and "encode_chunked" in kwargs:
kwargs["encode_chunked"] = False
self.__send_output(*args, **kwargs)
_http_client.HTTPConnection._send_output = _send_output
2018-06-13 00:02:38 +03:00
# add support for inet_pton() on Windows OS
if IS_WIN:
from thirdparty.wininetpton import win_inet_pton
# Reference: https://github.com/nodejs/node/issues/12786#issuecomment-298652440
codecs.register(lambda name: codecs.lookup("utf-8") if name == "cp65001" else None)
2019-03-27 18:36:32 +03:00
# Reference: http://bugs.python.org/issue17849
if hasattr(_http_client, "LineAndFileWrapper"):
def _(self, *args):
return self._readline()
_http_client.LineAndFileWrapper._readline = _http_client.LineAndFileWrapper.readline
_http_client.LineAndFileWrapper.readline = _
2019-05-06 01:54:21 +03:00
# to prevent too much "guessing" in case of binary data retrieval
thirdparty.chardet.universaldetector.MINIMUM_THRESHOLD = 0.90
2019-05-06 01:54:21 +03:00
def resolveCrossReferences():
"""
Place for cross-reference resolution
"""
2019-10-07 15:20:18 +03:00
lib.core.threads.isDigit = isDigit
2019-05-06 01:54:21 +03:00
lib.core.threads.readInput = readInput
lib.core.common.getPageTemplate = getPageTemplate
lib.core.convert.filterNone = filterNone
lib.core.convert.isListLike = isListLike
2019-05-21 15:18:14 +03:00
lib.core.convert.shellExec = shellExec
2019-05-06 01:54:21 +03:00
lib.core.convert.singleTimeWarnMessage = singleTimeWarnMessage
lib.core.option._pympTempLeakPatch = pympTempLeakPatch
2019-05-06 01:54:21 +03:00
lib.request.connect.setHTTPHandlers = _setHTTPHandlers
lib.utils.search.setHTTPHandlers = _setHTTPHandlers
lib.controller.checks.setVerbosity = setVerbosity
2019-05-19 08:52:38 +03:00
lib.utils.sqlalchemy.getSafeExString = getSafeExString
2019-05-20 12:21:31 +03:00
thirdparty.ansistrm.ansistrm.stdoutEncode = stdoutEncode
def pympTempLeakPatch(tempDir):
"""
Patch for "pymp" leaking directories inside Python3
"""
try:
import multiprocessing.util
multiprocessing.util.get_temp_dir = lambda: tempDir
except:
2019-05-09 16:47:23 +03:00
pass