SIGN IN SIGN UP
sqlmapproject / sqlmap UNCLAIMED

Automatic SQL injection and database takeover tool

0 0 0 Python
2019-05-08 12:47:52 +02:00
#!/usr/bin/env python
2008-10-15 15:38:22 +00:00
"""
2026-01-01 19:12:07 +01:00
Copyright (c) 2006-2026 sqlmap developers (https://sqlmap.org)
2017-10-11 14:50:46 +02:00
See the file 'LICENSE' for copying permission
2008-10-15 15:38:22 +00:00
"""
from lib.core.common import Backend
2011-01-15 23:54:03 +00:00
from lib.core.common import readInput
from lib.core.data import logger
from lib.core.enums import OS
from lib.core.exception import SqlmapUndefinedMethod
2008-10-15 15:38:22 +00:00
2019-05-29 16:42:04 +02:00
class Fingerprint(object):
2008-10-15 15:38:22 +00:00
"""
This class defines generic fingerprint functionalities for plugins.
"""
def __init__(self, dbms):
Backend.forceDbms(dbms)
2008-10-15 15:38:22 +00:00
def getFingerprint(self):
2011-04-30 13:20:05 +00:00
errMsg = "'getFingerprint' method must be defined "
2008-10-15 15:38:22 +00:00
errMsg += "into the specific DBMS plugin"
raise SqlmapUndefinedMethod(errMsg)
2008-10-15 15:38:22 +00:00
def checkDbms(self):
2011-04-30 13:20:05 +00:00
errMsg = "'checkDbms' method must be defined "
2008-10-15 15:38:22 +00:00
errMsg += "into the specific DBMS plugin"
raise SqlmapUndefinedMethod(errMsg)
def checkDbmsOs(self, detailed=False):
2011-04-30 13:20:05 +00:00
errMsg = "'checkDbmsOs' method must be defined "
errMsg += "into the specific DBMS plugin"
raise SqlmapUndefinedMethod(errMsg)
def forceDbmsEnum(self):
pass
2011-01-15 23:54:03 +00:00
def userChooseDbmsOs(self):
warnMsg = "for some reason sqlmap was unable to fingerprint "
warnMsg += "the back-end DBMS operating system"
logger.warning(warnMsg)
2011-01-15 23:54:03 +00:00
msg = "do you want to provide the OS? [(W)indows/(l)inux]"
while True:
2017-04-19 14:46:27 +02:00
os = readInput(msg, default='W').upper()
2011-01-15 23:54:03 +00:00
2017-04-19 14:46:27 +02:00
if os == 'W':
Backend.setOs(OS.WINDOWS)
2011-01-15 23:54:03 +00:00
break
2017-04-19 14:46:27 +02:00
elif os == 'L':
Backend.setOs(OS.LINUX)
2011-01-15 23:54:03 +00:00
break
else:
warnMsg = "invalid value"
logger.warning(warnMsg)