Submit
Path:
~
/
/
opt
/
imunify360
/
venv
/
lib
/
python3.11
/
site-packages
/
File Content:
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))
Submit
FILE
FOLDER
Name
Size
Permission
Action
Babel-2.12.1.dist-info
---
0755
Cerberus-1.3.5.dist-info
---
0755
Crypto
---
0755
Jinja2-2.11.2.dist-info
---
0755
PyJWT-2.1.0.dist-info
---
0755
PyMySQL-1.1.1.dist-info
---
0755
PyYAML-6.0.1.dist-info
---
0755
__pycache__
---
0755
_distutils_hack
---
0755
_yaml
---
0755
aiodns
---
0755
aiodns-3.0.0.dist-info
---
0755
aiohttp
---
0755
aiohttp-3.8.4.dist-info
---
0755
aiohttp_babel
---
0755
aiohttp_babel-0.0.6.dist-info
---
0755
aiohttp_jinja2
---
0755
aiohttp_jinja2-1.3.0.dist-info
---
0755
aiosignal
---
0755
aiosignal-1.3.1.dist-info
---
0755
async_lru
---
0755
async_lru-2.0.5.dist-info
---
0755
async_timeout
---
0755
async_timeout-4.0.3.dist-info
---
0755
attr
---
0755
attrs
---
0755
attrs-23.1.0.dist-info
---
0755
babel
---
0755
blinker
---
0755
blinker-1.4.dist-info
---
0755
cerberus
---
0755
certifi
---
0755
certifi-2023.7.22.dist-info
---
0755
cffi
---
0755
cffi-1.15.1.dist-info
---
0755
charset_normalizer
---
0755
charset_normalizer-2.0.12.dist-info
---
0755
clcommon
---
0755
clcommon-3.4.16.dist-info
---
0755
click
---
0755
click-8.1.7.dist-info
---
0755
cryptography
---
0755
cryptography-43.0.1.dist-info
---
0755
daemon
---
0755
dateutil
---
0755
defence360agent
---
0755
distro-1.6.0.dist-info
---
0755
docutils
---
0755
docutils-0.20.1.dist-info
---
0755
frozenlist
---
0755
frozenlist-1.4.0.dist-info
---
0755
geoip2
---
0755
geoip2-4.2.0.dist-info
---
0755
google
---
0755
humanize
---
0755
humanize-4.9.0.dist-info
---
0755
idna
---
0755
idna-3.4.dist-info
---
0755
im360
---
0755
imav
---
0755
imunify360_firewall-8.6.2-py3.11.egg-info
---
0755
imunify_antivirus-8.5.4-py3.11.egg-info
---
0755
imunify_core-8.5.1-py3.11.egg-info
---
0755
jinja2
---
0755
jsonschema
---
0755
jsonschema-3.2.0.dist-info
---
0755
jwt
---
0755
lockfile
---
0755
lockfile-0.12.2.dist-info
---
0755
lxml
---
0755
lxml-4.9.2.dist-info
---
0755
markupsafe
---
0755
markupsafe-2.0.1.dist-info
---
0755
maxminddb
---
0755
maxminddb-2.4.0.dist-info
---
0755
multidict
---
0755
multidict-6.0.4.dist-info
---
0755
packaging
---
0755
packaging-23.1.dist-info
---
0755
pam_i360
---
0755
pam_i360-6.4.10+1.el7-py3.11.egg-info
---
0755
peewee-3.16.0.dist-info
---
0755
peewee_migrate
---
0755
peewee_migrate-1.7.1.dist-info
---
0755
phpserialize-1.3.dist-info
---
0755
pip
---
0755
pip-25.1.1.dist-info
---
0755
pkg_resources
---
0755
playhouse
---
0755
protobuf-4.23.2.dist-info
---
0755
psutil
---
0755
psutil-5.8.0.dist-info
---
0755
pyasn1
---
0755
pyasn1-0.6.1.dist-info
---
0755
pycares
---
0755
pycares-4.3.0.dist-info
---
0755
pycparser
---
0755
pycparser-2.21.dist-info
---
0755
pycryptodome-3.18.0.dist-info
---
0755
pymysql
---
0755
pyrsistent
---
0755
pyrsistent-0.19.3.dist-info
---
0755
python_daemon-2.3.0.dist-info
---
0755
python_dateutil-2.8.2.dist-info
---
0755
python_pam-1.8.4.dist-info
---
0755
pytricia-1.0.2.dist-info
---
0755
pyzstd
---
0755
pyzstd-0.15.3.dist-info
---
0755
requests
---
0755
requests-2.26.0.dist-info
---
0755
restore_infected
---
0755
restore_infected-4.0.5-py3.11.egg-info
---
0755
sdnotify
---
0755
sdnotify-0.3.2.dist-info
---
0755
sentry_sdk
---
0755
sentry_sdk-0.19.2.dist-info
---
0755
setuptools
---
0755
setuptools-69.0.2.dist-info
---
0755
simplejson
---
0755
simplejson-3.20.1.dist-info
---
0755
six-1.16.0.dist-info
---
0755
speaklater-1.3.dist-info
---
0755
typing_extensions-4.14.0.dist-info
---
0755
urllib3
---
0755
urllib3-1.26.6.dist-info
---
0755
vendors_api
---
0755
yaml
---
0755
yarl
---
0755
yarl-1.9.2.dist-info
---
0755
_cffi_backend.cpython-311-x86_64-linux-gnu.so
1065976 bytes
0755
_pyrsistent_version.py
23 bytes
0644
distro.py
48414 bytes
0644
distutils-precedence.pth
151 bytes
0644
pam.py
7556 bytes
0644
peewee.py
274461 bytes
0644
phpserialize.py
18400 bytes
0644
pwiz.py
8193 bytes
0644
pytricia.cpython-311-x86_64-linux-gnu.so
95936 bytes
0755
secureio.py
20289 bytes
0644
six.py
34549 bytes
0644
speaklater.py
5216 bytes
0644
typing_extensions.py
157143 bytes
0644
N4ST4R_ID | Naxtarrr