mirror of
				https://github.com/sqlmapproject/sqlmap.git
				synced 2025-10-26 05:31:04 +03:00 
			
		
		
		
	Some refactoring (data)
This commit is contained in:
		
							parent
							
								
									82efb0ca79
								
							
						
					
					
						commit
						ef7d4bb404
					
				|  | @ -173,6 +173,7 @@ from lib.core.settings import URLENCODE_CHAR_LIMIT | ||||||
| from lib.core.settings import URLENCODE_FAILSAFE_CHARS | from lib.core.settings import URLENCODE_FAILSAFE_CHARS | ||||||
| from lib.core.settings import USER_AGENT_ALIASES | from lib.core.settings import USER_AGENT_ALIASES | ||||||
| from lib.core.settings import VERSION_STRING | from lib.core.settings import VERSION_STRING | ||||||
|  | from lib.core.settings import ZIP_HEADER | ||||||
| from lib.core.settings import WEBSCARAB_SPLITTER | from lib.core.settings import WEBSCARAB_SPLITTER | ||||||
| from lib.core.threads import getCurrentThreadData | from lib.core.threads import getCurrentThreadData | ||||||
| from lib.utils.sqlalchemy import _sqlalchemy | from lib.utils.sqlalchemy import _sqlalchemy | ||||||
|  | @ -1215,6 +1216,18 @@ def checkPipedInput(): | ||||||
| 
 | 
 | ||||||
|     return not os.isatty(sys.stdin.fileno()) |     return not os.isatty(sys.stdin.fileno()) | ||||||
| 
 | 
 | ||||||
|  | def isZipFile(filename): | ||||||
|  |     """ | ||||||
|  |     Checks if file contains zip compressed content | ||||||
|  | 
 | ||||||
|  |     >>> isZipFile(paths.WORDLIST) | ||||||
|  |     True | ||||||
|  |     """ | ||||||
|  | 
 | ||||||
|  |     checkFile(filename) | ||||||
|  | 
 | ||||||
|  |     return openFile(filename, "rb", encoding=None).read(len(ZIP_HEADER)) == ZIP_HEADER | ||||||
|  | 
 | ||||||
| def checkFile(filename, raiseOnError=True): | def checkFile(filename, raiseOnError=True): | ||||||
|     """ |     """ | ||||||
|     Checks for file existence and readability |     Checks for file existence and readability | ||||||
|  | @ -1314,18 +1327,42 @@ def setPaths(rootPath): | ||||||
|     paths.SQLMAP_ROOT_PATH = rootPath |     paths.SQLMAP_ROOT_PATH = rootPath | ||||||
| 
 | 
 | ||||||
|     # sqlmap paths |     # sqlmap paths | ||||||
|  |     paths.SQLMAP_DATA_PATH = os.path.join(paths.SQLMAP_ROOT_PATH, "data") | ||||||
|     paths.SQLMAP_EXTRAS_PATH = os.path.join(paths.SQLMAP_ROOT_PATH, "extra") |     paths.SQLMAP_EXTRAS_PATH = os.path.join(paths.SQLMAP_ROOT_PATH, "extra") | ||||||
|     paths.SQLMAP_PROCS_PATH = os.path.join(paths.SQLMAP_ROOT_PATH, "procs") |  | ||||||
|     paths.SQLMAP_SHELL_PATH = os.path.join(paths.SQLMAP_ROOT_PATH, "shell") |  | ||||||
|     paths.SQLMAP_SETTINGS_PATH = os.path.join(paths.SQLMAP_ROOT_PATH, "lib", "core", "settings.py") |     paths.SQLMAP_SETTINGS_PATH = os.path.join(paths.SQLMAP_ROOT_PATH, "lib", "core", "settings.py") | ||||||
|     paths.SQLMAP_TAMPER_PATH = os.path.join(paths.SQLMAP_ROOT_PATH, "tamper") |     paths.SQLMAP_TAMPER_PATH = os.path.join(paths.SQLMAP_ROOT_PATH, "tamper") | ||||||
|     paths.SQLMAP_WAF_PATH = os.path.join(paths.SQLMAP_ROOT_PATH, "waf") |     paths.SQLMAP_WAF_PATH = os.path.join(paths.SQLMAP_ROOT_PATH, "waf") | ||||||
|     paths.SQLMAP_TXT_PATH = os.path.join(paths.SQLMAP_ROOT_PATH, "txt") | 
 | ||||||
