added mac check, added WMI checks, and in progress registry check
This commit is contained in:
parent
b5008f9163
commit
71b722d215
1 changed files with 66 additions and 9 deletions
|
@ -6,9 +6,13 @@
|
||||||
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
using System;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
|
using System.Management;
|
||||||
|
using System.Runtime.InteropServices;
|
||||||
using SafeExamBrowser.Logging.Contracts;
|
using SafeExamBrowser.Logging.Contracts;
|
||||||
using SafeExamBrowser.SystemComponents.Contracts;
|
using SafeExamBrowser.SystemComponents.Contracts;
|
||||||
|
using Microsoft.Win32;
|
||||||
|
|
||||||
namespace SafeExamBrowser.SystemComponents
|
namespace SafeExamBrowser.SystemComponents
|
||||||
{
|
{
|
||||||
|
@ -36,28 +40,80 @@ namespace SafeExamBrowser.SystemComponents
|
||||||
this.logger = logger;
|
this.logger = logger;
|
||||||
this.systemInfo = systemInfo;
|
this.systemInfo = systemInfo;
|
||||||
}
|
}
|
||||||
|
private bool IsVirtualSystemInfo(string biosInfo, string manufacturer, string model)
|
||||||
public bool IsVirtualMachine()
|
|
||||||
{
|
{
|
||||||
var biosInfo = systemInfo.BiosInfo.ToLower();
|
bool isVirtualMachine = false;
|
||||||
var isVirtualMachine = false;
|
|
||||||
var macAddress = systemInfo.MacAddress;
|
biosInfo = biosInfo.ToLower();
|
||||||
var manufacturer = systemInfo.Manufacturer.ToLower();
|
manufacturer = manufacturer.ToLower();
|
||||||
var model = systemInfo.Model.ToLower();
|
model = model.ToLower();
|
||||||
var devices = systemInfo.PlugAndPlayDeviceIds;
|
|
||||||
|
|
||||||
isVirtualMachine |= biosInfo.Contains("hyper-v");
|
isVirtualMachine |= biosInfo.Contains("hyper-v");
|
||||||
isVirtualMachine |= biosInfo.Contains("virtualbox");
|
isVirtualMachine |= biosInfo.Contains("virtualbox");
|
||||||
isVirtualMachine |= biosInfo.Contains("vmware");
|
isVirtualMachine |= biosInfo.Contains("vmware");
|
||||||
|
isVirtualMachine |= biosInfo.Contains("ovmf");
|
||||||
|
isVirtualMachine |= biosInfo.Contains("edk ii unknown"); // qemu
|
||||||
isVirtualMachine |= manufacturer.Contains("microsoft corporation") && !model.Contains("surface");
|
isVirtualMachine |= manufacturer.Contains("microsoft corporation") && !model.Contains("surface");
|
||||||
isVirtualMachine |= manufacturer.Contains("parallels software");
|
isVirtualMachine |= manufacturer.Contains("parallels software");
|
||||||
isVirtualMachine |= manufacturer.Contains("qemu");
|
isVirtualMachine |= manufacturer.Contains("qemu");
|
||||||
isVirtualMachine |= manufacturer.Contains("vmware");
|
isVirtualMachine |= manufacturer.Contains("vmware");
|
||||||
isVirtualMachine |= model.Contains("virtualbox");
|
isVirtualMachine |= model.Contains("virtualbox");
|
||||||
|
isVirtualMachine |= model.Contains("Q35 +");
|
||||||
|
|
||||||
|
return isVirtualMachine;
|
||||||
|
}
|
||||||
|
|
||||||
|
private bool IsVirtualRegistry()
|
||||||
|
{
|
||||||
|
bool isVirtualMachine = false;
|
||||||
|
|
||||||
|
RegistryKey hardwareConfig = Microsoft.Win32.Registry.LocalMachine.OpenSubKey("SYSTEM\\HardwareConfig");
|
||||||
|
|
||||||
|
foreach (string childKeyName in hardwareConfig.GetSubKeyNames())
|
||||||
|
{
|
||||||
|
RegistryKey childKey = Microsoft.Win32.Registry.LocalMachine.OpenSubKey($"SYSTEM\\HardwareConfig\\{childKeyName}");
|
||||||
|
childKey.GetValue("");
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
return isVirtualMachine;
|
||||||
|
}
|
||||||
|
|
||||||
|
private bool IsVirtualWmi()
|
||||||
|
{
|
||||||
|
bool isVirtualMachine = false;
|
||||||
|
|
||||||
|
ManagementObjectSearcher searcherCpu = new ManagementObjectSearcher("SELECT * FROM Win32_Processor");
|
||||||
|
|
||||||
|
// edge case where no CPU is detected?
|
||||||
|
foreach (ManagementObject obj in searcherCpu.Get())
|
||||||
|
{
|
||||||
|
isVirtualMachine |= ((string) obj["Name"]).ToLower().Contains(" kvm "); // qemu
|
||||||
|
}
|
||||||
|
|
||||||
|
return isVirtualMachine;
|
||||||
|
}
|
||||||
|
|
||||||
|
public bool IsVirtualMachine()
|
||||||
|
{
|
||||||
|
var biosInfo = systemInfo.BiosInfo;
|
||||||
|
var isVirtualMachine = false;
|
||||||
|
var macAddress = systemInfo.MacAddress;
|
||||||
|
var manufacturer = systemInfo.Manufacturer;
|
||||||
|
var model = systemInfo.Model;
|
||||||
|
var devices = systemInfo.PlugAndPlayDeviceIds;
|
||||||
|
|
||||||
|
isVirtualMachine |= IsVirtualSystemInfo(biosInfo, manufacturer, model);
|
||||||
|
isVirtualMachine |= IsVirtualWmi();
|
||||||
|
isVirtualMachine |= IsVirtualRegistry();
|
||||||
|
|
||||||
|
// TODO: system version
|
||||||
|
|
||||||
if (macAddress != null && macAddress.Count() > 2)
|
if (macAddress != null && macAddress.Count() > 2)
|
||||||
{
|
{
|
||||||
isVirtualMachine |= macAddress.StartsWith(QEMU_MAC_PREFIX) || macAddress.StartsWith(VIRTUALBOX_MAC_PREFIX);
|
isVirtualMachine |= macAddress.StartsWith(QEMU_MAC_PREFIX);
|
||||||
|
isVirtualMachine |= macAddress.StartsWith(VIRTUALBOX_MAC_PREFIX);
|
||||||
|
isVirtualMachine |= macAddress.StartsWith("000000000000"); // indicates tampering
|
||||||
}
|
}
|
||||||
|
|
||||||
foreach (var device in devices)
|
foreach (var device in devices)
|
||||||
|
@ -65,6 +121,7 @@ namespace SafeExamBrowser.SystemComponents
|
||||||
isVirtualMachine |= DEVICE_BLACKLIST.Any(d => device.ToLower().Contains(d.ToLower()));
|
isVirtualMachine |= DEVICE_BLACKLIST.Any(d => device.ToLower().Contains(d.ToLower()));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
logger.Debug($"Computer '{systemInfo.Name}' appears {(isVirtualMachine ? "" : "not ")}to be a virtual machine.");
|
logger.Debug($"Computer '{systemInfo.Name}' appears {(isVirtualMachine ? "" : "not ")}to be a virtual machine.");
|
||||||
|
|
||||||
return isVirtualMachine;
|
return isVirtualMachine;
|
||||||
|
|
Loading…
Add table
Reference in a new issue