mirror of
				https://github.com/sqlmapproject/sqlmap.git
				synced 2025-11-04 01:47:37 +03:00 
			
		
		
		
	Fixed direct connection to always use the same query as of UNION query SQL injection (= one query with multiple columns/entries output). Minor fixes to Firebird/Access/SQLite connectors to use connector's execute()/fetchall() as wrapper for third-party libraries' methods. Forced conf.timeout to 10 seconds when directly connecting to database. Slightly improved regular expression to parse -d parameter. Added import check for all connectors' third-party libraries. Code refactoring: * Moved conf.direct request to direct() function in lib/request/direct.py (code reused where needed). * Back-delegated to generic connector close() and other methods.
		
			
				
	
	
		
			96 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			96 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
#!/usr/bin/env python
 | 
						|
 | 
						|
"""
 | 
						|
$Id$
 | 
						|
 | 
						|
This file is part of the sqlmap project, http://sqlmap.sourceforge.net.
 | 
						|
 | 
						|
Copyright (c) 2007-2010 Bernardo Damele A. G. <bernardo.damele@gmail.com>
 | 
						|
Copyright (c) 2006 Daniele Bellucci <daniele.bellucci@gmail.com>
 | 
						|
 | 
						|
sqlmap is free software; you can redistribute it and/or modify it under
 | 
						|
the terms of the GNU General Public License as published by the Free
 | 
						|
Software Foundation version 2 of the License.
 | 
						|
 | 
						|
sqlmap is distributed in the hope that it will be useful, but WITHOUT ANY
 | 
						|
WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
 | 
						|
FOR A PARTICULAR PURPOSE.  See the GNU General Public License for more
 | 
						|
details.
 | 
						|
 | 
						|
You should have received a copy of the GNU General Public License along
 | 
						|
with sqlmap; if not, write to the Free Software Foundation, Inc., 51
 | 
						|
Franklin St, Fifth Floor, Boston, MA  021101301  USA
 | 
						|
"""
 | 
						|
 | 
						|
import os
 | 
						|
 | 
						|
from lib.core.data import conf
 | 
						|
from lib.core.data import logger
 | 
						|
from lib.core.exception import sqlmapFilePathException
 | 
						|
from lib.core.exception import sqlmapUndefinedMethod
 | 
						|
 | 
						|
class Connector:
 | 
						|
    """
 | 
						|
    This class defines generic dbms protocol functionalities for plugins.
 | 
						|
    """
 | 
						|
 | 
						|
    def __init__(self):
 | 
						|
        self.connector = None
 | 
						|
        self.cursor = None
 | 
						|
 | 
						|
    def initConnection(self):
 | 
						|
        self.user = conf.dbmsUser
 | 
						|
        self.password = conf.dbmsPass
 | 
						|
        self.hostname = conf.hostname
 | 
						|
        self.port = conf.port
 | 
						|
        self.db = conf.dbmsDb
 | 
						|
 | 
						|
    def connected(self):
 | 
						|
        infoMsg = "connection to %s server %s" % (conf.dbms, self.hostname)
 | 
						|
        infoMsg += ":%d established" % self.port
 | 
						|
        logger.info(infoMsg)
 | 
						|
        
 | 
						|
    def closed(self):
 | 
						|
        infoMsg = "connection to %s server %s" % (conf.dbms, self.hostname)
 | 
						|
        infoMsg += ":%d closed" % self.port
 | 
						|
        logger.info(infoMsg)
 | 
						|
 | 
						|
        self.connector = None
 | 
						|
        self.cursor = None
 | 
						|
 | 
						|
    def setCursor(self):
 | 
						|
        self.cursor = self.connector.cursor()
 | 
						|
 | 
						|
    def getCursor(self):
 | 
						|
        return self.cursor
 | 
						|
 | 
						|
    def close(self):
 | 
						|
        self.cursor.close()
 | 
						|
        self.connector.close()
 | 
						|
        self.closed()
 | 
						|
 | 
						|
    def checkFileDb(self):
 | 
						|
        if not os.path.exists(self.db):
 | 
						|
            errMsg = "the provided database file '%s' does not exist" % self.db
 | 
						|
            raise sqlmapFilePathException, errMsg
 | 
						|
 | 
						|
    def connect(self):
 | 
						|
        errMsg  = "'connect' method must be defined "
 | 
						|
        errMsg += "into the specific DBMS plugin"
 | 
						|
        raise sqlmapUndefinedMethod, errMsg
 | 
						|
 | 
						|
    def fetchall(self):
 | 
						|
        errMsg  = "'fetchall' method must be defined "
 | 
						|
        errMsg += "into the specific DBMS plugin"
 | 
						|
        raise sqlmapUndefinedMethod, errMsg
 | 
						|
 | 
						|
    def execute(self, query):
 | 
						|
        errMsg  = "'execute' method must be defined "
 | 
						|
        errMsg += "into the specific DBMS plugin"
 | 
						|
        raise sqlmapUndefinedMethod, errMsg
 | 
						|
 | 
						|
    def select(self, query):
 | 
						|
        errMsg  = "'select' method must be defined "
 | 
						|
        errMsg += "into the specific DBMS plugin"
 | 
						|
        raise sqlmapUndefinedMethod, errMsg
 |