예제 #1
0
 def modify_bootini(self, drive, associated_task):
     log.debug("modify_bootini %s" % drive.path)
     bootini = join_path(drive.path, 'boot.ini')
     if not os.path.isfile(bootini):
         log.debug("Could not find boot.ini %s" % bootini)
         return
     src = join_path(self.info.root_dir, 'winboot', 'wisildr')
     dest = join_path(drive.path, 'wisildr')
     shutil.copyfile(src, dest)
     src = join_path(self.info.root_dir, 'winboot', 'wisildr.mbr')
     dest = join_path(drive.path, 'wisildr.mbr')
     shutil.copyfile(src, dest)
     run_command(['attrib', '-R', '-S', '-H', bootini])
     boot_line = 'C:\wisildr.mbr = "%s"' % self.info.distro.name
     old_line = boot_line[:boot_line.index("=")].strip().lower()
     # ConfigParser gets confused by the ':' and changes the options order
     content = read_file(bootini)
     if content[-1] != '\n':
         content += '\n'
     lines = content.split('\n')
     is_section = False
     for i, line in enumerate(lines):
         if line.strip().lower() == "[operating systems]":
             is_section = True
         elif line.strip().startswith("["):
             is_section = False
         if is_section and line.strip().lower().startswith(old_line):
             lines[i] = boot_line
             break
         if is_section and not line.strip():
             lines.insert(i, boot_line)
             break
     content = '\n'.join(lines)
     write_file(bootini, content)
     run_command(['attrib', '+R', '+S', '+H', bootini])
예제 #2
0
 def modify_bootini(self, drive, associated_task):
     log.debug("modify_bootini %s" % drive.path)
     bootini = join_path(drive.path, 'boot.ini')
     if not os.path.isfile(bootini):
         log.debug("Could not find boot.ini %s" % bootini)
         return
     src = join_path(self.info.root_dir, 'winboot', 'wisildr')
     dest = join_path(drive.path, 'wisildr')
     shutil.copyfile(src,  dest)
     src = join_path(self.info.root_dir, 'winboot', 'wisildr.mbr')
     dest = join_path(drive.path, 'wisildr.mbr')
     shutil.copyfile(src,  dest)
     run_command(['attrib', '-R', '-S', '-H', bootini])
     boot_line = 'C:\wisildr.mbr = "%s"' % self.info.distro.name
     old_line = boot_line[:boot_line.index("=")].strip().lower()
     # ConfigParser gets confused by the ':' and changes the options order
     content = read_file(bootini)
     if content[-1] != '\n':
         content += '\n'
     lines = content.split('\n')
     is_section = False
     for i,line in enumerate(lines):
         if line.strip().lower() == "[operating systems]":
             is_section = True
         elif line.strip().startswith("["):
             is_section = False
         if is_section and line.strip().lower().startswith(old_line):
             lines[i] = boot_line
             break
         if is_section and not line.strip():
             lines.insert(i, boot_line)
             break
     content = '\n'.join(lines)
     write_file(bootini, content)
     run_command(['attrib', '+R', '+S', '+H', bootini])
예제 #3
0
 def expand_diskimage(self, associated_task=None):
     # TODO: might use -p to get percentage to feed into progress.
     root = join_path(self.info.disks_dir, 'root.disk')
     resize2fs = join_path(self.info.bin_dir, 'resize2fs.exe')
     resize_cmd = [resize2fs, '-f', root,
                   '%dM' % self.info.root_size_mb]
     run_command(resize_cmd)
예제 #4
0
    def modify_configsys(self, drive, associated_task):
        log.debug("modify_configsys %s" % drive.path)
        configsys = join_path(drive.path, 'config.sys')
        if not os.path.isfile(configsys):
            return
        src = join_path(self.info.root_dir, 'winboot', 'wisildr.exe')
        dest = join_path(drive.path, 'wisildr.exe')
        shutil.copyfile(src, dest)
        run_command(['attrib', '-R', '-S', '-H', configsys])
        config = read_file(configsys)
        if 'REM WUBI MENU START\n' in config:
            log.debug("Configsys has already been modified")
            return

        config += '''
        REM WUBI MENU START
        [menu]
        menucolor=15,0
        menuitem=windows,Windows
        menuitem=wisildr,$distro
        menudefault=windows,10
        [wisildr]
        device=wisildr.exe
        [windows]

        REM WUBI MENU END
        '''
        write_file(configsys, config)
        run_command(['attrib', '+R', '+S', '+H', configsys])
