wni: set random password on user creation

This commit is contained in:
Rafał Wojdyła 2013-11-11 22:11:08 +01:00 committed by Marek Marczykowski-Górecki
parent ccd04c7c8f
commit f91d6e93f6

View File

@ -31,7 +31,7 @@ import win32netcon
import win32security import win32security
import win32profile import win32profile
import pywintypes import pywintypes
import md5 import random
from qubes.storage import QubesVmStorage from qubes.storage import QubesVmStorage
from qubes.qubes import QubesException,system_path from qubes.qubes import QubesException,system_path
@ -53,30 +53,28 @@ class QubesWniVmStorage(QubesVmStorage):
os.putenv("WNI_DRIVER_QUBESDB_PATH", system_path['qubesdb_daemon_path']) os.putenv("WNI_DRIVER_QUBESDB_PATH", system_path['qubesdb_daemon_path'])
os.putenv("WNI_DRIVER_QREXEC_PATH", system_path['qrexec_agent_path']) os.putenv("WNI_DRIVER_QREXEC_PATH", system_path['qrexec_agent_path'])
def _get_secret(self):
# TODO: some machine-specific secret (accessible only to Administrator)
return ""
def _get_username(self, vmname = None): def _get_username(self, vmname = None):
if vmname is None: if vmname is None:
vmname = self.vm.name vmname = self.vm.name
return "qubes-vm-%s" % vmname return "qubes-vm-%s" % vmname
def _get_password(self, vmname = None): def _get_random_password(self, vmname = None):
if vmname is None: if vmname is None:
vmname = self.vm.name vmname = self.vm.name
return md5.md5("%s-%s" % (vmname, self._get_secret())).hexdigest() return '%x' % random.SystemRandom().getrandombits(256)
def get_config_params(self): def get_config_params(self):
return {} return {}
def create_on_disk_private_img(self, verbose, source_template = None): def create_on_disk_private_img(self, verbose, source_template = None):
# FIXME: this may not always be correct
home_dir = os.path.join(self.home_root, self._get_username()) home_dir = os.path.join(self.home_root, self._get_username())
# Create user data in information level 1 (PyUSER_INFO_1) format. # Create user data in information level 1 (PyUSER_INFO_1) format.
user_data = {} user_data = {}
user_data['name'] = self._get_username() user_data['name'] = self._get_username()
user_data['full_name'] = self._get_username() user_data['full_name'] = self._get_username()
user_data['password'] = self._get_password() # libvirt driver doesn't need to know the password anymore
user_data['password'] = self._get_random_password()
user_data['flags'] = ( user_data['flags'] = (
win32netcon.UF_NORMAL_ACCOUNT | win32netcon.UF_NORMAL_ACCOUNT |
win32netcon.UF_SCRIPT | win32netcon.UF_SCRIPT |
@ -113,13 +111,8 @@ class QubesWniVmStorage(QubesVmStorage):
user_data['name'] = self._get_username(new_name) user_data['name'] = self._get_username(new_name)
win32net.NetUserSetInfo(None, win32net.NetUserSetInfo(None,
self._get_username(old_name), 0, user_data) self._get_username(old_name), 0, user_data)
win32net.NetUserChangePassword(None,
self._get_username(new_name),
self._get_password(old_name),
self._get_password(new_name))
#TODO: rename user profile #TODO: rename user profile
def verify_files(self): def verify_files(self):
if not os.path.exists (self.vmdir): if not os.path.exists (self.vmdir):
raise QubesException ( raise QubesException (