Ejemplo n.º 1
0
        /// <summary>
        ///     Extracts an a VHDX file
        /// </summary>
        /// <param name="fileEntry"> </param>
        /// <returns> </returns>
        public IEnumerable <FileEntry> Extract(FileEntry fileEntry, ExtractorOptions options, ResourceGovernor governor)
        {
            using var disk = new DiscUtils.Vhdx.Disk(fileEntry.Content, Ownership.None);
            LogicalVolumeInfo[]? logicalVolumes = null;

            try
            {
                var manager = new VolumeManager(disk);
                logicalVolumes = manager.GetLogicalVolumes();
            }
            catch (Exception e)
            {
                Logger.Debug("Error reading {0} disk at {1} ({2}:{3})", disk.GetType(), fileEntry.FullPath, e.GetType(), e.Message);
            }

            if (logicalVolumes != null)
            {
                foreach (var volume in logicalVolumes)
                {
                    var fsInfos = FileSystemManager.DetectFileSystems(volume);

                    foreach (var entry in DiscCommon.DumpLogicalVolume(volume, fileEntry.FullPath, options, governor, Context, fileEntry))
                    {
                        yield return(entry);
                    }
                }
            }
            else
            {
                if (options.ExtractSelfOnFail)
                {
                    yield return(fileEntry);
                }
            }
        }
Ejemplo n.º 2
0
        /// <summary>
        ///     Extracts an a VHDX file
        /// </summary>
        /// <param name="fileEntry"> </param>
        /// <returns> </returns>
        public IEnumerable <FileEntry> Extract(FileEntry fileEntry, IList <Regex> allow, IList <Regex> deny)
        {
            using (var disk = new DiscUtils.Vhdx.Disk(fileEntry.Content, Ownership.None))
            {
                LogicalVolumeInfo[] logicalVolumes = null;

                try
                {
                    var manager = new VolumeManager(disk);
                    logicalVolumes = manager.GetLogicalVolumes();
                }
                catch (Exception e)
                {
                    Logger.Debug("Error reading {0} disk at {1} ({2}:{3})", disk.GetType(), fileEntry.FullPath, e.GetType(), e.Message);
                }

                if (logicalVolumes != null)
                {
                    foreach (var volume in logicalVolumes)
                    {
                        var fsInfos = FileSystemManager.DetectFileSystems(volume);

                        foreach (var entry in DumpLogicalVolume(volume, fileEntry.FullPath, fileEntry))
                        {
                            if (Utility.FileNamePasses(entry.Name, allow, deny))
                            {
                                yield return(entry);
                            }
                        }
                    }
                }
            }
        }