예제 #5
0
 def undo_bcd(self, associated_task):
     bcdedit = join_path(os.getenv('SystemDrive'), 'bcdedit.exe')
     if not isfile(bcdedit):
         bcdedit = join_path(os.getenv('SystemRoot'), 'sysnative', 'bcdedit.exe')
     if not os.path.isfile(bcdedit):
         bcdedit = join_path(os.environ['systemroot'], 'System32', 'bcdedit.exe')
     if not os.path.isfile(bcdedit):
         log.error("Cannot find bcdedit")
         return
     id = registry.get_value(
         'HKEY_LOCAL_MACHINE',
         self.info.registry_key,
         'VistaBootDrive')
     if not id:
         log.debug("Could not find bcd id")
         return
     log.debug("Removing bcd entry %s" % id)
     command = [bcdedit, '/delete', id , '/f']
     try:
         run_command(command)
         registry.set_value(
             'HKEY_LOCAL_MACHINE',
             self.info.registry_key,
             'VistaBootDrive',
             "")
     except Exception, err: #this shouldn't be fatal
         log.error(err)
예제 #6
0
    def modify_configsys(self, drive, associated_task):
        log.debug("modify_configsys %s" % drive.path)
        configsys = join_path(drive.path, 'config.sys')
        if not os.path.isfile(configsys):
            return
        src = join_path(self.info.root_dir, 'winboot', 'wisildr.exe')
        dest = join_path(drive.path, 'wisildr.exe')
        shutil.copyfile(src,  dest)
        run_command(['attrib', '-R', '-S', '-H', configsys])
        config = read_file(configsys)
        if 'REM WUBI MENU START\n' in config:
            log.debug("Configsys has already been modified")
            return

        config += '''
        REM WUBI MENU START
        [menu]
        menucolor=15,0
        menuitem=windows,Windows
        menuitem=wisildr,$distro
        menudefault=windows,10
        [wisildr]
        device=wisildr.exe
        [windows]

        REM WUBI MENU END
        '''
        write_file(configsys, config)
        run_command(['attrib', '+R', '+S', '+H', configsys])
예제 #7
0
 def select_target_dir(self):
     target_dir = join_path(self.info.target_drive.path, self.info.distro.installation_dir)
     target_dir.replace(' ', '_')
     target_dir.replace('__', '_')
     if os.path.exists(target_dir):
         raise Exception("Cannot install into %s.\nThere is another file or directory with this name.\nPlease remove it before continuing." % target_dir)
     self.info.target_dir = target_dir
     log.info('Installing into %s' % target_dir)
     self.info.icon = join_path(self.info.target_dir, self.info.distro.name + '.ico')
예제 #8
0
 def uncompress_files(self, associated_task):
     if self.info.target_drive.is_fat():
         return
     command1 = ['compact', join_path(self.info.install_boot_dir), '/U', '/A', '/F']
     command2 = ['compact', join_path(self.info.install_boot_dir,'*.*'), '/U', '/A', '/F']
     for command in [command1,command2]:
         log.debug(" ".join(command))
         try:
             run_command(command)
         except Exception, err:
             log.error(err)
예제 #9
0
 def select_target_dir(self):
     target_dir = join_path(self.info.target_drive.path,
                            self.info.distro.installation_dir)
     target_dir.replace(' ', '_')
     target_dir.replace('__', '_')
     if os.path.exists(target_dir):
         raise Exception(
             "Cannot install into %s.\nThere is another file or directory with this name.\nPlease remove it before continuing."
             % target_dir)
     self.info.target_dir = target_dir
     log.info('Installing into %s' % target_dir)
     self.info.icon = join_path(self.info.target_dir,
                                self.info.distro.name + '.ico')
예제 #10
0
 def extract_file_from_iso(self,
                           iso_path,
                           file_path,
                           output_dir=None,
                           overwrite=False):
     '''
     platform specific
     '''
     log.debug("  extracting %s from %s" % (file_path, iso_path))
     if not iso_path or not os.path.exists(iso_path):
         raise Exception('Invalid path %s' % iso_path)
     iso_path = abspath(iso_path)
     file_path = os.path.normpath(file_path)
     if not output_dir:
         output_dir = tempfile.gettempdir()
     output_file = join_path(output_dir, os.path.basename(file_path))
     if os.path.exists(output_file):
         if overwrite:
             os.unlink(output_file)
         else:
             raise Exception('Cannot overwrite %s' % output_file)
     command = [
         self.info.iso_extractor, 'e', '-i!' + file_path, '-o' + output_dir,
         iso_path
     ]
     try:
         run_command(command)
     except Exception, err:
         log.exception(err)
         output_file = None
