| Server IP : 127.0.1.1 / Your IP : 216.73.216.152 Web Server : Apache/2.4.52 (Ubuntu) System : Linux bahcrestlinepropertiesllc 5.15.0-113-generic #123-Ubuntu SMP Mon Jun 10 08:16:17 UTC 2024 x86_64 User : www-data ( 33) PHP Version : 7.4.33 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare, MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : OFF | Sudo : ON | Pkexec : ON Directory : /lib/python3/dist-packages/cloudinit/sources/helpers/vmware/imc/ |
Upload File : |
# Copyright (C) 2016 Canonical Ltd.
# Copyright (C) 2016 VMware INC.
#
# Author: Maitreyee Saikia <msaikia@vmware.com>
#
# This file is part of cloud-init. See LICENSE file for license information.
import logging
import os
from cloudinit import atomic_helper, subp
LOG = logging.getLogger(__name__)
class PasswordConfigurator:
"""
Class for changing configurations related to passwords in a VM. Includes
setting and expiring passwords.
"""
def configure(self, passwd, resetPasswd, distro):
"""
Main method to perform all functionalities based on configuration file
inputs.
@param passwd: encoded admin password.
@param resetPasswd: boolean to determine if password needs to be reset.
@return cfg: dict to be used by cloud-init set_passwd code.
"""
LOG.info("Starting password configuration")
if passwd:
passwd = atomic_helper.b64d(passwd)
allRootUsers = []
for line in open("/etc/passwd", "r"):
if line.split(":")[2] == "0":
allRootUsers.append(line.split(":")[0])
# read shadow file and check for each user, if its uid0 or root.
uidUsersList = []
for line in open("/etc/shadow", "r"):
user = line.split(":")[0]
if user in allRootUsers:
uidUsersList.append(user)
if passwd:
LOG.info("Setting admin password")
distro.set_passwd("root", passwd)
if resetPasswd:
self.reset_password(uidUsersList)
LOG.info("Configure Password completed!")
def reset_password(self, uidUserList):
"""
Method to reset password. Use passwd --expire command. Use chage if
not succeeded using passwd command. Log failure message otherwise.
@param: list of users for which to expire password.
"""
LOG.info("Expiring password.")
for user in uidUserList:
try:
subp.subp(["passwd", "--expire", user])
except subp.ProcessExecutionError as e:
if os.path.exists("/usr/bin/chage"):
subp.subp(["chage", "-d", "0", user])
else:
LOG.warning(
"Failed to expire password for %s with error: %s",
user,
e,
)