From e33a12e7ec5060d7391dea84bcd736a6b9c44980 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Damian=20B=C3=BCchel?= Date: Tue, 2 May 2023 14:56:15 +0200 Subject: [PATCH] SEBWIN-703, #604: Fixed false-positive VM detection due to virtual disk devices. --- .../VirtualMachineDetector.cs | 15 +++++++++++---- 1 file changed, 11 insertions(+), 4 deletions(-) diff --git a/SafeExamBrowser.SystemComponents/VirtualMachineDetector.cs b/SafeExamBrowser.SystemComponents/VirtualMachineDetector.cs index 17d99b9b..c2506ab9 100644 --- a/SafeExamBrowser.SystemComponents/VirtualMachineDetector.cs +++ b/SafeExamBrowser.SystemComponents/VirtualMachineDetector.cs @@ -14,7 +14,10 @@ namespace SafeExamBrowser.SystemComponents { public class VirtualMachineDetector : IVirtualMachineDetector { - private static readonly string[] DEVICE_BLACKLIST = + private const string QEMU_MAC_PREFIX = "525400"; + private const string VIRTUALBOX_MAC_PREFIX = "080027"; + + private static readonly string[] DeviceBlacklist = { // Hyper-V "PROD_VIRTUAL", "HYPER_V", @@ -25,8 +28,12 @@ namespace SafeExamBrowser.SystemComponents // VMware "PROD_VMWARE", "VEN_VMWARE", "VMWARE_IDE" }; - private static readonly string QEMU_MAC_PREFIX = "525400"; - private static readonly string VIRTUALBOX_MAC_PREFIX = "080027"; + + private static readonly string[] DeviceWhitelist = + { + // Microsoft Virtual Disk + "PROD_VIRTUAL_DISK" + }; private readonly ILogger logger; private readonly ISystemInfo systemInfo; @@ -62,7 +69,7 @@ namespace SafeExamBrowser.SystemComponents foreach (var device in devices) { - isVirtualMachine |= DEVICE_BLACKLIST.Any(d => device.ToLower().Contains(d.ToLower())); + isVirtualMachine |= DeviceBlacklist.Any(d => device.ToLower().Contains(d.ToLower())) && DeviceWhitelist.All(d => !device.ToLower().Contains(d.ToLower())); } logger.Debug($"Computer '{systemInfo.Name}' appears {(isVirtualMachine ? "" : "not ")}to be a virtual machine.");