예제 #11
0
 def create_virtual_disks(self, associated_task):
     self.info.disks_dir
     for disk in ["root", "home", "usr", "swap"]:
         path = join_path(self.info.disks_dir, disk + ".disk")
         size_mb = int(getattr(self.info, disk + "_size_mb"))
         if size_mb:
             create_virtual_disk(path, size_mb)
예제 #12
0
 def create_uninstaller(self, associated_task):
     uninstaller_name = 'uninstall-%s.exe' % self.info.application_name
     uninstaller_name.replace(' ', '_')
     uninstaller_name.replace('__', '_')
     uninstaller_path = join_path(self.info.target_dir, uninstaller_name)
     if os.path.splitext(self.info.original_exe)[-1] == '.exe':
         log.debug('Copying uninstaller %s -> %s' %
                   (self.info.original_exe, uninstaller_path))
         shutil.copyfile(self.info.original_exe, uninstaller_path)
     registry.set_value('HKEY_LOCAL_MACHINE', self.info.registry_key,
                        'UninstallString', uninstaller_path)
     registry.set_value('HKEY_LOCAL_MACHINE', self.info.registry_key,
                        'InstallationDir', self.info.target_dir)
     registry.set_value('HKEY_LOCAL_MACHINE', self.info.registry_key,
                        'DisplayName', self.info.distro.name)
     registry.set_value('HKEY_LOCAL_MACHINE', self.info.registry_key,
                        'DisplayIcon', self.info.icon)
     registry.set_value('HKEY_LOCAL_MACHINE', self.info.registry_key,
                        'DisplayVersion', self.info.version_revision)
     registry.set_value('HKEY_LOCAL_MACHINE', self.info.registry_key,
                        'Publisher', self.info.distro.name)
     registry.set_value('HKEY_LOCAL_MACHINE', self.info.registry_key,
                        'URLInfoAbout', self.info.distro.website)
     registry.set_value('HKEY_LOCAL_MACHINE', self.info.registry_key,
                        'HelpLink', self.info.distro.support)
예제 #13
0
 def create_virtual_disks(self, associated_task):
     self.info.disks_dir
     for disk in ["root", "home", "usr", "swap"]:
         path = join_path(self.info.disks_dir, disk + ".disk")
         size_mb = int(getattr(self.info, disk + "_size_mb"))
         if size_mb:
             create_virtual_disk(path, size_mb)
예제 #14
0
 def undo_bootini(self, drive, associated_task):
     log.debug("undo_bootini %s" % drive.path)
     bootini = join_path(drive.path, 'boot.ini')
     if not os.path.isfile(bootini):
         return
     run_command(['attrib', '-R', '-S', '-H', bootini])
     remove_line_in_file(bootini, 'c:\wisildr.mbr', ignore_case=True)
     run_command(['attrib', '+R', '+S', '+H', bootini])
예제 #15
0
 def undo_bootini(self, drive, associated_task):
     log.debug("undo_bootini %s" % drive.path)
     bootini = join_path(drive.path, 'boot.ini')
     if not os.path.isfile(bootini):
         return
     run_command(['attrib', '-R', '-S', '-H', bootini])
     remove_line_in_file(bootini, 'c:\wisildr.mbr', ignore_case=True)
     run_command(['attrib', '+R', '+S', '+H', bootini])
예제 #16
0
 def uncompress_files(self, associated_task):
     if self.info.target_drive.is_fat():
         return
     command1 = [
         'compact',
         join_path(self.info.install_boot_dir), '/U', '/A', '/F'
     ]
     command2 = [
         'compact',
         join_path(self.info.install_boot_dir, '*.*'), '/U', '/A', '/F'
     ]
     for command in [command1, command2]:
         log.debug(" ".join(command))
         try:
             run_command(command)
         except Exception, err:
             log.error(err)