|     paths.SQLMAP_UDF_PATH = os.path.join(paths.SQLMAP_ROOT_PATH, "udf") |     paths.SQLMAP_PROCS_PATH = os.path.join(paths.SQLMAP_DATA_PATH, "procs") | ||||||
|     paths.SQLMAP_XML_PATH = os.path.join(paths.SQLMAP_ROOT_PATH, "xml") |     paths.SQLMAP_SHELL_PATH = os.path.join(paths.SQLMAP_DATA_PATH, "shell") | ||||||
|  |     paths.SQLMAP_TXT_PATH = os.path.join(paths.SQLMAP_DATA_PATH, "txt") | ||||||
|  |     paths.SQLMAP_UDF_PATH = os.path.join(paths.SQLMAP_DATA_PATH, "udf") | ||||||
|  |     paths.SQLMAP_XML_PATH = os.path.join(paths.SQLMAP_DATA_PATH, "xml") | ||||||
|     paths.SQLMAP_XML_BANNER_PATH = os.path.join(paths.SQLMAP_XML_PATH, "banner") |     paths.SQLMAP_XML_BANNER_PATH = os.path.join(paths.SQLMAP_XML_PATH, "banner") | ||||||
|     paths.SQLMAP_XML_PAYLOADS_PATH = os.path.join(paths.SQLMAP_XML_PATH, "payloads") |     paths.SQLMAP_XML_PAYLOADS_PATH = os.path.join(paths.SQLMAP_XML_PATH, "payloads") | ||||||
| 
 | 
 | ||||||
|  |     # sqlmap files | ||||||
|  |     paths.COMMON_COLUMNS = os.path.join(paths.SQLMAP_TXT_PATH, "common-columns.txt") | ||||||
|  |     paths.COMMON_TABLES = os.path.join(paths.SQLMAP_TXT_PATH, "common-tables.txt") | ||||||
|  |     paths.COMMON_OUTPUTS = os.path.join(paths.SQLMAP_TXT_PATH, 'common-outputs.txt') | ||||||
|  |     paths.SQL_KEYWORDS = os.path.join(paths.SQLMAP_TXT_PATH, "keywords.txt") | ||||||
|  |     paths.SMALL_DICT = os.path.join(paths.SQLMAP_TXT_PATH, "smalldict.txt") | ||||||
|  |     paths.USER_AGENTS = os.path.join(paths.SQLMAP_TXT_PATH, "user-agents.txt") | ||||||
|  |     paths.WORDLIST = os.path.join(paths.SQLMAP_TXT_PATH, "wordlist.tx_") | ||||||
|  |     paths.ERRORS_XML = os.path.join(paths.SQLMAP_XML_PATH, "errors.xml") | ||||||
|  |     paths.BOUNDARIES_XML = os.path.join(paths.SQLMAP_XML_PATH, "boundaries.xml") | ||||||
|  |     paths.LIVE_TESTS_XML = os.path.join(paths.SQLMAP_XML_PATH, "livetests.xml") | ||||||
|  |     paths.QUERIES_XML = os.path.join(paths.SQLMAP_XML_PATH, "queries.xml") | ||||||
|  |     paths.GENERIC_XML = os.path.join(paths.SQLMAP_XML_BANNER_PATH, "generic.xml") | ||||||
|  |     paths.MSSQL_XML = os.path.join(paths.SQLMAP_XML_BANNER_PATH, "mssql.xml") | ||||||
|  |     paths.MYSQL_XML = os.path.join(paths.SQLMAP_XML_BANNER_PATH, "mysql.xml") | ||||||
|  |     paths.ORACLE_XML = os.path.join(paths.SQLMAP_XML_BANNER_PATH, "oracle.xml") | ||||||
|  |     paths.PGSQL_XML = os.path.join(paths.SQLMAP_XML_BANNER_PATH, "postgresql.xml") | ||||||
|  | 
 | ||||||
|  |     for path in paths.values(): | ||||||
|  |         if any(path.endswith(_) for _ in (".txt", ".xml", ".tx_")): | ||||||
|  |             checkFile(path) | ||||||
|  | 
 | ||||||
