$38 GRAYBYTE WORDPRESS FILE MANAGER $85

SERVER : vnpttt-amd7f72-h1.vietnix.vn #1 SMP Fri May 24 12:42:50 UTC 2024
SERVER IP : 103.200.23.149 | ADMIN IP 216.73.216.22
OPTIONS : CRL = ON | WGT = ON | SDO = OFF | PKEX = OFF
DEACTIVATED : NONE

/usr/lib/python3.6/site-packages/up2date_client/

HOME
Current File : /usr/lib/python3.6/site-packages/up2date_client//clpwd.py
import pwd
import os

class ClPwd:
    class NoSuchUserException(Exception):
        def __init__(self, user):
            Exception.__init__(self, "No such user (%s)" % (user,))

    def __init__(self, min_uid = None):
        self._user_key_map = {}
        self._uid_key_map = {}
        self._user_full_map = {}
        self._uid_full_map = {}
        if min_uid is None:
            self._min_uid = self.get_sys_min_uid(500)
        else:
            self._min_uid = min_uid

    def get_user_dict(self):
        self._load_passwd_database()
        return self._user_key_map

    def get_uid_dict(self):
        self._load_passwd_database()
        return self._uid_key_map

    def get_user_full_dict(self):
        self._load_passwd_database()
        return self._user_full_map

    def get_uid_full_dict(self):
        self._load_passwd_database()
        return self._uid_full_map

    def get_pw_by_name(self, user):
        """
        Return pw_entry for user
        """
        try:
            return self.get_user_full_dict()[user]
        except KeyError:
            raise ClPwd.NoSuchUserException(user)

    def get_pw_by_uid(self, uid):
        """
        Return list of passwd entries for uid
        """
        try:
            return self.get_uid_full_dict()[uid]
        except KeyError:
            raise ClPwd.NoSuchUserException(uid)

    def get_uid(self, user):
        """
        Returns uid for user
        """
        try:
            return self.get_user_full_dict()[user].pw_uid
        except KeyError:
            raise ClPwd.NoSuchUserException(user)

    def get_homedir(self, user):
        """
        Returns homedir for a user
        @param user: string
        @return: string
        """
        try:
            return self.get_user_full_dict()[user].pw_dir
        except KeyError:
            raise ClPwd.NoSuchUserException(user)

    def _load_passwd_database(self):
        """
        Loads the passwd database and fills user_to_uid and user_to_homedir maps
        """
        if not self._uid_full_map:
            for entry in pwd.getpwall():
                self._user_full_map[entry.pw_name] = entry
                if entry.pw_uid not in self._uid_full_map:
                    self._uid_full_map[entry.pw_uid] = []
                self._uid_full_map[entry.pw_uid].append(entry)
                if entry.pw_uid >= self._min_uid:
                    self._user_key_map[entry.pw_name] = entry
                    if entry.pw_uid not in self._uid_key_map:
                        self._uid_key_map[entry.pw_uid] = []
                    self._uid_key_map[entry.pw_uid].append(entry)

    def get_names(self, uid):
        """
        Return names of users with uid specified
        @param uid: int
        @return: list of strings
        """
        try:
            entries = self.get_uid_full_dict()[uid]
        except KeyError:
            raise ClPwd.NoSuchUserException(uid)

        return [entry.pw_name for entry in entries]


    def get_sys_min_uid(self, def_min_uid = 500):
        """
        Return system defined MIN_UID from /etc/login.def or def_min_uid
        @param def_min_uid: int
        @return: MIN_UID: int
        """

        LOGIN_DEF_FILE = '/etc/login.defs'
        if (os.path.exists(LOGIN_DEF_FILE)):
            with open(LOGIN_DEF_FILE, 'r') as lines:
                for line in lines:
                    if line.startswith('UID_MIN'):
                        try:
                            return int(line.split('UID_MIN')[1].strip())
                        except ValueError:
                            pass

        return def_min_uid

Current_dir [ NOT WRITEABLE ] Document_root [ WRITEABLE ]


[ Back ]
NAME
SIZE
LAST TOUCH
USER
CAN-I?
FUNCTIONS
..
--
16 Dec 2025 9.25 PM
root / root
0755
__pycache__
--
14 Aug 2025 9.29 PM
root / root
0755
__init__.py
0 KB
29 May 2025 8.37 PM
root / root
0644
capabilities.py
7.277 KB
29 May 2025 8.37 PM
root / root
0644
clientCaps.py
2.156 KB
29 May 2025 8.37 PM
root / root
0644
clpwd.py
3.558 KB
29 May 2025 8.37 PM
root / root
0644
config.py
14.456 KB
29 May 2025 8.37 PM
root / root
0644
debUtils.py
2.764 KB
29 May 2025 8.37 PM
root / root
0644
getMethod.py
4.201 KB
29 May 2025 8.37 PM
root / root
0644
haltree.py
4.533 KB
29 May 2025 8.37 PM
root / root
0644
hardware.py
31.909 KB
29 May 2025 8.37 PM
root / root
0644
hardware_gudev.py
12.906 KB
29 May 2025 8.37 PM
root / root
0644
hardware_hal.py
11.332 KB
29 May 2025 8.37 PM
root / root
0644
hardware_udev.py
12.988 KB
29 May 2025 8.37 PM
root / root
0644
pkgUtils.py
0.288 KB
29 May 2025 8.37 PM
root / root
0644
pkgplatform.py
0.302 KB
29 May 2025 8.47 PM
root / root
0644
pmPlugin.py
2.792 KB
29 May 2025 8.37 PM
root / root
0644
rhnChannel.py
4.913 KB
29 May 2025 8.37 PM
root / root
0644
rhnHardware.py
0.32 KB
29 May 2025 8.37 PM
root / root
0644
rhnPackageInfo.py
2.34 KB
29 May 2025 8.37 PM
root / root
0644
rhncli.py
9.116 KB
29 May 2025 8.37 PM
root / root
0644
rhnreg.py
31.349 KB
29 May 2025 8.37 PM
root / root
0644
rhnreg_constants.py
18.134 KB
29 May 2025 8.37 PM
root / root
0644
rhnserver.py
9.308 KB
29 May 2025 8.37 PM
root / root
0644
rpcServer.py
11.718 KB
29 May 2025 8.37 PM
root / root
0644
rpmUtils.py
5.196 KB
29 May 2025 8.37 PM
root / root
0644
transaction.py
4.095 KB
29 May 2025 8.37 PM
root / root
0644
tui.py
43.7 KB
29 May 2025 8.37 PM
root / root
0644
up2dateAuth.py
10.688 KB
29 May 2025 8.37 PM
root / root
0644
up2dateErrors.py
10.256 KB
29 May 2025 8.37 PM
root / root
0644
up2dateLog.py
2.059 KB
29 May 2025 8.37 PM
root / root
0644
up2dateUtils.py
5.059 KB
29 May 2025 8.47 PM
root / root
0644

GRAYBYTE WORDPRESS FILE MANAGER @ 2026 CONTACT ME
Static GIF