예제 #17
0
 def copy_installation_files(self, associated_task):
     self.info.custominstall = join_path(self.info.install_dir,
                                         'custom-installation')
     src = join_path(self.info.data_dir, 'custom-installation')
     dest = self.info.custominstall
     log.debug('Copying %s -> %s' % (src, dest))
     shutil.copytree(src, dest)
     src = join_path(self.info.root_dir, 'winboot')
     if isdir(
             src
     ):  # make runpy will fail otherwise as winboot will not be there
         dest = join_path(self.info.target_dir, 'winboot')
         log.debug('Copying %s -> %s' % (src, dest))
         shutil.copytree(src, dest)
     dest = join_path(self.info.custominstall, 'hooks',
                      'failure-command.sh')
     msg=_('The installation failed. Logs have been saved in: %s.' \
         '\n\nNote that in verbose mode, the logs may include the password.' \
         '\n\nThe system will now reboot.')
     msg = msg % join_path(self.info.install_dir, 'installation-logs.zip')
     msg = "msg=\"%s\"" % msg
     msg = str(msg.encode('utf8'))
     replace_line_in_file(dest, 'msg=', msg)
     src = join_path(self.info.image_dir, self.info.distro.name + '.ico')
     dest = self.info.icon
     log.debug('Copying %s -> %s' % (src, dest))
     shutil.copyfile(src, dest)
예제 #18
0
 def get_windows_user_dir(self):
     homedrive = os.getenv('homedrive')
     homepath = os.getenv('homepath')
     user_directory = ""
     if homedrive and homepath:
         user_directory = join_path(homedrive, homepath)
         user_directory = user_directory.decode('ascii', 'ignore')
     log.debug('user_directory=%s' % user_directory)
     return user_directory
예제 #19
0
 def get_windows_user_dir(self):
     homedrive = os.getenv('homedrive')
     homepath = os.getenv('homepath')
     user_directory = ""
     if homedrive and homepath:
         user_directory = join_path(homedrive, homepath)
         user_directory = user_directory.decode('ascii', 'ignore')
     log.debug('user_directory=%s' % user_directory)
     return user_directory
예제 #20
0
 def diskimage_bootloader(self, associated_task=None):
     src = join_path(self.info.root_dir, 'winboot')
     dest = join_path(self.info.target_dir, 'winboot')
     if isdir(src):
         log.debug('Copying %s -> %s' % (src, dest))
         shutil.copytree(src, dest)
     src = join_path(self.info.disks_dir, 'wisildr')
     shutil.copyfile(src, join_path(dest, 'wisildr'))
     # Overwrite the copy that's in root_dir.
     for drive in self.info.drives:
         if drive.type not in ('removable', 'hd'):
             continue
         dest = join_path(drive.path, 'wisildr')
         try:
             shutil.copyfile(src, dest)
         except: # don't need to worry about failure here
             pass
     os.unlink(src)
예제 #21
0
 def diskimage_bootloader(self, associated_task=None):
     src = join_path(self.info.root_dir, 'winboot')
     dest = join_path(self.info.target_dir, 'winboot')
     if isdir(src):
         log.debug('Copying %s -> %s' % (src, dest))
         shutil.copytree(src, dest)
     src = join_path(self.info.disks_dir, 'wisildr')
     shutil.copyfile(src, join_path(dest, 'wisildr'))
     # Overwrite the copy that's in root_dir.
     for drive in self.info.drives:
         if drive.type not in ('removable', 'hd'):
             continue
         dest = join_path(drive.path, 'wisildr')
         try:
             shutil.copyfile(src, dest)
         except:  # don't need to worry about failure here
             pass
     os.unlink(src)
예제 #22
0
 def uncompress_target_dir(self, associated_task):
     if self.info.target_drive.is_fat():
         return
     try:
         command = ['compact', self.info.target_dir, '/U', '/A', '/F']
         run_command(command)
         command = ['compact', join_path(self.info.target_dir,'*.*'), '/U', '/A', '/F']
         run_command(command)
     except Exception, err:
         log.error(err)
예제 #23
0
 def undo_bootloader(self, associated_task):
     winboot_files = ['wisildr', 'wisildr.mbr', 'wisildr.exe']
     self.undo_bcd(associated_task)
     for drive in self.info.drives:
         if drive.type not in ('removable', 'hd'):
             continue
         self.undo_bootini(drive, associated_task)
         self.undo_configsys(drive, associated_task)
         for f in winboot_files:
             f = join_path(drive.path, f)
             if os.path.isfile(f):
                 os.unlink(f)
