Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
sqlmapproject
GitHub Repository: sqlmapproject/sqlmap
Path: blob/master/plugins/dbms/informix/connector.py
2992 views
1
#!/usr/bin/env python
2
3
"""
4
Copyright (c) 2006-2025 sqlmap developers (https://sqlmap.org)
5
See the file 'LICENSE' for copying permission
6
"""
7
8
try:
9
import ibm_db_dbi
10
except:
11
pass
12
13
import logging
14
15
from lib.core.common import getSafeExString
16
from lib.core.data import conf
17
from lib.core.data import logger
18
from lib.core.exception import SqlmapConnectionException
19
from plugins.generic.connector import Connector as GenericConnector
20
21
class Connector(GenericConnector):
22
"""
23
Homepage: https://github.com/ibmdb/python-ibmdb
24
User guide: https://github.com/ibmdb/python-ibmdb/wiki/README
25
API: https://www.python.org/dev/peps/pep-0249/
26
License: Apache License 2.0
27
"""
28
29
def connect(self):
30
self.initConnection()
31
32
try:
33
database = "DATABASE=%s;HOSTNAME=%s;PORT=%s;PROTOCOL=TCPIP;" % (self.db, self.hostname, self.port)
34
self.connector = ibm_db_dbi.connect(database, self.user, self.password)
35
except ibm_db_dbi.OperationalError as ex:
36
raise SqlmapConnectionException(getSafeExString(ex))
37
38
self.initCursor()
39
self.printConnected()
40
41
def fetchall(self):
42
try:
43
return self.cursor.fetchall()
44
except ibm_db_dbi.ProgrammingError as ex:
45
logger.log(logging.WARN if conf.dbmsHandler else logging.DEBUG, "(remote) %s" % getSafeExString(ex))
46
return None
47
48
def execute(self, query):
49
try:
50
self.cursor.execute(query)
51
except (ibm_db_dbi.OperationalError, ibm_db_dbi.ProgrammingError) as ex:
52
logger.log(logging.WARN if conf.dbmsHandler else logging.DEBUG, "(remote) %s" % getSafeExString(ex))
53
except ibm_db_dbi.InternalError as ex:
54
raise SqlmapConnectionException(getSafeExString(ex))
55
56
self.connector.commit()
57
58
def select(self, query):
59
self.execute(query)
60
return self.fetchall()
61
62