/// <summary> /// Returns the default collection of registry rules. /// </summary> /// <returns></returns> public static RegistryRuleCollection GetDefaultRuleCollection() { var rules = new RegistryRuleCollection(); rules.PopulateWithDefaultRules(); return(rules); }
/// <summary> /// Initializes a new instance of <see cref="ProcessSynchronizer"/>. /// The constructor will create default databases from the specified files. /// </summary> /// <param name="fileSystemRoot">The directory to use as root of the file system.</param> /// <param name="fileSystemRuleCollection">The collection of engine rules to apply on the file system virtualization engine.</param> /// <param name="registryDatabaseFile">The file to use with a default <see cref="RegistryDatabase"/>.</param> /// <param name="registryRuleCollection">The collection of engine rules to apply on the registry virtualization engine.</param> public ProcessSynchronizer(ApplicationFile fileSystemRoot, FileSystemRuleCollection fileSystemRuleCollection, ApplicationFile registryDatabaseFile, RegistryRuleCollection registryRuleCollection) { if (fileSystemRoot.Type != FileType.Directory) throw new ArgumentException("The root location specified for the file system is not valid.", "fileSystemRoot"); if (registryDatabaseFile.Type != FileType.Database) throw new ArgumentException("The filename specified for the registry database is not valid.", "registryDatabaseFile"); _connectionStrings = new Dictionary<ConfigurationDataType, string>(2) { {ConfigurationDataType.RegistryDatabaseFile, registryDatabaseFile.FileName}, {ConfigurationDataType.FileSystemRoot, fileSystemRoot.FileName} }; _fsRuleCollection = fileSystemRuleCollection; _regRuleCollection = registryRuleCollection; }
/// <summary> /// Returns the default collection of registry rules. /// </summary> /// <returns></returns> public static RegistryRuleCollection GetDefaultRuleCollection() { var rules = new RegistryRuleCollection(); rules.PopulateWithDefaultRules(); return rules; }
/// <summary> /// Initializes a new instance of <see cref="RegistrySwitch"/>. /// </summary> /// <param name="indexGenerator">The <see cref="IndexGenerator"/> to use for generating virtual key handles.</param> /// <param name="knownKeys">A list of all known virtual registry keys.</param> /// <param name="ruleCollection">The collection of engine rules to consider when deciding on a target registry.</param> public RegistrySwitch(IndexGenerator indexGenerator, IDictionary<uint, VirtualRegistryKey> knownKeys, RegistryRuleCollection ruleCollection) { _transparentRegistry = new TransparentRegistry(indexGenerator); _virtualRegistry = new VirtualRegistry(indexGenerator, knownKeys); _engineRules = ruleCollection; }
/// <summary> /// Initializes a new instance of <see cref="VirtualProcessStartInfo"/> /// based on the <see cref="ApplicationData"/> specified. /// </summary> /// <exception cref="ArgumentNullException"> /// An <see cref="ArgumentNullException"/> is thrown if <paramref name="data"/> of one of its properties is null. /// </exception> /// <exception cref="ArgumentException"> /// An <see cref="ArgumentException"/> is thrown if any of the properties of <paramref name="data"/> is of the wrong type. /// </exception> /// <param name="data">The data to base the process on.</param> /// <param name="workingDirectory">The working directory of the process to start.</param> public VirtualProcessStartInfo(ApplicationData data, ApplicationFile workingDirectory) { if (data == null || data.Files.RegistryDatabase == null || data.Files.Executable == null || data.Files.RootDirectory == null) throw new ArgumentNullException("data", "The data argument or one of its properties is null."); if (workingDirectory == null) throw new ArgumentNullException("workingDirectory", "The workingDirectory argument is null."); if (data.Files.Executable.Type != FileType.Executable) throw new ArgumentException("The ApplicationData specified contains an illegal value for the main executable.", "data"); if (data.Files.RegistryDatabase.Type != FileType.Database) throw new ArgumentException( "The ApplicationData specified contains an illegal value for the registry database.", "data"); if (workingDirectory.Type != FileType.Directory) throw new ArgumentException("The working directory specified is not a directory.", "workingDirectory"); _files = new ApplicationFiles { RegistryDatabase = new ApplicationFile(Path.Combine(workingDirectory.FileName, data.Files.RegistryDatabase.FileName)), Executable = new ApplicationFile(Path.Combine(workingDirectory.FileName, data.Files.Executable.FileName)), RootDirectory = new ApplicationFile(Path.Combine(workingDirectory.FileName, data.Files.RootDirectory.FileName)) }; _arguments = ""; _workingDirectory = workingDirectory; _fileSystemRuleCollection = data.Settings.FileSystemEngineRuleCollection ?? FileSystemRuleCollection.GetDefaultRuleCollection(); _registryRuleCollection = data.Settings.RegistryEngineRuleCollection ?? RegistryRuleCollection.GetDefaultRuleCollection(); }