예제 #24
0
 def undo_bootloader(self, associated_task):
     winboot_files = ['wisildr', 'wisildr.mbr', 'wisildr.exe']
     self.undo_bcd(associated_task)
     for drive in self.info.drives:
         if drive.type not in ('removable', 'hd'):
             continue
         self.undo_bootini(drive, associated_task)
         self.undo_configsys(drive, associated_task)
         for f in winboot_files:
             f = join_path(drive.path, f)
             if os.path.isfile(f):
                 os.unlink(f)
예제 #25
0
 def uncompress_target_dir(self, associated_task):
     if self.info.target_drive.is_fat():
         return
     try:
         command = ['compact', self.info.target_dir, '/U', '/A', '/F']
         run_command(command)
         command = [
             'compact',
             join_path(self.info.target_dir, '*.*'), '/U', '/A', '/F'
         ]
         run_command(command)
     except Exception, err:
         log.error(err)
예제 #26
0
 def undo_configsys(self, drive, associated_task):
     log.debug("undo_configsys %s" % drive)
     configsys = join_path(drive.path, 'config.sys')
     if not os.path.isfile(configsys):
         return
     run_command(['attrib', '-R', '-S', '-H', configsys])
     config = read_file(configsys)
     s = config.find('REM WUBI MENU START\n')
     e = config.find('REM WUBI MENU END\n')
     if s > 0 and e > 0:
         e += len('REM WUBI MENU END')
     config = config[:s] + config[e:]
     write_file(configsys, config)
     run_command(['attrib', '+R', '+S', '+H', configsys])
예제 #27
0
 def undo_configsys(self, drive, associated_task):
     log.debug("undo_configsys %s" % drive)
     configsys = join_path(drive.path, 'config.sys')
     if not os.path.isfile(configsys):
         return
     run_command(['attrib', '-R', '-S', '-H', configsys])
     config = read_file(configsys)
     s = config.find('REM WUBI MENU START\n')
     e = config.find('REM WUBI MENU END\n')
     if s > 0 and e > 0:
         e += len('REM WUBI MENU END')
     config = config[:s] + config[e:]
     write_file(configsys, config)
     run_command(['attrib', '+R', '+S', '+H', configsys])
예제 #28
0
 def undo_bcd(self, associated_task):
     bcdedit = join_path(os.getenv('SystemDrive'), 'bcdedit.exe')
     if not isfile(bcdedit):
         bcdedit = join_path(os.getenv('SystemRoot'), 'sysnative',
                             'bcdedit.exe')
     if not os.path.isfile(bcdedit):
         bcdedit = join_path(os.environ['systemroot'], 'System32',
                             'bcdedit.exe')
     if not os.path.isfile(bcdedit):
         log.error("Cannot find bcdedit")
         return
     id = registry.get_value('HKEY_LOCAL_MACHINE', self.info.registry_key,
                             'VistaBootDrive')
     if not id:
         log.debug("Could not find bcd id")
         return
     log.debug("Removing bcd entry %s" % id)
     command = [bcdedit, '/delete', id, '/f']
     try:
         run_command(command)
         registry.set_value('HKEY_LOCAL_MACHINE', self.info.registry_key,
                            'VistaBootDrive', "")
     except Exception, err:  #this shouldn't be fatal
         log.error(err)
예제 #29
0
    def modify_bcd(self, drive, associated_task):
        log.debug("modify_bcd %s" % drive)
        if drive is self.info.system_drive \
        or drive.path == "C:" \
        or drive.path == os.getenv('SystemDrive').upper():
            src = join_path(self.info.root_dir, 'winboot', 'wisildr')
            dest = join_path(drive.path, 'wisildr')
            shutil.copyfile(src, dest)
            src = join_path(self.info.root_dir, 'winboot', 'wisildr.mbr')
            dest = join_path(drive.path, 'wisildr.mbr')
            shutil.copyfile(src, dest)
        bcdedit = join_path(os.getenv('SystemDrive'), 'bcdedit.exe')
        if not os.path.isfile(bcdedit):
            bcdedit = join_path(os.environ['systemroot'], 'sysnative',
                                'bcdedit.exe')
        # FIXME: Just test for bcdedit in the PATH.  What's the Windows
        # equivalent of `type`?
        if not os.path.isfile(bcdedit):
            bcdedit = join_path(os.environ['systemroot'], 'System32',
                                'bcdedit.exe')
        if not os.path.isfile(bcdedit):
            log.error("Cannot find bcdedit")
            return
        if registry.get_value('HKEY_LOCAL_MACHINE', self.info.registry_key,
                              'VistaBootDrive'):
            log.debug("BCD has already been modified")
            return

        command = [
            bcdedit, '/create', '/d',
            '%s' % self.info.distro.name, '/application', 'bootsector'
        ]
        id = run_command(command)
        id = id[id.index('{'):id.index('}') + 1]
        mbr_path = join_path(self.info.target_dir, 'winboot',
                             'wisildr.mbr')[2:]
        run_command([
            bcdedit, '/set', id, 'device',
            'partition=%s' % self.info.target_drive.path
        ])
        run_command([bcdedit, '/set', id, 'path', mbr_path])
        run_command([bcdedit, '/displayorder', id, '/addlast'])
        run_command([bcdedit, '/timeout', '10'])
        run_command([bcdedit, '/bootsequence', id])
        registry.set_value('HKEY_LOCAL_MACHINE', self.info.registry_key,
                           'VistaBootDrive', id)