|     if IS_WIN: |     if IS_WIN: | ||||||
|         if os.getenv("LOCALAPPDATA"): |         if os.getenv("LOCALAPPDATA"): | ||||||
|             paths.SQLMAP_HOME_PATH = os.path.expandvars("%LOCALAPPDATA%\\sqlmap") |             paths.SQLMAP_HOME_PATH = os.path.expandvars("%LOCALAPPDATA%\\sqlmap") | ||||||
|  | @ -1348,28 +1385,6 @@ def setPaths(rootPath): | ||||||
|     paths.SQLMAP_SHELL_HISTORY = os.path.join(paths.SQLMAP_HISTORY_PATH, "sqlmap.hst") |     paths.SQLMAP_SHELL_HISTORY = os.path.join(paths.SQLMAP_HISTORY_PATH, "sqlmap.hst") | ||||||
|     paths.GITHUB_HISTORY = os.path.join(paths.SQLMAP_HISTORY_PATH, "github.hst") |     paths.GITHUB_HISTORY = os.path.join(paths.SQLMAP_HISTORY_PATH, "github.hst") | ||||||
| 
 | 
 | ||||||
|     # sqlmap files |  | ||||||
|     paths.COMMON_COLUMNS = os.path.join(paths.SQLMAP_TXT_PATH, "common-columns.txt") |  | ||||||
|     paths.COMMON_TABLES = os.path.join(paths.SQLMAP_TXT_PATH, "common-tables.txt") |  | ||||||
|     paths.COMMON_OUTPUTS = os.path.join(paths.SQLMAP_TXT_PATH, 'common-outputs.txt') |  | ||||||
|     paths.SQL_KEYWORDS = os.path.join(paths.SQLMAP_TXT_PATH, "keywords.txt") |  | ||||||
|     paths.SMALL_DICT = os.path.join(paths.SQLMAP_TXT_PATH, "smalldict.txt") |  | ||||||
|     paths.USER_AGENTS = os.path.join(paths.SQLMAP_TXT_PATH, "user-agents.txt") |  | ||||||
|     paths.WORDLIST = os.path.join(paths.SQLMAP_TXT_PATH, "wordlist.zip") |  | ||||||
|     paths.ERRORS_XML = os.path.join(paths.SQLMAP_XML_PATH, "errors.xml") |  | ||||||
|     paths.BOUNDARIES_XML = os.path.join(paths.SQLMAP_XML_PATH, "boundaries.xml") |  | ||||||
|     paths.LIVE_TESTS_XML = os.path.join(paths.SQLMAP_XML_PATH, "livetests.xml") |  | ||||||
|     paths.QUERIES_XML = os.path.join(paths.SQLMAP_XML_PATH, "queries.xml") |  | ||||||
|     paths.GENERIC_XML = os.path.join(paths.SQLMAP_XML_BANNER_PATH, "generic.xml") |  | ||||||
|     paths.MSSQL_XML = os.path.join(paths.SQLMAP_XML_BANNER_PATH, "mssql.xml") |  | ||||||
|     paths.MYSQL_XML = os.path.join(paths.SQLMAP_XML_BANNER_PATH, "mysql.xml") |  | ||||||
|     paths.ORACLE_XML = os.path.join(paths.SQLMAP_XML_BANNER_PATH, "oracle.xml") |  | ||||||
|     paths.PGSQL_XML = os.path.join(paths.SQLMAP_XML_BANNER_PATH, "postgresql.xml") |  | ||||||
| 
 |  | ||||||
|     for path in paths.values(): |  | ||||||
|         if any(path.endswith(_) for _ in (".txt", ".xml", ".zip")): |  | ||||||
|             checkFile(path) |  | ||||||
| 
 |  | ||||||
| def weAreFrozen(): | def weAreFrozen(): | ||||||
|     """ |     """ | ||||||
|     Returns whether we are frozen via py2exe. |     Returns whether we are frozen via py2exe. | ||||||
|  |  | ||||||
|  | @ -18,7 +18,7 @@ from lib.core.enums import OS | ||||||
| from thirdparty.six import unichr as _unichr | from thirdparty.six import unichr as _unichr | ||||||
| 
 | 
 | ||||||
