SEBWIN-301: Defined settings for service component.
This commit is contained in:
parent
4087db9097
commit
1c7c856c33
12 changed files with 183 additions and 14 deletions
|
@ -41,7 +41,7 @@ namespace SafeExamBrowser.Configuration.ConfigurationData
|
||||||
|
|
||||||
if (value is int policy)
|
if (value is int policy)
|
||||||
{
|
{
|
||||||
settings.ServicePolicy = policy == FORCE ? ServicePolicy.Mandatory : (policy == WARN ? ServicePolicy.Warn : ServicePolicy.Optional);
|
settings.Service.Policy = policy == FORCE ? ServicePolicy.Mandatory : (policy == WARN ? ServicePolicy.Warn : ServicePolicy.Optional);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -147,7 +147,19 @@ namespace SafeExamBrowser.Configuration.ConfigurationData
|
||||||
settings.Mouse.AllowMiddleButton = false;
|
settings.Mouse.AllowMiddleButton = false;
|
||||||
settings.Mouse.AllowRightButton = true;
|
settings.Mouse.AllowRightButton = true;
|
||||||
|
|
||||||
settings.ServicePolicy = ServicePolicy.Mandatory;
|
settings.Service.AllowEaseOfAccessOptions = false;
|
||||||
|
settings.Service.AllowNetworkOptions = false;
|
||||||
|
settings.Service.AllowPasswordChange = false;
|
||||||
|
settings.Service.AllowPowerOptions = false;
|
||||||
|
settings.Service.AllowSignout = false;
|
||||||
|
settings.Service.AllowTaskManager = false;
|
||||||
|
settings.Service.AllowUserLock = false;
|
||||||
|
settings.Service.AllowUserSwitch = false;
|
||||||
|
settings.Service.DisableChromeNotifications = true;
|
||||||
|
settings.Service.DisableRemoteConnections = true;
|
||||||
|
settings.Service.DisableVmwareOverlay = true;
|
||||||
|
settings.Service.DisableWindowsUpdate = true;
|
||||||
|
settings.Service.Policy = ServicePolicy.Mandatory;
|
||||||
|
|
||||||
settings.AllowApplicationLogAccess = false;
|
settings.AllowApplicationLogAccess = false;
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,81 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2019 ETH Zürich, Educational Development and Technology (LET)
|
||||||
|
*
|
||||||
|
* 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/.
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace SafeExamBrowser.Contracts.Configuration.Settings
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// Defines all configuration options for the service application component.
|
||||||
|
/// </summary>
|
||||||
|
public class ServiceSettings
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// Determines whether the user may access the ease of access options on the security screen.
|
||||||
|
/// </summary>
|
||||||
|
public bool AllowEaseOfAccessOptions { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Determines whether the user may access the network options on the security screen.
|
||||||
|
/// </summary>
|
||||||
|
public bool AllowNetworkOptions { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Determines whether the user may change the password for a user account via the security screen.
|
||||||
|
/// </summary>
|
||||||
|
public bool AllowPasswordChange { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Determines whether the user may access the power options on the security screen.
|
||||||
|
/// </summary>
|
||||||
|
public bool AllowPowerOptions { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Determines whether the user may sign out of their account via the security screen.
|
||||||
|
/// </summary>
|
||||||
|
public bool AllowSignout { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Determines whether the user may start the task manager via the security screen.
|
||||||
|
/// </summary>
|
||||||
|
public bool AllowTaskManager { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Determines whether the user may lock the computer via the security screen.
|
||||||
|
/// </summary>
|
||||||
|
public bool AllowUserLock { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Determines whether the user may switch to another user account via the security screen.
|
||||||
|
/// </summary>
|
||||||
|
public bool AllowUserSwitch { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Determines whether desktop notifications of Google Chrome should be deactivated.
|
||||||
|
/// </summary>
|
||||||
|
public bool DisableChromeNotifications { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Determines whether remote desktop connections should be deactivated.
|
||||||
|
/// </summary>
|
||||||
|
public bool DisableRemoteConnections { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Determines whether the user interface overlay for VMware clients should be deactivated.
|
||||||
|
/// </summary>
|
||||||
|
public bool DisableVmwareOverlay { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Determines whether Windows Update should be deactivated.
|
||||||
|
/// </summary>
|
||||||
|
public bool DisableWindowsUpdate { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// The active policy for the service component.
|
||||||
|
/// </summary>
|
||||||
|
public ServicePolicy Policy { get; set; }
|
||||||
|
}
|
||||||
|
}
|
|
@ -68,9 +68,9 @@ namespace SafeExamBrowser.Contracts.Configuration.Settings
|
||||||
public string QuitPasswordHash { get; set; }
|
public string QuitPasswordHash { get; set; }
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// The active policy for the service component.
|
/// All service-related settings.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public ServicePolicy ServicePolicy { get; set; }
|
public ServiceSettings Service { get; set; }
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// All taskbar-related settings.
|
/// All taskbar-related settings.
|
||||||
|
@ -78,7 +78,7 @@ namespace SafeExamBrowser.Contracts.Configuration.Settings
|
||||||
public TaskbarSettings Taskbar { get; set; }
|
public TaskbarSettings Taskbar { get; set; }
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// The mode which determines the look & feel of the user interface.
|
/// The mode which determines the look & feel of the user interface.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public UserInterfaceMode UserInterfaceMode { get; set; }
|
public UserInterfaceMode UserInterfaceMode { get; set; }
|
||||||
|
|
||||||
|
@ -88,6 +88,7 @@ namespace SafeExamBrowser.Contracts.Configuration.Settings
|
||||||
Browser = new BrowserSettings();
|
Browser = new BrowserSettings();
|
||||||
Keyboard = new KeyboardSettings();
|
Keyboard = new KeyboardSettings();
|
||||||
Mouse = new MouseSettings();
|
Mouse = new MouseSettings();
|
||||||
|
Service = new ServiceSettings();
|
||||||
Taskbar = new TaskbarSettings();
|
Taskbar = new TaskbarSettings();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -9,7 +9,7 @@
|
||||||
namespace SafeExamBrowser.Contracts.Configuration.Settings
|
namespace SafeExamBrowser.Contracts.Configuration.Settings
|
||||||
{
|
{
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Defines all possible look & feel options for the application.
|
/// Defines all possible look & feel options for the application.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public enum UserInterfaceMode
|
public enum UserInterfaceMode
|
||||||
{
|
{
|
||||||
|
|
|
@ -85,6 +85,7 @@
|
||||||
<Compile Include="Configuration\ServiceConfiguration.cs" />
|
<Compile Include="Configuration\ServiceConfiguration.cs" />
|
||||||
<Compile Include="Configuration\Settings\ActionCenterSettings.cs" />
|
<Compile Include="Configuration\Settings\ActionCenterSettings.cs" />
|
||||||
<Compile Include="Configuration\Settings\BrowserWindowSettings.cs" />
|
<Compile Include="Configuration\Settings\BrowserWindowSettings.cs" />
|
||||||
|
<Compile Include="Configuration\Settings\ServiceSettings.cs" />
|
||||||
<Compile Include="Configuration\Settings\UserInterfaceMode.cs" />
|
<Compile Include="Configuration\Settings\UserInterfaceMode.cs" />
|
||||||
<Compile Include="Applications\Events\IconChangedEventHandler.cs" />
|
<Compile Include="Applications\Events\IconChangedEventHandler.cs" />
|
||||||
<Compile Include="Applications\Events\InstanceTerminatedEventHandler.cs" />
|
<Compile Include="Applications\Events\InstanceTerminatedEventHandler.cs" />
|
||||||
|
|
|
@ -55,7 +55,7 @@ namespace SafeExamBrowser.Runtime.UnitTests.Operations
|
||||||
sessionContext.Next = session;
|
sessionContext.Next = session;
|
||||||
sessionContext.Next.AppConfig = appConfig;
|
sessionContext.Next.AppConfig = appConfig;
|
||||||
session.Settings = settings;
|
session.Settings = settings;
|
||||||
settings.ServicePolicy = ServicePolicy.Mandatory;
|
settings.Service.Policy = ServicePolicy.Mandatory;
|
||||||
|
|
||||||
sut = new ServiceOperation(logger.Object, runtimeHost.Object, service.Object, sessionContext, 0);
|
sut = new ServiceOperation(logger.Object, runtimeHost.Object, service.Object, sessionContext, 0);
|
||||||
}
|
}
|
||||||
|
@ -64,12 +64,12 @@ namespace SafeExamBrowser.Runtime.UnitTests.Operations
|
||||||
public void Perform_MustConnectToService()
|
public void Perform_MustConnectToService()
|
||||||
{
|
{
|
||||||
service.Setup(s => s.Connect(null, true)).Returns(true);
|
service.Setup(s => s.Connect(null, true)).Returns(true);
|
||||||
settings.ServicePolicy = ServicePolicy.Mandatory;
|
settings.Service.Policy = ServicePolicy.Mandatory;
|
||||||
|
|
||||||
sut.Perform();
|
sut.Perform();
|
||||||
|
|
||||||
service.Setup(s => s.Connect(null, true)).Returns(true);
|
service.Setup(s => s.Connect(null, true)).Returns(true);
|
||||||
settings.ServicePolicy = ServicePolicy.Optional;
|
settings.Service.Policy = ServicePolicy.Optional;
|
||||||
|
|
||||||
sut.Perform();
|
sut.Perform();
|
||||||
|
|
||||||
|
@ -160,7 +160,7 @@ namespace SafeExamBrowser.Runtime.UnitTests.Operations
|
||||||
|
|
||||||
service.SetupGet(s => s.IsConnected).Returns(false);
|
service.SetupGet(s => s.IsConnected).Returns(false);
|
||||||
service.Setup(s => s.Connect(null, true)).Returns(false);
|
service.Setup(s => s.Connect(null, true)).Returns(false);
|
||||||
settings.ServicePolicy = ServicePolicy.Mandatory;
|
settings.Service.Policy = ServicePolicy.Mandatory;
|
||||||
sut.ActionRequired += (args) => errorShown = args is MessageEventArgs m && m.Icon == MessageBoxIcon.Error;
|
sut.ActionRequired += (args) => errorShown = args is MessageEventArgs m && m.Icon == MessageBoxIcon.Error;
|
||||||
|
|
||||||
var result = sut.Perform();
|
var result = sut.Perform();
|
||||||
|
@ -174,7 +174,7 @@ namespace SafeExamBrowser.Runtime.UnitTests.Operations
|
||||||
{
|
{
|
||||||
service.SetupGet(s => s.IsConnected).Returns(false);
|
service.SetupGet(s => s.IsConnected).Returns(false);
|
||||||
service.Setup(s => s.Connect(null, true)).Returns(false);
|
service.Setup(s => s.Connect(null, true)).Returns(false);
|
||||||
settings.ServicePolicy = ServicePolicy.Optional;
|
settings.Service.Policy = ServicePolicy.Optional;
|
||||||
|
|
||||||
var result = sut.Perform();
|
var result = sut.Perform();
|
||||||
|
|
||||||
|
@ -189,7 +189,7 @@ namespace SafeExamBrowser.Runtime.UnitTests.Operations
|
||||||
|
|
||||||
service.SetupGet(s => s.IsConnected).Returns(false);
|
service.SetupGet(s => s.IsConnected).Returns(false);
|
||||||
service.Setup(s => s.Connect(null, true)).Returns(false);
|
service.Setup(s => s.Connect(null, true)).Returns(false);
|
||||||
settings.ServicePolicy = ServicePolicy.Warn;
|
settings.Service.Policy = ServicePolicy.Warn;
|
||||||
sut.ActionRequired += (args) => warningShown = args is MessageEventArgs m && m.Icon == MessageBoxIcon.Warning;
|
sut.ActionRequired += (args) => warningShown = args is MessageEventArgs m && m.Icon == MessageBoxIcon.Warning;
|
||||||
|
|
||||||
var result = sut.Perform();
|
var result = sut.Perform();
|
||||||
|
|
|
@ -106,8 +106,8 @@ namespace SafeExamBrowser.Runtime.Operations
|
||||||
|
|
||||||
private bool TryEstablishConnection()
|
private bool TryEstablishConnection()
|
||||||
{
|
{
|
||||||
var mandatory = Context.Next.Settings.ServicePolicy == ServicePolicy.Mandatory;
|
var mandatory = Context.Next.Settings.Service.Policy == ServicePolicy.Mandatory;
|
||||||
var warn = Context.Next.Settings.ServicePolicy == ServicePolicy.Warn;
|
var warn = Context.Next.Settings.Service.Policy == ServicePolicy.Warn;
|
||||||
var connected = service.Connect();
|
var connected = service.Connect();
|
||||||
var success = connected || !mandatory;
|
var success = connected || !mandatory;
|
||||||
|
|
||||||
|
|
|
@ -45,10 +45,12 @@ namespace SafeExamBrowser.Service
|
||||||
var bootstrapOperations = new Queue<IOperation>();
|
var bootstrapOperations = new Queue<IOperation>();
|
||||||
var sessionOperations = new Queue<IOperation>();
|
var sessionOperations = new Queue<IOperation>();
|
||||||
|
|
||||||
|
bootstrapOperations.Enqueue(new RestoreOperation(logger));
|
||||||
bootstrapOperations.Enqueue(new CommunicationHostOperation(serviceHost, logger));
|
bootstrapOperations.Enqueue(new CommunicationHostOperation(serviceHost, logger));
|
||||||
bootstrapOperations.Enqueue(new ServiceEventCleanupOperation(logger, sessionContext));
|
bootstrapOperations.Enqueue(new ServiceEventCleanupOperation(logger, sessionContext));
|
||||||
|
|
||||||
sessionOperations.Enqueue(new SessionInitializationOperation(logger, LogWriterFactory, ServiceEventFactory, serviceHost, sessionContext));
|
sessionOperations.Enqueue(new SessionInitializationOperation(logger, LogWriterFactory, ServiceEventFactory, serviceHost, sessionContext));
|
||||||
|
sessionOperations.Enqueue(new LockdownOperation(logger, sessionContext));
|
||||||
sessionOperations.Enqueue(new SessionActivationOperation(logger, sessionContext));
|
sessionOperations.Enqueue(new SessionActivationOperation(logger, sessionContext));
|
||||||
|
|
||||||
var bootstrapSequence = new OperationSequence(logger, bootstrapOperations);
|
var bootstrapSequence = new OperationSequence(logger, bootstrapOperations);
|
||||||
|
|
33
SafeExamBrowser.Service/Operations/LockdownOperation.cs
Normal file
33
SafeExamBrowser.Service/Operations/LockdownOperation.cs
Normal file
|
@ -0,0 +1,33 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2019 ETH Zürich, Educational Development and Technology (LET)
|
||||||
|
*
|
||||||
|
* 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/.
|
||||||
|
*/
|
||||||
|
|
||||||
|
using SafeExamBrowser.Contracts.Core.OperationModel;
|
||||||
|
using SafeExamBrowser.Contracts.Logging;
|
||||||
|
|
||||||
|
namespace SafeExamBrowser.Service.Operations
|
||||||
|
{
|
||||||
|
internal class LockdownOperation : SessionOperation
|
||||||
|
{
|
||||||
|
private readonly ILogger logger;
|
||||||
|
|
||||||
|
public LockdownOperation(ILogger logger, SessionContext sessionContext) : base(sessionContext)
|
||||||
|
{
|
||||||
|
this.logger = logger;
|
||||||
|
}
|
||||||
|
|
||||||
|
public override OperationResult Perform()
|
||||||
|
{
|
||||||
|
return OperationResult.Success;
|
||||||
|
}
|
||||||
|
|
||||||
|
public override OperationResult Revert()
|
||||||
|
{
|
||||||
|
return OperationResult.Success;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
37
SafeExamBrowser.Service/Operations/RestoreOperation.cs
Normal file
37
SafeExamBrowser.Service/Operations/RestoreOperation.cs
Normal file
|
@ -0,0 +1,37 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2019 ETH Zürich, Educational Development and Technology (LET)
|
||||||
|
*
|
||||||
|
* 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/.
|
||||||
|
*/
|
||||||
|
|
||||||
|
using SafeExamBrowser.Contracts.Core.OperationModel;
|
||||||
|
using SafeExamBrowser.Contracts.Core.OperationModel.Events;
|
||||||
|
using SafeExamBrowser.Contracts.Logging;
|
||||||
|
|
||||||
|
namespace SafeExamBrowser.Service.Operations
|
||||||
|
{
|
||||||
|
internal class RestoreOperation : IOperation
|
||||||
|
{
|
||||||
|
private readonly ILogger logger;
|
||||||
|
|
||||||
|
public event ActionRequiredEventHandler ActionRequired { add { } remove { } }
|
||||||
|
public event StatusChangedEventHandler StatusChanged { add { } remove { } }
|
||||||
|
|
||||||
|
public RestoreOperation(ILogger logger)
|
||||||
|
{
|
||||||
|
this.logger = logger;
|
||||||
|
}
|
||||||
|
|
||||||
|
public OperationResult Perform()
|
||||||
|
{
|
||||||
|
return OperationResult.Success;
|
||||||
|
}
|
||||||
|
|
||||||
|
public OperationResult Revert()
|
||||||
|
{
|
||||||
|
return OperationResult.Success;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -64,6 +64,8 @@
|
||||||
<Compile Include="Installer.cs">
|
<Compile Include="Installer.cs">
|
||||||
<SubType>Component</SubType>
|
<SubType>Component</SubType>
|
||||||
</Compile>
|
</Compile>
|
||||||
|
<Compile Include="Operations\LockdownOperation.cs" />
|
||||||
|
<Compile Include="Operations\RestoreOperation.cs" />
|
||||||
<Compile Include="Operations\ServiceEventCleanupOperation.cs" />
|
<Compile Include="Operations\ServiceEventCleanupOperation.cs" />
|
||||||
<Compile Include="Operations\SessionActivationOperation.cs" />
|
<Compile Include="Operations\SessionActivationOperation.cs" />
|
||||||
<Compile Include="Operations\SessionInitializationOperation.cs" />
|
<Compile Include="Operations\SessionInitializationOperation.cs" />
|
||||||
|
|
Loading…
Reference in a new issue