예제 #30
0
 def create_uninstaller(self, associated_task):
     uninstaller_name = 'uninstall-%s.exe'  % self.info.application_name
     uninstaller_name.replace(' ', '_')
     uninstaller_name.replace('__', '_')
     uninstaller_path = join_path(self.info.target_dir, uninstaller_name)
     if os.path.splitext(self.info.original_exe)[-1] == '.exe':
         log.debug('Copying uninstaller %s -> %s' % (self.info.original_exe, uninstaller_path))
         shutil.copyfile(self.info.original_exe, uninstaller_path)
     registry.set_value('HKEY_LOCAL_MACHINE', self.info.registry_key, 'UninstallString', uninstaller_path)
     registry.set_value('HKEY_LOCAL_MACHINE', self.info.registry_key, 'InstallationDir', self.info.target_dir)
     registry.set_value('HKEY_LOCAL_MACHINE', self.info.registry_key, 'DisplayName', self.info.distro.name)
     registry.set_value('HKEY_LOCAL_MACHINE', self.info.registry_key, 'DisplayIcon', self.info.icon)
     registry.set_value('HKEY_LOCAL_MACHINE', self.info.registry_key, 'DisplayVersion', self.info.version_revision)
     registry.set_value('HKEY_LOCAL_MACHINE', self.info.registry_key, 'Publisher', self.info.distro.name)
     registry.set_value('HKEY_LOCAL_MACHINE', self.info.registry_key, 'URLInfoAbout', self.info.distro.website)
     registry.set_value('HKEY_LOCAL_MACHINE', self.info.registry_key, 'HelpLink', self.info.distro.support)
예제 #31
0
    def modify_bcd(self, drive, associated_task):
        log.debug("modify_bcd %s" % drive)
        if drive is self.info.system_drive \
        or drive.path == "C:" \
        or drive.path == os.getenv('SystemDrive').upper():
            src = join_path(self.info.root_dir, 'winboot', 'wisildr')
            dest = join_path(drive.path, 'wisildr')
            shutil.copyfile(src,  dest)
            src = join_path(self.info.root_dir, 'winboot', 'wisildr.mbr')
            dest = join_path(drive.path, 'wisildr.mbr')
            shutil.copyfile(src,  dest)
        bcdedit = join_path(os.getenv('SystemDrive'), 'bcdedit.exe')
        if not os.path.isfile(bcdedit):
            bcdedit = join_path(os.environ['systemroot'], 'sysnative', 'bcdedit.exe')
        # FIXME: Just test for bcdedit in the PATH.  What's the Windows
        # equivalent of `type`?
        if not os.path.isfile(bcdedit):
            bcdedit = join_path(os.environ['systemroot'], 'System32', 'bcdedit.exe')
        if not os.path.isfile(bcdedit):
            log.error("Cannot find bcdedit")
            return
        if registry.get_value('HKEY_LOCAL_MACHINE', self.info.registry_key, 'VistaBootDrive'):
            log.debug("BCD has already been modified")
            return

        command = [bcdedit, '/create', '/d', '%s' % self.info.distro.name, '/application', 'bootsector']
        id = run_command(command)
        id = id[id.index('{'):id.index('}')+1]
        mbr_path = join_path(self.info.target_dir, 'winboot', 'wisildr.mbr')[2:]
        run_command([bcdedit, '/set', id, 'device', 'partition=%s' % self.info.target_drive.path])
        run_command([bcdedit, '/set', id, 'path', mbr_path])
        run_command([bcdedit, '/displayorder', id, '/addlast'])
        run_command([bcdedit, '/timeout', '10'])
        run_command([bcdedit, '/bootsequence', id])
        registry.set_value(
            'HKEY_LOCAL_MACHINE',
            self.info.registry_key,
            'VistaBootDrive',
            id)
