X7ROOT File Manager
Current Path:
/opt/imunify360/venv/lib/python3.11/site-packages
opt
/
imunify360
/
venv
/
lib
/
python3.11
/
site-packages
/
ðŸ“
..
ðŸ“
Babel-2.12.1.dist-info
ðŸ“
Cerberus-1.3.5.dist-info
ðŸ“
Crypto
ðŸ“
Jinja2-2.11.2.dist-info
ðŸ“
PyJWT-2.1.0.dist-info
ðŸ“
PyYAML-6.0.1.dist-info
ðŸ“
__pycache__
📄
_cffi_backend.cpython-311-x86_64-linux-gnu.so
(267.63 KB)
ðŸ“
_distutils_hack
📄
_pyrsistent_version.py
(23 B)
ðŸ“
_yaml
ðŸ“
aiodns
ðŸ“
aiodns-3.0.0.dist-info
ðŸ“
aiosignal
ðŸ“
aiosignal-1.3.1.dist-info
ðŸ“
async_lru
ðŸ“
async_lru-2.0.5.dist-info
ðŸ“
async_timeout
ðŸ“
async_timeout-4.0.3.dist-info
ðŸ“
attr
ðŸ“
attrs
ðŸ“
attrs-23.1.0.dist-info
ðŸ“
babel
ðŸ“
blinker
ðŸ“
blinker-1.4.dist-info
ðŸ“
cerberus
ðŸ“
certifi
ðŸ“
certifi-2023.7.22.dist-info
ðŸ“
cffi
ðŸ“
cffi-1.15.1.dist-info
ðŸ“
charset_normalizer
ðŸ“
charset_normalizer-2.0.12.dist-info
ðŸ“
clcommon
ðŸ“
clcommon-3.4.16.dist-info
ðŸ“
click
ðŸ“
click-8.1.7.dist-info
ðŸ“
cryptography
ðŸ“
cryptography-43.0.1.dist-info
ðŸ“
daemon
ðŸ“
dateutil
ðŸ“
defence360agent
ðŸ“
distro-1.6.0.dist-info
📄
distro.py
(47.28 KB)
📄
distutils-precedence.pth
(151 B)
ðŸ“
docutils
ðŸ“
docutils-0.20.1.dist-info
ðŸ“
frozenlist
ðŸ“
frozenlist-1.4.0.dist-info
ðŸ“
geoip2
ðŸ“
geoip2-4.2.0.dist-info
ðŸ“
google
ðŸ“
humanize
ðŸ“
humanize-4.9.0.dist-info
ðŸ“
idna
ðŸ“
idna-3.4.dist-info
ðŸ“
imav
ðŸ“
imunify_antivirus-8.5.6-py3.11.egg-info
ðŸ“
imunify_core-8.6.0-py3.11.egg-info
ðŸ“
jinja2
ðŸ“
jsonschema
ðŸ“
jsonschema-3.2.0.dist-info
ðŸ“
jwt
ðŸ“
lockfile
ðŸ“
lockfile-0.12.2.dist-info
ðŸ“
lxml
ðŸ“
lxml-4.9.2.dist-info
ðŸ“
markupsafe
ðŸ“
markupsafe-2.0.1.dist-info
ðŸ“
maxminddb
ðŸ“
maxminddb-2.4.0.dist-info
ðŸ“
multidict
ðŸ“
multidict-6.0.4.dist-info
ðŸ“
packaging
ðŸ“
packaging-23.1.dist-info
📄
pam.py
(7.38 KB)
ðŸ“
peewee-3.16.0.dist-info
📄
peewee.py
(268.03 KB)
ðŸ“
peewee_migrate
ðŸ“
peewee_migrate-1.7.1.dist-info
ðŸ“
phpserialize-1.3.dist-info
📄
phpserialize.py
(17.97 KB)
ðŸ“
pip
ðŸ“
pip-25.1.1.dist-info
ðŸ“
pkg_resources
ðŸ“
playhouse
ðŸ“
protobuf-4.23.2.dist-info
ðŸ“
psutil
ðŸ“
psutil-5.8.0.dist-info
📄
pwiz.py
(8 KB)
ðŸ“
pyasn1
ðŸ“
pyasn1-0.6.1.dist-info
ðŸ“
pycares
ðŸ“
pycares-4.3.0.dist-info
ðŸ“
pycparser
ðŸ“
pycparser-2.21.dist-info
ðŸ“
pycryptodome-3.18.0.dist-info
ðŸ“
pyrsistent
ðŸ“
pyrsistent-0.19.3.dist-info
ðŸ“
python_daemon-2.3.0.dist-info
ðŸ“
python_dateutil-2.8.2.dist-info
ðŸ“
python_pam-1.8.4.dist-info
ðŸ“
pytricia-1.0.2.dist-info
📄
pytricia.cpython-311-x86_64-linux-gnu.so
(33.42 KB)
ðŸ“
pyzstd
ðŸ“
pyzstd-0.15.3.dist-info
ðŸ“
requests
ðŸ“
requests-2.26.0.dist-info
ðŸ“
sdnotify
ðŸ“
sdnotify-0.3.2.dist-info
📄
secureio.py
(19.81 KB)
ðŸ“
sentry_sdk
ðŸ“
sentry_sdk-0.19.2.dist-info
ðŸ“
setuptools
ðŸ“
setuptools-69.0.2.dist-info
ðŸ“
simplejson
ðŸ“
simplejson-3.20.1.dist-info
ðŸ“
six-1.16.0.dist-info
📄
six.py
(33.74 KB)
ðŸ“
speaklater-1.3.dist-info
📄
speaklater.py
(5.09 KB)
ðŸ“
typing_extensions-4.14.0.dist-info
📄
typing_extensions.py
(153.46 KB)
ðŸ“
urllib3
ðŸ“
urllib3-1.26.6.dist-info
ðŸ“
vendors_api
ðŸ“
yaml
ðŸ“
yarl
ðŸ“
yarl-1.9.2.dist-info
Editing: pam.py
# (c) 2007 Chris AtLee <chris@atlee.ca> # Licensed under the MIT license: # http://www.opensource.org/licenses/mit-license.php # # Original author: Chris AtLee # # Modified by David Ford, 2011-12-6 # added py3 support and encoding # added pam_end # added pam_setcred to reset credentials after seeing Leon Walker's remarks # added byref as well # use readline to prestuff the getuser input ''' PAM module for python Provides an authenticate function that will allow the caller to authenticate a user against the Pluggable Authentication Modules (PAM) on the system. Implemented using ctypes, so no compilation is necessary. ''' __all__ = ['pam'] __version__ = '1.8.4' __author__ = 'David Ford <david@blue-labs.org>' __released__ = '2018 June 15' import sys from ctypes import CDLL, POINTER, Structure, CFUNCTYPE, cast, byref, sizeof from ctypes import c_void_p, c_size_t, c_char_p, c_char, c_int from ctypes import memmove from ctypes.util import find_library class PamHandle(Structure): """wrapper class for pam_handle_t pointer""" _fields_ = [ ("handle", c_void_p) ] def __init__(self): Structure.__init__(self) self.handle = 0 class PamMessage(Structure): """wrapper class for pam_message structure""" _fields_ = [ ("msg_style", c_int), ("msg", c_char_p) ] def __repr__(self): return "<PamMessage %i '%s'>" % (self.msg_style, self.msg) class PamResponse(Structure): """wrapper class for pam_response structure""" _fields_ = [ ("resp", c_char_p), ("resp_retcode", c_int) ] def __repr__(self): return "<PamResponse %i '%s'>" % (self.resp_retcode, self.resp) conv_func = CFUNCTYPE(c_int, c_int, POINTER(POINTER(PamMessage)), POINTER(POINTER(PamResponse)), c_void_p) class PamConv(Structure): """wrapper class for pam_conv structure""" _fields_ = [ ("conv", conv_func), ("appdata_ptr", c_void_p) ] # Various constants PAM_PROMPT_ECHO_OFF = 1 PAM_PROMPT_ECHO_ON = 2 PAM_ERROR_MSG = 3 PAM_TEXT_INFO = 4 PAM_REINITIALIZE_CRED = 8 libc = CDLL(find_library("c")) libpam = CDLL(find_library("pam")) calloc = libc.calloc calloc.restype = c_void_p calloc.argtypes = [c_size_t, c_size_t] # bug #6 (@NIPE-SYSTEMS), some libpam versions don't include this function if hasattr(libpam, 'pam_end'): pam_end = libpam.pam_end pam_end.restype = c_int pam_end.argtypes = [PamHandle, c_int] pam_start = libpam.pam_start pam_start.restype = c_int pam_start.argtypes = [c_char_p, c_char_p, POINTER(PamConv), POINTER(PamHandle)] pam_setcred = libpam.pam_setcred pam_setcred.restype = c_int pam_setcred.argtypes = [PamHandle, c_int] pam_strerror = libpam.pam_strerror pam_strerror.restype = c_char_p pam_strerror.argtypes = [PamHandle, c_int] pam_authenticate = libpam.pam_authenticate pam_authenticate.restype = c_int pam_authenticate.argtypes = [PamHandle, c_int] class pam(): code = 0 reason = None def __init__(self): pass def authenticate(self, username, password, service='login', encoding='utf-8', resetcreds=True): """username and password authentication for the given service. Returns True for success, or False for failure. self.code (integer) and self.reason (string) are always stored and may be referenced for the reason why authentication failed. 0/'Success' will be stored for success. Python3 expects bytes() for ctypes inputs. This function will make necessary conversions using the supplied encoding. Inputs: username: username to authenticate password: password in plain text service: PAM service to authenticate against, defaults to 'login' Returns: success: True failure: False """ @conv_func def my_conv(n_messages, messages, p_response, app_data): """Simple conversation function that responds to any prompt where the echo is off with the supplied password""" # Create an array of n_messages response objects addr = calloc(n_messages, sizeof(PamResponse)) response = cast(addr, POINTER(PamResponse)) p_response[0] = response for i in range(n_messages): if messages[i].contents.msg_style == PAM_PROMPT_ECHO_OFF: dst = calloc(len(password)+1, sizeof(c_char)) memmove(dst, cpassword, len(password)) response[i].resp = dst response[i].resp_retcode = 0 return 0 # python3 ctypes prefers bytes if sys.version_info >= (3,): if isinstance(username, str): username = username.encode(encoding) if isinstance(password, str): password = password.encode(encoding) if isinstance(service, str): service = service.encode(encoding) else: if isinstance(username, unicode): username = username.encode(encoding) if isinstance(password, unicode): password = password.encode(encoding) if isinstance(service, unicode): service = service.encode(encoding) if b'\x00' in username or b'\x00' in password or b'\x00' in service: self.code = 4 # PAM_SYSTEM_ERR in Linux-PAM self.reason = 'strings may not contain NUL' return False # do this up front so we can safely throw an exception if there's # anything wrong with it cpassword = c_char_p(password) handle = PamHandle() conv = PamConv(my_conv, 0) retval = pam_start(service, username, byref(conv), byref(handle)) if retval != 0: # This is not an authentication error, something has gone wrong starting up PAM self.code = retval self.reason = "pam_start() failed" return False retval = pam_authenticate(handle, 0) auth_success = retval == 0 if auth_success and resetcreds: retval = pam_setcred(handle, PAM_REINITIALIZE_CRED); # store information to inform the caller why we failed self.code = retval self.reason = pam_strerror(handle, retval) if sys.version_info >= (3,): self.reason = self.reason.decode(encoding) if hasattr(libpam, 'pam_end'): pam_end(handle, retval) return auth_success def authenticate(*vargs, **dargs): """ Compatibility function for older versions of python-pam. """ return pam().authenticate(*vargs, **dargs) if __name__ == "__main__": import readline, getpass def input_with_prefill(prompt, text): def hook(): readline.insert_text(text) readline.redisplay() readline.set_pre_input_hook(hook) if sys.version_info >= (3,): result = input(prompt) else: result = raw_input(prompt) readline.set_pre_input_hook() return result pam = pam() username = input_with_prefill('Username: ', getpass.getuser()) # enter a valid username and an invalid/valid password, to verify both failure and success pam.authenticate(username, getpass.getpass()) print('{} {}'.format(pam.code, pam.reason))
Upload File
Create Folder