2019-03-07 08:34:47 +01:00
|
|
|
|
/*
|
2023-03-08 00:30:20 +01:00
|
|
|
|
* Copyright (c) 2023 ETH Zürich, Educational Development and Technology (LET)
|
2019-03-07 08:34:47 +01:00
|
|
|
|
*
|
|
|
|
|
* This Source Code Form is subject to the terms of the Mozilla Public
|
|
|
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
|
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
|
|
|
|
*/
|
|
|
|
|
|
2023-07-03 15:25:31 +02:00
|
|
|
|
using System;
|
2019-03-07 08:34:47 +01:00
|
|
|
|
using System.Collections.Generic;
|
2023-07-03 15:25:31 +02:00
|
|
|
|
using System.Linq;
|
2019-09-06 09:39:28 +02:00
|
|
|
|
using SafeExamBrowser.Settings;
|
2019-12-20 11:37:07 +01:00
|
|
|
|
using SafeExamBrowser.Settings.Security;
|
2019-03-07 08:34:47 +01:00
|
|
|
|
|
2019-12-20 10:03:47 +01:00
|
|
|
|
namespace SafeExamBrowser.Configuration.ConfigurationData.DataMapping
|
2019-03-07 08:34:47 +01:00
|
|
|
|
{
|
2019-12-20 10:03:47 +01:00
|
|
|
|
internal class SecurityDataMapper : BaseDataMapper
|
2019-03-07 08:34:47 +01:00
|
|
|
|
{
|
2019-12-20 10:03:47 +01:00
|
|
|
|
internal override void Map(string key, object value, AppSettings settings)
|
|
|
|
|
{
|
|
|
|
|
switch (key)
|
|
|
|
|
{
|
2020-07-01 13:39:17 +02:00
|
|
|
|
case Keys.Security.AdminPasswordHash:
|
2019-12-20 11:37:07 +01:00
|
|
|
|
MapAdminPasswordHash(settings, value);
|
|
|
|
|
break;
|
2020-09-10 12:35:58 +02:00
|
|
|
|
case Keys.Security.AllowReconfiguration:
|
|
|
|
|
MapAllowReconfiguration(settings, value);
|
|
|
|
|
break;
|
2020-05-04 12:37:54 +02:00
|
|
|
|
case Keys.Security.AllowTermination:
|
|
|
|
|
MapAllowTermination(settings, value);
|
|
|
|
|
break;
|
2019-12-20 10:03:47 +01:00
|
|
|
|
case Keys.Security.AllowVirtualMachine:
|
|
|
|
|
MapVirtualMachinePolicy(settings, value);
|
|
|
|
|
break;
|
2023-08-11 18:24:45 +02:00
|
|
|
|
case Keys.Security.ClipboardPolicy:
|
|
|
|
|
MapClipboardPolicy(settings, value);
|
|
|
|
|
break;
|
2024-01-11 19:01:56 +01:00
|
|
|
|
case Keys.Security.DisableSessionChangeLockScreen:
|
|
|
|
|
MapDisableSessionChangeLockScreen(settings, value);
|
|
|
|
|
break;
|
2019-12-20 10:03:47 +01:00
|
|
|
|
case Keys.Security.QuitPasswordHash:
|
|
|
|
|
MapQuitPasswordHash(settings, value);
|
|
|
|
|
break;
|
2020-09-10 12:35:58 +02:00
|
|
|
|
case Keys.Security.ReconfigurationUrl:
|
|
|
|
|
MapReconfigurationUrl(settings, value);
|
|
|
|
|
break;
|
2024-03-05 16:39:21 +01:00
|
|
|
|
case Keys.Security.VerifyCursorConfiguration:
|
|
|
|
|
MapVerifyCursorConfiguration(settings, value);
|
|
|
|
|
break;
|
2023-07-03 15:25:31 +02:00
|
|
|
|
case Keys.Security.VersionRestrictions:
|
|
|
|
|
MapVersionRestrictions(settings, value);
|
|
|
|
|
break;
|
2019-12-20 10:03:47 +01:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
internal override void MapGlobal(IDictionary<string, object> rawData, AppSettings settings)
|
|
|
|
|
{
|
2019-12-20 11:37:07 +01:00
|
|
|
|
MapApplicationLogAccess(rawData, settings);
|
2019-12-20 10:03:47 +01:00
|
|
|
|
MapKioskMode(rawData, settings);
|
|
|
|
|
}
|
|
|
|
|
|
2019-12-20 11:37:07 +01:00
|
|
|
|
private void MapAdminPasswordHash(AppSettings settings, object value)
|
|
|
|
|
{
|
|
|
|
|
if (value is string hash)
|
|
|
|
|
{
|
|
|
|
|
settings.Security.AdminPasswordHash = hash;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2020-09-10 12:35:58 +02:00
|
|
|
|
private void MapAllowReconfiguration(AppSettings settings, object value)
|
|
|
|
|
{
|
|
|
|
|
if (value is bool allow)
|
|
|
|
|
{
|
|
|
|
|
settings.Security.AllowReconfiguration = allow;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2020-05-04 12:37:54 +02:00
|
|
|
|
private void MapAllowTermination(AppSettings settings, object value)
|
|
|
|
|
{
|
|
|
|
|
if (value is bool allow)
|
|
|
|
|
{
|
|
|
|
|
settings.Security.AllowTermination = allow;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2019-12-20 11:37:07 +01:00
|
|
|
|
private void MapApplicationLogAccess(IDictionary<string, object> rawData, AppSettings settings)
|
|
|
|
|
{
|
2020-02-19 11:53:29 +01:00
|
|
|
|
var hasValue = rawData.TryGetValue(Keys.Security.AllowApplicationLog, out var value);
|
2019-12-20 11:37:07 +01:00
|
|
|
|
|
|
|
|
|
if (hasValue && value is bool allow)
|
|
|
|
|
{
|
|
|
|
|
settings.Security.AllowApplicationLogAccess = allow;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (settings.Security.AllowApplicationLogAccess)
|
|
|
|
|
{
|
|
|
|
|
settings.ActionCenter.ShowApplicationLog = true;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
settings.ActionCenter.ShowApplicationLog = false;
|
|
|
|
|
settings.Taskbar.ShowApplicationLog = false;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2019-10-01 11:30:53 +02:00
|
|
|
|
private void MapKioskMode(IDictionary<string, object> rawData, AppSettings settings)
|
2019-03-07 08:34:47 +01:00
|
|
|
|
{
|
|
|
|
|
var hasCreateNewDesktop = rawData.TryGetValue(Keys.Security.KioskModeCreateNewDesktop, out var createNewDesktop);
|
2019-03-19 12:26:03 +01:00
|
|
|
|
var hasDisableExplorerShell = rawData.TryGetValue(Keys.Security.KioskModeDisableExplorerShell, out var disableExplorerShell);
|
2019-03-07 08:34:47 +01:00
|
|
|
|
|
|
|
|
|
if (hasDisableExplorerShell && disableExplorerShell as bool? == true)
|
|
|
|
|
{
|
2019-12-20 11:37:07 +01:00
|
|
|
|
settings.Security.KioskMode = KioskMode.DisableExplorerShell;
|
2019-03-07 08:34:47 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (hasCreateNewDesktop && createNewDesktop as bool? == true)
|
|
|
|
|
{
|
2019-12-20 11:37:07 +01:00
|
|
|
|
settings.Security.KioskMode = KioskMode.CreateNewDesktop;
|
2019-03-07 08:34:47 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (hasCreateNewDesktop && hasDisableExplorerShell && createNewDesktop as bool? == false && disableExplorerShell as bool? == false)
|
|
|
|
|
{
|
2019-12-20 11:37:07 +01:00
|
|
|
|
settings.Security.KioskMode = KioskMode.None;
|
2019-03-07 08:34:47 +01:00
|
|
|
|
}
|
|
|
|
|
}
|
2019-06-11 09:53:33 +02:00
|
|
|
|
|
2019-12-20 10:03:47 +01:00
|
|
|
|
private void MapQuitPasswordHash(AppSettings settings, object value)
|
|
|
|
|
{
|
|
|
|
|
if (value is string hash)
|
|
|
|
|
{
|
2019-12-20 11:37:07 +01:00
|
|
|
|
settings.Security.QuitPasswordHash = hash;
|
2019-12-20 10:03:47 +01:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2023-08-11 18:24:45 +02:00
|
|
|
|
private void MapClipboardPolicy(AppSettings settings, object value)
|
|
|
|
|
{
|
|
|
|
|
const int ALLOW = 0;
|
|
|
|
|
const int BLOCK = 1;
|
|
|
|
|
|
|
|
|
|
if (value is int policy)
|
|
|
|
|
{
|
|
|
|
|
settings.Security.ClipboardPolicy = policy == ALLOW ? ClipboardPolicy.Allow : (policy == BLOCK ? ClipboardPolicy.Block : ClipboardPolicy.Isolated);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2024-01-11 19:01:56 +01:00
|
|
|
|
private void MapDisableSessionChangeLockScreen(AppSettings settings, object value)
|
|
|
|
|
{
|
|
|
|
|
if (value is bool disable)
|
|
|
|
|
{
|
|
|
|
|
settings.Security.DisableSessionChangeLockScreen = disable;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2019-12-20 10:03:47 +01:00
|
|
|
|
private void MapVirtualMachinePolicy(AppSettings settings, object value)
|
|
|
|
|
{
|
|
|
|
|
if (value is bool allow)
|
|
|
|
|
{
|
2020-05-04 12:37:54 +02:00
|
|
|
|
settings.Security.VirtualMachinePolicy = allow ? VirtualMachinePolicy.Allow : VirtualMachinePolicy.Deny;
|
2019-12-20 10:03:47 +01:00
|
|
|
|
}
|
|
|
|
|
}
|
2020-09-10 12:35:58 +02:00
|
|
|
|
|
|
|
|
|
private void MapReconfigurationUrl(AppSettings settings, object value)
|
|
|
|
|
{
|
|
|
|
|
if (value is string url)
|
|
|
|
|
{
|
|
|
|
|
settings.Security.ReconfigurationUrl = url;
|
|
|
|
|
}
|
|
|
|
|
}
|
2023-07-03 15:25:31 +02:00
|
|
|
|
|
2024-03-05 16:39:21 +01:00
|
|
|
|
private void MapVerifyCursorConfiguration(AppSettings settings, object value)
|
|
|
|
|
{
|
|
|
|
|
if (value is bool verify)
|
|
|
|
|
{
|
|
|
|
|
settings.Security.VerifyCursorConfiguration = verify;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2023-07-03 15:25:31 +02:00
|
|
|
|
private void MapVersionRestrictions(AppSettings settings, object value)
|
|
|
|
|
{
|
|
|
|
|
if (value is IList<object> restrictions)
|
|
|
|
|
{
|
|
|
|
|
foreach (var restriction in restrictions.Cast<string>())
|
|
|
|
|
{
|
|
|
|
|
var parts = restriction.Split('.');
|
|
|
|
|
var os = parts.Length > 0 ? parts[0] : default;
|
|
|
|
|
|
|
|
|
|
if (os?.Equals("win", StringComparison.OrdinalIgnoreCase) == true)
|
|
|
|
|
{
|
|
|
|
|
var major = parts.Length > 1 ? int.Parse(parts[1]) : default;
|
|
|
|
|
var minor = parts.Length > 2 ? int.Parse(parts[2]) : default;
|
|
|
|
|
var patch = parts.Length > 3 && int.TryParse(parts[3], out _) ? int.Parse(parts[3]) : default(int?);
|
|
|
|
|
var build = parts.Length > 4 && int.TryParse(parts[4], out _) ? int.Parse(parts[4]) : default(int?);
|
|
|
|
|
|
|
|
|
|
settings.Security.VersionRestrictions.Add(new VersionRestriction
|
|
|
|
|
{
|
|
|
|
|
Major = major,
|
|
|
|
|
Minor = minor,
|
|
|
|
|
Patch = patch,
|
|
|
|
|
Build = build,
|
|
|
|
|
IsMinimumRestriction = restriction.Contains("min"),
|
|
|
|
|
RequiresAllianceEdition = restriction.Contains("AE")
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2019-03-07 08:34:47 +01:00
|
|
|
|
}
|
|
|
|
|
}
|