sqlmap/lib/controller/handler.py

112 lines
4.2 KiB
Python
Raw Normal View History

#!/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
"""
from lib.core.common import Backend
2008-10-15 19:38:22 +04:00
from lib.core.data import conf
from lib.core.data import logger
2013-04-15 16:20:21 +04:00
from lib.core.dicts import DBMS_DICT
from lib.core.enums import DBMS
2008-10-15 19:38:22 +04:00
from lib.core.settings import MSSQL_ALIASES
from lib.core.settings import MYSQL_ALIASES
from lib.core.settings import ORACLE_ALIASES
from lib.core.settings import PGSQL_ALIASES
from lib.core.settings import SQLITE_ALIASES
from lib.core.settings import ACCESS_ALIASES
from lib.core.settings import FIREBIRD_ALIASES
from lib.core.settings import MAXDB_ALIASES
2010-10-12 23:05:12 +04:00
from lib.core.settings import SYBASE_ALIASES
from lib.core.settings import DB2_ALIASES
from lib.core.settings import HSQLDB_ALIASES
from lib.utils.sqlalchemy import SQLAlchemy
2008-10-15 19:38:22 +04:00
from plugins.dbms.mssqlserver import MSSQLServerMap
from plugins.dbms.mssqlserver.connector import Connector as MSSQLServerConn
2008-10-15 19:38:22 +04:00
from plugins.dbms.mysql import MySQLMap
from plugins.dbms.mysql.connector import Connector as MySQLConn
2008-10-15 19:38:22 +04:00
from plugins.dbms.oracle import OracleMap
from plugins.dbms.oracle.connector import Connector as OracleConn
2008-10-15 19:38:22 +04:00
from plugins.dbms.postgresql import PostgreSQLMap
from plugins.dbms.postgresql.connector import Connector as PostgreSQLConn
from plugins.dbms.sqlite import SQLiteMap
from plugins.dbms.sqlite.connector import Connector as SQLiteConn
from plugins.dbms.access import AccessMap
from plugins.dbms.access.connector import Connector as AccessConn
from plugins.dbms.firebird import FirebirdMap
from plugins.dbms.firebird.connector import Connector as FirebirdConn
from plugins.dbms.maxdb import MaxDBMap
from plugins.dbms.maxdb.connector import Connector as MaxDBConn
2010-10-13 22:55:17 +04:00
from plugins.dbms.sybase import SybaseMap
from plugins.dbms.sybase.connector import Connector as SybaseConn
from plugins.dbms.db2 import DB2Map
from plugins.dbms.db2.connector import Connector as DB2Conn
from plugins.dbms.hsqldb import HSQLDBMap
from plugins.dbms.hsqldb.connector import Connector as HSQLDBConn
2008-10-15 19:38:22 +04:00
def setHandler():
"""
Detect which is the target web application back-end database
management system.
"""
items = [
2013-04-15 16:20:21 +04:00
(DBMS.MYSQL, MYSQL_ALIASES, MySQLMap, MySQLConn),
(DBMS.ORACLE, ORACLE_ALIASES, OracleMap, OracleConn),
(DBMS.PGSQL, PGSQL_ALIASES, PostgreSQLMap, PostgreSQLConn),
(DBMS.MSSQL, MSSQL_ALIASES, MSSQLServerMap, MSSQLServerConn),
(DBMS.SQLITE, SQLITE_ALIASES, SQLiteMap, SQLiteConn),
(DBMS.ACCESS, ACCESS_ALIASES, AccessMap, AccessConn),
(DBMS.FIREBIRD, FIREBIRD_ALIASES, FirebirdMap, FirebirdConn),
(DBMS.MAXDB, MAXDB_ALIASES, MaxDBMap, MaxDBConn),
(DBMS.SYBASE, SYBASE_ALIASES, SybaseMap, SybaseConn),
(DBMS.DB2, DB2_ALIASES, DB2Map, DB2Conn),
(DBMS.HSQLDB, HSQLDB_ALIASES, HSQLDBMap, HSQLDBConn),
]
2012-05-09 22:25:04 +04:00
_ = max(_ if (Backend.getIdentifiedDbms() or "").lower() in _[1] else None for _ in items)
2012-05-09 22:25:04 +04:00
if _:
2012-05-09 22:26:02 +04:00
items.remove(_)
items.insert(0, _)
2012-05-09 22:25:04 +04:00
2014-08-30 23:53:09 +04:00
for dbms, aliases, Handler, Connector in items:
if conf.dbms and conf.dbms.lower() != dbms.lower():
debugMsg = "skipping test for %s" % dbms
2008-10-15 19:38:22 +04:00
logger.debug(debugMsg)
continue
2012-05-09 22:25:04 +04:00
handler = Handler()
conf.dbmsConnector = Connector()
2010-10-20 13:54:17 +04:00
2010-03-30 17:23:20 +04:00
if conf.direct:
logger.debug("forcing timeout to 10 seconds")
conf.timeout = 10
2013-04-15 16:20:21 +04:00
2014-08-30 23:53:09 +04:00
dialect = DBMS_DICT[dbms][3]
2013-04-15 16:20:21 +04:00
2013-07-01 14:26:57 +04:00
if dialect:
sqlalchemy = SQLAlchemy(dialect=dialect)
sqlalchemy.connect()
if sqlalchemy.connector:
conf.dbmsConnector = sqlalchemy
else:
2014-12-05 13:24:43 +03:00
try:
conf.dbmsConnector.connect()
except NameError:
pass
2013-04-15 16:20:21 +04:00
else:
conf.dbmsConnector.connect()
2008-10-15 19:38:22 +04:00
2010-03-21 03:39:44 +03:00
if handler.checkDbms():
conf.dbmsHandler = handler
break
else:
conf.dbmsConnector = None
# At this point back-end DBMS is correctly fingerprinted, no need
# to enforce it anymore
Backend.flushForcedDbms()