| # sqlmap version (<major>.<minor>.<month>.<monthly commit>) | # sqlmap version (<major>.<minor>.<month>.<monthly commit>) | ||||||
| VERSION = "1.3.5.129" | VERSION = "1.3.5.130" | ||||||
| TYPE = "dev" if VERSION.count('.') > 2 and VERSION.split('.')[-1] != '0' else "stable" | TYPE = "dev" if VERSION.count('.') > 2 and VERSION.split('.')[-1] != '0' else "stable" | ||||||
| TYPE_COLORS = {"dev": 33, "stable": 90, "pip": 34} | TYPE_COLORS = {"dev": 33, "stable": 90, "pip": 34} | ||||||
| VERSION_STRING = "sqlmap/%s#%s" % ('.'.join(VERSION.split('.')[:-1]) if VERSION.count('.') > 2 and VERSION.split('.')[-1] == '0' else VERSION, TYPE) | VERSION_STRING = "sqlmap/%s#%s" % ('.'.join(VERSION.split('.')[:-1]) if VERSION.count('.') > 2 and VERSION.split('.')[-1] == '0' else VERSION, TYPE) | ||||||
|  | @ -777,6 +777,9 @@ LOBLKSIZE = 2048 | ||||||
| # Prefix used to mark special variables (e.g. keywords, having special chars, etc.) | # Prefix used to mark special variables (e.g. keywords, having special chars, etc.) | ||||||
| EVALCODE_ENCODED_PREFIX = "EVAL_" | EVALCODE_ENCODED_PREFIX = "EVAL_" | ||||||
| 
 | 
 | ||||||
|  | # Reference: https://en.wikipedia.org/wiki/Zip_(file_format) | ||||||
|  | ZIP_HEADER = b"\x50\x4b\x03\x04" | ||||||
|  | 
 | ||||||
| # Reference: http://www.cookiecentral.com/faq/#3.5 | # Reference: http://www.cookiecentral.com/faq/#3.5 | ||||||
| NETSCAPE_FORMAT_HEADER_COOKIES = "# Netscape HTTP Cookie File." | NETSCAPE_FORMAT_HEADER_COOKIES = "# Netscape HTTP Cookie File." | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -9,6 +9,7 @@ import os | ||||||
| import zipfile | import zipfile | ||||||
| 
 | 
 | ||||||
| from lib.core.common import getSafeExString | from lib.core.common import getSafeExString | ||||||
|  | from lib.core.common import isZipFile | ||||||
| from lib.core.exception import SqlmapDataException | from lib.core.exception import SqlmapDataException | ||||||
| from lib.core.exception import SqlmapInstallationException | from lib.core.exception import SqlmapInstallationException | ||||||
| from thirdparty import six | from thirdparty import six | ||||||
|  | @ -45,7 +46,7 @@ class Wordlist(six.Iterator): | ||||||
|             self.iter = iter(self.custom) |             self.iter = iter(self.custom) | ||||||
|         else: |         else: | ||||||
|             self.current = self.filenames[self.index] |             self.current = self.filenames[self.index] | ||||||
|             if os.path.splitext(self.current)[1].lower() == ".zip": |             if isZipFile(self.current): | ||||||
|                 try: |                 try: | ||||||
|                     _ = zipfile.ZipFile(self.current, 'r') |                     _ = zipfile.ZipFile(self.current, 'r') | ||||||
|                 except zipfile.error as ex: |                 except zipfile.error as ex: | ||||||
|  |  | ||||||
|  | @ -55,6 +55,7 @@ from lib.core.common import getPublicTypeMembers | ||||||
| from lib.core.common import getSafeExString | from lib.core.common import getSafeExString | ||||||
| from lib.core.common import hashDBRetrieve | from lib.core.common import hashDBRetrieve | ||||||
| from lib.core.common import hashDBWrite | from lib.core.common import hashDBWrite | ||||||
|  | from lib.core.common import isZipFile | ||||||
| from lib.core.common import normalizeUnicode | from lib.core.common import normalizeUnicode | ||||||
| from lib.core.common import openFile | from lib.core.common import openFile | ||||||
| from lib.core.common import paths | from lib.core.common import paths | ||||||
|  | @ -1003,7 +1004,7 @@ def dictionaryAttack(attack_dict): | ||||||
|                     for dictPath in dictPaths: |                     for dictPath in dictPaths: | ||||||
|                         checkFile(dictPath) |                         checkFile(dictPath) | ||||||
| 
 | 
 | ||||||
|                         if os.path.splitext(dictPath)[1].lower() == ".zip": |                         if isZipFile(dictPath): | ||||||
|                             _ = zipfile.ZipFile(dictPath, 'r') |                             _ = zipfile.ZipFile(dictPath, 'r') | ||||||
|                             if len(_.namelist()) == 0: |                             if len(_.namelist()) == 0: | ||||||
|                                 errMsg = "no file(s) inside '%s'" % dictPath |                                 errMsg = "no file(s) inside '%s'" % dictPath | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue
	
	Block a user