예제 #32
0
 def extract_file_from_iso(self, iso_path, file_path, output_dir=None, overwrite=False):
     '''
     platform specific
     '''
     log.debug("  extracting %s from %s" % (file_path, iso_path))
     if not iso_path or not os.path.exists(iso_path):
         raise Exception('Invalid path %s' % iso_path)
     iso_path = abspath(iso_path)
     file_path = os.path.normpath(file_path)
     if not output_dir:
         output_dir = tempfile.gettempdir()
     output_file = join_path(output_dir, os.path.basename(file_path))
     if os.path.exists(output_file):
         if overwrite:
             os.unlink(output_file)
         else:
             raise Exception('Cannot overwrite %s' % output_file)
     command = [self.info.iso_extractor, 'e', '-i!' + file_path, '-o' + output_dir, iso_path]
     try:
         run_command(command)
     except Exception, err:
         log.exception(err)
         output_file = None
예제 #33
0
 def copy_installation_files(self, associated_task):
     self.info.custominstall = join_path(self.info.install_dir, 'custom-installation')
     src = join_path(self.info.data_dir, 'custom-installation')
     dest = self.info.custominstall
     log.debug('Copying %s -> %s' % (src, dest))
     shutil.copytree(src, dest)
     src = join_path(self.info.root_dir, 'winboot')
     if isdir(src): # make runpy will fail otherwise as winboot will not be there
         dest = join_path(self.info.target_dir, 'winboot')
         log.debug('Copying %s -> %s' % (src, dest))
         shutil.copytree(src, dest)
     dest = join_path(self.info.custominstall, 'hooks', 'failure-command.sh')
     msg=_('The installation failed. Logs have been saved in: %s.' \
         '\n\nNote that in verbose mode, the logs may include the password.' \
         '\n\nThe system will now reboot.')
     msg = msg % join_path(self.info.install_dir, 'installation-logs.zip')
     msg = "msg=\"%s\"" % msg
     msg = str(msg.encode('utf8'))
     replace_line_in_file(dest, 'msg=', msg)
     src = join_path(self.info.image_dir, self.info.distro.name + '.ico')
     dest = self.info.icon
     log.debug('Copying %s -> %s' % (src, dest))
     shutil.copyfile(src, dest)
예제 #34
0
 def __init__(self, *args, **kargs):
     Backend.__init__(self, *args, **kargs)
     self.info.iso_extractor = join_path(self.info.bin_dir, '7z.exe')
     self.info.cpuid = join_path(self.info.bin_dir, 'cpuid.dll')
     log.debug('7z=%s' % self.info.iso_extractor)
     self.cache = {}
예제 #35
0
 def create_swap_diskimage(self, associated_task=None):
     path = join_path(self.info.disks_dir, 'swap.disk')
     # fsutil works in bytes.
     swap_size = '%d' % (self.info.swap_size_mb * 1024 * 1024)
     create_cmd = ['fsutil', 'file', 'createnew', path, swap_size]
     run_command(create_cmd)
예제 #36
0
 def create_swap_diskimage(self, associated_task=None):
     path = join_path(self.info.disks_dir, 'swap.disk')
     # fsutil works in bytes.
     swap_size = '%d' % (self.info.swap_size_mb * 1024 * 1024)
     create_cmd = ['fsutil', 'file', 'createnew', path, swap_size]
     run_command(create_cmd)
예제 #37
0
 def expand_diskimage(self, associated_task=None):
     # TODO: might use -p to get percentage to feed into progress.
     root = join_path(self.info.disks_dir, 'root.disk')
     resize2fs = join_path(self.info.bin_dir, 'resize2fs.exe')
     resize_cmd = [resize2fs, '-f', root, '%dM' % self.info.root_size_mb]
     run_command(resize_cmd)
예제 #38
0
 def __init__(self, *args, **kargs):
     Backend.__init__(self, *args, **kargs)
     self.info.iso_extractor = join_path(self.info.bin_dir, '7z.exe')
     self.info.cpuid = join_path(self.info.bin_dir, 'cpuid.dll')
     log.debug('7z=%s' % self.info.iso_extractor)
     self.cache = {}