2018-01-16 08:14:57 +01:00
|
|
|
|
/*
|
2024-03-05 18:37:42 +01:00
|
|
|
|
* Copyright (c) 2024 ETH Zürich, IT Services
|
2018-01-16 08:14:57 +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/.
|
|
|
|
|
*/
|
|
|
|
|
|
2018-02-12 12:21:55 +01:00
|
|
|
|
using System;
|
2018-01-16 08:14:57 +01:00
|
|
|
|
using System.Collections.Generic;
|
2018-02-16 13:15:16 +01:00
|
|
|
|
using System.Diagnostics;
|
2022-08-17 14:40:41 +02:00
|
|
|
|
using System.Text;
|
2019-11-05 10:08:19 +01:00
|
|
|
|
using SafeExamBrowser.Applications;
|
2018-01-17 08:26:44 +01:00
|
|
|
|
using SafeExamBrowser.Browser;
|
2018-02-12 12:21:55 +01:00
|
|
|
|
using SafeExamBrowser.Client.Communication;
|
2018-02-28 09:45:29 +01:00
|
|
|
|
using SafeExamBrowser.Client.Notifications;
|
2018-08-31 10:06:27 +02:00
|
|
|
|
using SafeExamBrowser.Client.Operations;
|
2019-08-30 09:55:26 +02:00
|
|
|
|
using SafeExamBrowser.Communication.Contracts;
|
|
|
|
|
using SafeExamBrowser.Communication.Contracts.Proxies;
|
2018-08-31 10:06:27 +02:00
|
|
|
|
using SafeExamBrowser.Communication.Hosts;
|
|
|
|
|
using SafeExamBrowser.Communication.Proxies;
|
2019-01-10 10:04:30 +01:00
|
|
|
|
using SafeExamBrowser.Configuration.Cryptography;
|
2022-07-18 21:37:04 +02:00
|
|
|
|
using SafeExamBrowser.Configuration.Integrity;
|
2019-08-30 09:55:26 +02:00
|
|
|
|
using SafeExamBrowser.Core.Contracts.OperationModel;
|
2018-08-31 10:06:27 +02:00
|
|
|
|
using SafeExamBrowser.Core.OperationModel;
|
|
|
|
|
using SafeExamBrowser.Core.Operations;
|
|
|
|
|
using SafeExamBrowser.I18n;
|
2019-08-30 09:55:26 +02:00
|
|
|
|
using SafeExamBrowser.I18n.Contracts;
|
2018-08-31 10:06:27 +02:00
|
|
|
|
using SafeExamBrowser.Logging;
|
2019-08-30 09:55:26 +02:00
|
|
|
|
using SafeExamBrowser.Logging.Contracts;
|
2023-07-21 09:31:59 +02:00
|
|
|
|
using SafeExamBrowser.Monitoring;
|
2019-10-01 11:30:53 +02:00
|
|
|
|
using SafeExamBrowser.Monitoring.Applications;
|
2018-02-12 12:21:55 +01:00
|
|
|
|
using SafeExamBrowser.Monitoring.Display;
|
|
|
|
|
using SafeExamBrowser.Monitoring.Keyboard;
|
|
|
|
|
using SafeExamBrowser.Monitoring.Mouse;
|
2020-06-29 19:29:48 +02:00
|
|
|
|
using SafeExamBrowser.Monitoring.System;
|
2021-02-10 23:21:48 +01:00
|
|
|
|
using SafeExamBrowser.Proctoring;
|
2020-07-28 19:56:25 +02:00
|
|
|
|
using SafeExamBrowser.Server;
|
2019-10-01 11:30:53 +02:00
|
|
|
|
using SafeExamBrowser.Settings.Logging;
|
|
|
|
|
using SafeExamBrowser.Settings.UserInterface;
|
2018-02-12 12:21:55 +01:00
|
|
|
|
using SafeExamBrowser.SystemComponents;
|
2019-08-30 17:33:28 +02:00
|
|
|
|
using SafeExamBrowser.SystemComponents.Audio;
|
2019-08-30 09:55:26 +02:00
|
|
|
|
using SafeExamBrowser.SystemComponents.Contracts;
|
2022-04-19 18:21:29 +02:00
|
|
|
|
using SafeExamBrowser.SystemComponents.Contracts.Network;
|
2020-12-03 19:47:17 +01:00
|
|
|
|
using SafeExamBrowser.SystemComponents.Contracts.PowerSupply;
|
2019-08-30 17:33:28 +02:00
|
|
|
|
using SafeExamBrowser.SystemComponents.Keyboard;
|
2022-04-19 18:21:29 +02:00
|
|
|
|
using SafeExamBrowser.SystemComponents.Network;
|
2019-09-03 11:46:36 +02:00
|
|
|
|
using SafeExamBrowser.SystemComponents.PowerSupply;
|
2022-12-21 05:37:03 +01:00
|
|
|
|
using SafeExamBrowser.SystemComponents.Registry;
|
2019-08-30 09:55:26 +02:00
|
|
|
|
using SafeExamBrowser.UserInterface.Contracts;
|
2020-01-22 15:16:11 +01:00
|
|
|
|
using SafeExamBrowser.UserInterface.Contracts.FileSystemDialog;
|
2019-08-30 09:55:26 +02:00
|
|
|
|
using SafeExamBrowser.UserInterface.Contracts.MessageBox;
|
|
|
|
|
using SafeExamBrowser.UserInterface.Contracts.Shell;
|
2019-11-14 14:03:43 +01:00
|
|
|
|
using SafeExamBrowser.UserInterface.Shared.Activators;
|
2018-01-17 08:26:44 +01:00
|
|
|
|
using SafeExamBrowser.WindowsApi;
|
2019-08-30 09:55:26 +02:00
|
|
|
|
using SafeExamBrowser.WindowsApi.Contracts;
|
2023-10-04 14:48:08 +02:00
|
|
|
|
using SafeExamBrowser.WindowsApi.Processes;
|
2019-03-22 10:09:51 +01:00
|
|
|
|
using Desktop = SafeExamBrowser.UserInterface.Desktop;
|
|
|
|
|
using Mobile = SafeExamBrowser.UserInterface.Mobile;
|
2018-01-16 08:14:57 +01:00
|
|
|
|
|
|
|
|
|
namespace SafeExamBrowser.Client
|
|
|
|
|
{
|
|
|
|
|
internal class CompositionRoot
|
|
|
|
|
{
|
2019-10-09 14:04:27 +02:00
|
|
|
|
private const int TWO_SECONDS = 2000;
|
2019-10-01 16:24:10 +02:00
|
|
|
|
private const int FIVE_SECONDS = 5000;
|
|
|
|
|
|
2019-06-11 09:53:33 +02:00
|
|
|
|
private Guid authenticationToken;
|
2019-10-01 11:30:53 +02:00
|
|
|
|
private ClientContext context;
|
2018-02-16 13:15:16 +01:00
|
|
|
|
private string logFilePath;
|
2019-01-23 08:12:15 +01:00
|
|
|
|
private LogLevel logLevel;
|
2018-02-16 13:15:16 +01:00
|
|
|
|
private string runtimeHostUri;
|
2019-03-21 16:05:16 +01:00
|
|
|
|
private UserInterfaceMode uiMode;
|
2018-02-16 13:15:16 +01:00
|
|
|
|
|
2019-03-06 16:10:00 +01:00
|
|
|
|
private IActionCenter actionCenter;
|
2024-02-13 11:04:36 +01:00
|
|
|
|
private ApplicationMonitor applicationMonitor;
|
2018-01-17 08:26:44 +01:00
|
|
|
|
private ILogger logger;
|
2018-03-14 12:07:20 +01:00
|
|
|
|
private IMessageBox messageBox;
|
2018-01-17 08:26:44 +01:00
|
|
|
|
private INativeMethods nativeMethods;
|
2022-04-19 18:21:29 +02:00
|
|
|
|
private INetworkAdapter networkAdapter;
|
2020-12-03 19:47:17 +01:00
|
|
|
|
private IPowerSupply powerSupply;
|
2018-03-08 15:27:12 +01:00
|
|
|
|
private IRuntimeProxy runtimeProxy;
|
2018-01-17 08:26:44 +01:00
|
|
|
|
private ISystemInfo systemInfo;
|
2019-03-06 16:10:00 +01:00
|
|
|
|
private ITaskbar taskbar;
|
2019-12-06 17:42:46 +01:00
|
|
|
|
private ITaskview taskview;
|
2022-01-14 13:33:35 +01:00
|
|
|
|
private IUserInfo userInfo;
|
2018-01-17 08:26:44 +01:00
|
|
|
|
private IText text;
|
|
|
|
|
private IUserInterfaceFactory uiFactory;
|
2018-01-16 08:14:57 +01:00
|
|
|
|
|
2020-03-16 13:38:25 +01:00
|
|
|
|
internal ClientController ClientController { get; private set; }
|
2018-01-17 08:26:44 +01:00
|
|
|
|
|
2018-02-21 14:01:21 +01:00
|
|
|
|
internal void BuildObjectGraph(Action shutdown)
|
2018-01-16 08:14:57 +01:00
|
|
|
|
{
|
2018-02-16 13:15:16 +01:00
|
|
|
|
ValidateCommandLineArguments();
|
2018-02-12 12:21:55 +01:00
|
|
|
|
|
2018-02-16 13:15:16 +01:00
|
|
|
|
InitializeLogging();
|
2018-08-31 10:06:27 +02:00
|
|
|
|
InitializeText();
|
2018-01-17 08:26:44 +01:00
|
|
|
|
|
2024-02-13 11:04:36 +01:00
|
|
|
|
var processFactory = new ProcessFactory(ModuleLogger(nameof(ProcessFactory)));
|
2023-09-01 12:28:03 +02:00
|
|
|
|
var registry = new Registry(ModuleLogger(nameof(Registry)));
|
2022-01-14 13:33:35 +01:00
|
|
|
|
|
2023-09-01 12:28:03 +02:00
|
|
|
|
uiFactory = BuildUserInterfaceFactory();
|
2020-03-17 11:07:40 +01:00
|
|
|
|
actionCenter = uiFactory.CreateActionCenter();
|
2022-01-14 13:33:35 +01:00
|
|
|
|
context = new ClientContext();
|
2019-03-21 16:05:16 +01:00
|
|
|
|
messageBox = BuildMessageBox();
|
2020-03-09 17:35:48 +01:00
|
|
|
|
nativeMethods = new NativeMethods();
|
2024-02-13 11:04:36 +01:00
|
|
|
|
applicationMonitor = new ApplicationMonitor(TWO_SECONDS, ModuleLogger(nameof(ApplicationMonitor)), nativeMethods, processFactory);
|
2022-04-19 18:21:29 +02:00
|
|
|
|
networkAdapter = new NetworkAdapter(ModuleLogger(nameof(NetworkAdapter)), nativeMethods);
|
2019-10-04 16:36:12 +02:00
|
|
|
|
runtimeProxy = new RuntimeProxy(runtimeHostUri, new ProxyObjectFactory(), ModuleLogger(nameof(RuntimeProxy)), Interlocutor.Client);
|
2023-09-01 12:28:03 +02:00
|
|
|
|
systemInfo = new SystemInfo(registry);
|
2020-03-17 11:07:40 +01:00
|
|
|
|
taskbar = uiFactory.CreateTaskbar(ModuleLogger("Taskbar"));
|
|
|
|
|
taskview = uiFactory.CreateTaskview();
|
2022-01-14 13:33:35 +01:00
|
|
|
|
userInfo = new UserInfo(ModuleLogger(nameof(UserInfo)));
|
2018-02-12 12:21:55 +01:00
|
|
|
|
|
2023-06-01 18:18:01 +02:00
|
|
|
|
var applicationFactory = new ApplicationFactory(applicationMonitor, ModuleLogger(nameof(ApplicationFactory)), nativeMethods, processFactory, new Registry(ModuleLogger(nameof(Registry))));
|
2023-07-21 09:31:59 +02:00
|
|
|
|
var clipboard = new Clipboard(ModuleLogger(nameof(Clipboard)), nativeMethods);
|
2019-10-04 16:36:12 +02:00
|
|
|
|
var displayMonitor = new DisplayMonitor(ModuleLogger(nameof(DisplayMonitor)), nativeMethods, systemInfo);
|
|
|
|
|
var explorerShell = new ExplorerShell(ModuleLogger(nameof(ExplorerShell)), nativeMethods);
|
2020-01-22 16:08:57 +01:00
|
|
|
|
var fileSystemDialog = BuildFileSystemDialog();
|
2019-01-10 10:04:30 +01:00
|
|
|
|
var hashAlgorithm = new HashAlgorithm();
|
2020-02-14 14:43:08 +01:00
|
|
|
|
var splashScreen = uiFactory.CreateSplashScreen();
|
2020-06-29 19:29:48 +02:00
|
|
|
|
var systemMonitor = new SystemMonitor(ModuleLogger(nameof(SystemMonitor)));
|
2018-02-12 12:21:55 +01:00
|
|
|
|
|
|
|
|
|
var operations = new Queue<IOperation>();
|
|
|
|
|
|
2020-03-09 17:35:48 +01:00
|
|
|
|
operations.Enqueue(new I18nOperation(logger, text));
|
2019-10-01 16:24:10 +02:00
|
|
|
|
operations.Enqueue(new RuntimeConnectionOperation(context, logger, runtimeProxy, authenticationToken));
|
|
|
|
|
operations.Enqueue(new ConfigurationOperation(context, logger, runtimeProxy));
|
2018-08-10 13:23:24 +02:00
|
|
|
|
operations.Enqueue(new DelegateOperation(UpdateAppConfig));
|
2022-11-24 14:50:25 +01:00
|
|
|
|
operations.Enqueue(new DelegateOperation(BuildIntegrityModule));
|
2024-01-11 17:35:52 +01:00
|
|
|
|
operations.Enqueue(new DelegateOperation(BuildPowerSupply));
|
2018-09-28 11:05:49 +02:00
|
|
|
|
operations.Enqueue(new LazyInitializationOperation(BuildClientHostOperation));
|
2019-10-01 16:24:10 +02:00
|
|
|
|
operations.Enqueue(new ClientHostDisconnectionOperation(context, logger, FIVE_SECONDS));
|
2018-09-25 12:10:34 +02:00
|
|
|
|
operations.Enqueue(new LazyInitializationOperation(BuildKeyboardInterceptorOperation));
|
2019-03-06 16:10:00 +01:00
|
|
|
|
operations.Enqueue(new LazyInitializationOperation(BuildMouseInterceptorOperation));
|
2019-11-05 10:08:19 +01:00
|
|
|
|
operations.Enqueue(new ApplicationOperation(context, applicationFactory, applicationMonitor, logger, text));
|
2019-10-01 16:24:10 +02:00
|
|
|
|
operations.Enqueue(new DisplayMonitorOperation(context, displayMonitor, logger, taskbar));
|
2020-06-29 19:29:48 +02:00
|
|
|
|
operations.Enqueue(new SystemMonitorOperation(context, systemMonitor, logger));
|
2019-03-08 15:56:38 +01:00
|
|
|
|
operations.Enqueue(new LazyInitializationOperation(BuildShellOperation));
|
2018-09-25 12:10:34 +02:00
|
|
|
|
operations.Enqueue(new LazyInitializationOperation(BuildBrowserOperation));
|
2020-07-28 19:56:25 +02:00
|
|
|
|
operations.Enqueue(new LazyInitializationOperation(BuildServerOperation));
|
2021-02-10 23:21:48 +01:00
|
|
|
|
operations.Enqueue(new LazyInitializationOperation(BuildProctoringOperation));
|
2023-07-21 09:31:59 +02:00
|
|
|
|
operations.Enqueue(new ClipboardOperation(context, clipboard, logger));
|
2018-02-12 12:21:55 +01:00
|
|
|
|
|
|
|
|
|
var sequence = new OperationSequence(logger, operations);
|
|
|
|
|
|
2019-03-06 16:10:00 +01:00
|
|
|
|
ClientController = new ClientController(
|
|
|
|
|
actionCenter,
|
2019-10-01 11:30:53 +02:00
|
|
|
|
applicationMonitor,
|
2019-10-01 16:24:10 +02:00
|
|
|
|
context,
|
2019-03-06 16:10:00 +01:00
|
|
|
|
displayMonitor,
|
|
|
|
|
explorerShell,
|
2020-01-22 16:08:57 +01:00
|
|
|
|
fileSystemDialog,
|
2019-03-06 16:10:00 +01:00
|
|
|
|
hashAlgorithm,
|
|
|
|
|
logger,
|
|
|
|
|
messageBox,
|
2024-05-02 10:30:26 +02:00
|
|
|
|
networkAdapter,
|
2019-03-06 16:10:00 +01:00
|
|
|
|
sequence,
|
2022-12-21 05:37:03 +01:00
|
|
|
|
registry,
|
2019-03-06 16:10:00 +01:00
|
|
|
|
runtimeProxy,
|
|
|
|
|
shutdown,
|
2020-02-14 14:43:08 +01:00
|
|
|
|
splashScreen,
|
2020-06-29 19:29:48 +02:00
|
|
|
|
systemMonitor,
|
2019-03-06 16:10:00 +01:00
|
|
|
|
taskbar,
|
|
|
|
|
text,
|
2019-10-01 11:30:53 +02:00
|
|
|
|
uiFactory);
|
2018-02-12 12:21:55 +01:00
|
|
|
|
}
|
|
|
|
|
|
2018-02-16 13:15:16 +01:00
|
|
|
|
internal void LogStartupInformation()
|
|
|
|
|
{
|
2022-04-19 18:21:29 +02:00
|
|
|
|
logger.Log($"# New client instance started at {DateTime.Now:yyyy-MM-dd HH:mm:ss.fff}");
|
2018-02-16 13:15:16 +01:00
|
|
|
|
logger.Log(string.Empty);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
internal void LogShutdownInformation()
|
2018-02-12 12:21:55 +01:00
|
|
|
|
{
|
2022-04-19 18:21:29 +02:00
|
|
|
|
logger?.Log($"# Client instance terminated at {DateTime.Now:yyyy-MM-dd HH:mm:ss.fff}");
|
2018-02-16 13:15:16 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void ValidateCommandLineArguments()
|
|
|
|
|
{
|
|
|
|
|
var args = Environment.GetCommandLineArgs();
|
2019-03-21 16:05:16 +01:00
|
|
|
|
var hasFive = args?.Length >= 5;
|
2022-08-17 14:40:41 +02:00
|
|
|
|
var valid = false;
|
2018-02-12 12:21:55 +01:00
|
|
|
|
|
2019-01-23 08:12:15 +01:00
|
|
|
|
if (hasFive)
|
2018-02-12 12:21:55 +01:00
|
|
|
|
{
|
2022-08-17 14:40:41 +02:00
|
|
|
|
var logFilePath = Encoding.UTF8.GetString(Convert.FromBase64String(args[1]));
|
|
|
|
|
var hasLogFilePath = Uri.TryCreate(logFilePath, UriKind.Absolute, out var filePath) && filePath.IsFile;
|
|
|
|
|
var hasLogLevel = Enum.TryParse(args[2], out LogLevel logLevel);
|
|
|
|
|
var hasHostUri = Uri.TryCreate(args[3], UriKind.Absolute, out var runtimeHostUri) && runtimeHostUri.IsWellFormedOriginalString();
|
|
|
|
|
var hasAuthenticationToken = Guid.TryParse(args[4], out var authenticationToken);
|
2018-02-12 12:21:55 +01:00
|
|
|
|
|
2022-08-17 14:40:41 +02:00
|
|
|
|
if (hasLogFilePath && hasLogLevel && hasHostUri && hasAuthenticationToken)
|
2018-02-12 12:21:55 +01:00
|
|
|
|
{
|
2022-08-17 14:40:41 +02:00
|
|
|
|
this.authenticationToken = authenticationToken;
|
|
|
|
|
this.logFilePath = logFilePath;
|
|
|
|
|
this.logLevel = logLevel;
|
|
|
|
|
this.runtimeHostUri = args[3];
|
|
|
|
|
this.uiMode = args.Length == 6 && Enum.TryParse(args[5], out uiMode) ? uiMode : UserInterfaceMode.Desktop;
|
2018-02-16 13:15:16 +01:00
|
|
|
|
|
2022-08-17 14:40:41 +02:00
|
|
|
|
valid = true;
|
2018-02-12 12:21:55 +01:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2022-08-17 14:40:41 +02:00
|
|
|
|
if (!valid)
|
|
|
|
|
{
|
|
|
|
|
throw new ArgumentException("Invalid arguments! Required: SafeExamBrowser.Client.exe <logfile path> <log level> <host URI> <token>");
|
|
|
|
|
}
|
2018-02-12 12:21:55 +01:00
|
|
|
|
}
|
|
|
|
|
|
2018-02-16 13:15:16 +01:00
|
|
|
|
private void InitializeLogging()
|
2018-02-12 12:21:55 +01:00
|
|
|
|
{
|
2018-02-16 13:15:16 +01:00
|
|
|
|
var logFileWriter = new LogFileWriter(new DefaultLogFormatter(), logFilePath);
|
2018-02-12 12:21:55 +01:00
|
|
|
|
|
|
|
|
|
logFileWriter.Initialize();
|
2020-03-09 17:35:48 +01:00
|
|
|
|
|
|
|
|
|
logger = new Logger();
|
2019-01-23 08:12:15 +01:00
|
|
|
|
logger.LogLevel = logLevel;
|
2018-02-12 12:21:55 +01:00
|
|
|
|
logger.Subscribe(logFileWriter);
|
|
|
|
|
}
|
|
|
|
|
|
2018-08-31 10:06:27 +02:00
|
|
|
|
private void InitializeText()
|
|
|
|
|
{
|
2020-03-09 17:35:48 +01:00
|
|
|
|
text = new Text(ModuleLogger(nameof(Text)));
|
2018-08-31 10:06:27 +02:00
|
|
|
|
}
|
|
|
|
|
|
2018-02-12 12:21:55 +01:00
|
|
|
|
private IOperation BuildBrowserOperation()
|
|
|
|
|
{
|
2020-01-22 15:16:11 +01:00
|
|
|
|
var fileSystemDialog = BuildFileSystemDialog();
|
2023-03-02 23:48:11 +01:00
|
|
|
|
var keyGenerator = new KeyGenerator(context.AppConfig, context.IntegrityModule, ModuleLogger(nameof(KeyGenerator)));
|
2019-10-04 16:36:12 +02:00
|
|
|
|
var moduleLogger = ModuleLogger(nameof(BrowserApplication));
|
2021-10-18 12:06:10 +02:00
|
|
|
|
var browser = new BrowserApplication(
|
|
|
|
|
context.AppConfig,
|
|
|
|
|
context.Settings.Browser,
|
|
|
|
|
fileSystemDialog,
|
|
|
|
|
new HashAlgorithm(),
|
|
|
|
|
keyGenerator,
|
|
|
|
|
messageBox,
|
|
|
|
|
moduleLogger,
|
2023-03-08 00:01:20 +01:00
|
|
|
|
nativeMethods,
|
|
|
|
|
context.Settings.SessionMode,
|
2021-10-18 12:06:10 +02:00
|
|
|
|
text,
|
|
|
|
|
uiFactory);
|
2019-12-05 11:54:43 +01:00
|
|
|
|
var operation = new BrowserOperation(actionCenter, context, logger, taskbar, taskview, uiFactory);
|
2018-02-12 12:21:55 +01:00
|
|
|
|
|
2019-10-01 16:24:10 +02:00
|
|
|
|
context.Browser = browser;
|
2018-06-21 07:56:25 +02:00
|
|
|
|
|
2018-02-12 12:21:55 +01:00
|
|
|
|
return operation;
|
|
|
|
|
}
|
|
|
|
|
|
2018-09-28 11:05:49 +02:00
|
|
|
|
private IOperation BuildClientHostOperation()
|
2018-02-12 12:21:55 +01:00
|
|
|
|
{
|
2018-02-16 13:15:16 +01:00
|
|
|
|
var processId = Process.GetCurrentProcess().Id;
|
2018-03-16 15:46:53 +01:00
|
|
|
|
var factory = new HostObjectFactory();
|
2019-10-04 16:36:12 +02:00
|
|
|
|
var clientHost = new ClientHost(context.AppConfig.ClientAddress, factory, ModuleLogger(nameof(ClientHost)), processId, FIVE_SECONDS);
|
2019-10-01 16:24:10 +02:00
|
|
|
|
var operation = new CommunicationHostOperation(clientHost, logger);
|
2018-02-12 12:21:55 +01:00
|
|
|
|
|
2019-10-01 16:24:10 +02:00
|
|
|
|
context.ClientHost = clientHost;
|
|
|
|
|
context.ClientHost.AuthenticationToken = authenticationToken;
|
2018-09-28 11:05:49 +02:00
|
|
|
|
|
|
|
|
|
return operation;
|
|
|
|
|
}
|
|
|
|
|
|
2022-11-24 14:50:25 +01:00
|
|
|
|
private void BuildIntegrityModule()
|
|
|
|
|
{
|
|
|
|
|
context.IntegrityModule = new IntegrityModule(context.AppConfig, ModuleLogger(nameof(IntegrityModule)));
|
|
|
|
|
}
|
|
|
|
|
|
2024-01-11 17:35:52 +01:00
|
|
|
|
private void BuildPowerSupply()
|
|
|
|
|
{
|
|
|
|
|
powerSupply = new PowerSupply(ModuleLogger(nameof(PowerSupply)), context.Settings.PowerSupply);
|
|
|
|
|
}
|
|
|
|
|
|
2018-02-12 12:21:55 +01:00
|
|
|
|
private IOperation BuildKeyboardInterceptorOperation()
|
|
|
|
|
{
|
2019-10-04 16:36:12 +02:00
|
|
|
|
var keyboardInterceptor = new KeyboardInterceptor(ModuleLogger(nameof(KeyboardInterceptor)), nativeMethods, context.Settings.Keyboard);
|
2019-10-01 16:24:10 +02:00
|
|
|
|
var operation = new KeyboardInterceptorOperation(context, keyboardInterceptor, logger);
|
2018-02-12 12:21:55 +01:00
|
|
|
|
|
|
|
|
|
return operation;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private IOperation BuildMouseInterceptorOperation()
|
|
|
|
|
{
|
2019-10-04 16:36:12 +02:00
|
|
|
|
var mouseInterceptor = new MouseInterceptor(ModuleLogger(nameof(MouseInterceptor)), nativeMethods, context.Settings.Mouse);
|
2019-10-01 16:24:10 +02:00
|
|
|
|
var operation = new MouseInterceptorOperation(context, logger, mouseInterceptor);
|
2018-02-12 12:21:55 +01:00
|
|
|
|
|
|
|
|
|
return operation;
|
2018-01-17 08:26:44 +01:00
|
|
|
|
}
|
|
|
|
|
|
2021-02-10 23:21:48 +01:00
|
|
|
|
private IOperation BuildProctoringOperation()
|
|
|
|
|
{
|
2024-02-13 11:04:36 +01:00
|
|
|
|
var controller = new ProctoringController(
|
|
|
|
|
context.AppConfig,
|
|
|
|
|
applicationMonitor,
|
|
|
|
|
context.Browser,
|
|
|
|
|
new FileSystem(),
|
|
|
|
|
ModuleLogger(nameof(ProctoringController)),
|
|
|
|
|
nativeMethods,
|
|
|
|
|
context.Server,
|
|
|
|
|
text,
|
|
|
|
|
uiFactory);
|
2024-01-18 18:02:21 +01:00
|
|
|
|
var operation = new ProctoringOperation(actionCenter, context, controller, logger, taskbar, uiFactory);
|
2021-02-10 23:21:48 +01:00
|
|
|
|
|
2024-02-29 21:05:43 +01:00
|
|
|
|
context.Proctoring = controller;
|
|
|
|
|
|
2021-02-10 23:21:48 +01:00
|
|
|
|
return operation;
|
|
|
|
|
}
|
|
|
|
|
|
2020-07-28 19:56:25 +02:00
|
|
|
|
private IOperation BuildServerOperation()
|
|
|
|
|
{
|
2023-03-02 23:48:11 +01:00
|
|
|
|
var keyGenerator = new KeyGenerator(context.AppConfig, context.IntegrityModule, ModuleLogger(nameof(KeyGenerator)));
|
|
|
|
|
var server = new ServerProxy(context.AppConfig, keyGenerator, ModuleLogger(nameof(ServerProxy)), systemInfo, userInfo, powerSupply, networkAdapter);
|
2021-07-22 14:21:06 +02:00
|
|
|
|
var operation = new ServerOperation(context, logger, server);
|
2020-07-28 19:56:25 +02:00
|
|
|
|
|
2020-07-29 23:39:05 +02:00
|
|
|
|
context.Server = server;
|
|
|
|
|
|
2020-07-28 19:56:25 +02:00
|
|
|
|
return operation;
|
|
|
|
|
}
|
|
|
|
|
|
2019-03-08 15:56:38 +01:00
|
|
|
|
private IOperation BuildShellOperation()
|
2018-01-17 08:26:44 +01:00
|
|
|
|
{
|
2021-03-18 23:12:07 +01:00
|
|
|
|
var aboutNotification = new AboutNotification(context.AppConfig, text, uiFactory);
|
2019-10-04 16:36:12 +02:00
|
|
|
|
var audio = new Audio(context.Settings.Audio, ModuleLogger(nameof(Audio)));
|
|
|
|
|
var keyboard = new Keyboard(ModuleLogger(nameof(Keyboard)));
|
2021-03-18 23:12:07 +01:00
|
|
|
|
var logNotification = new LogNotification(logger, text, uiFactory);
|
2019-03-08 15:56:38 +01:00
|
|
|
|
var operation = new ShellOperation(
|
|
|
|
|
actionCenter,
|
2019-08-30 17:33:28 +02:00
|
|
|
|
audio,
|
2021-03-18 23:12:07 +01:00
|
|
|
|
aboutNotification,
|
2019-10-01 16:24:10 +02:00
|
|
|
|
context,
|
2019-08-30 15:59:51 +02:00
|
|
|
|
keyboard,
|
2019-09-04 14:11:19 +02:00
|
|
|
|
logger,
|
2021-03-18 23:12:07 +01:00
|
|
|
|
logNotification,
|
2024-01-11 12:02:01 +01:00
|
|
|
|
nativeMethods,
|
2022-04-19 18:21:29 +02:00
|
|
|
|
networkAdapter,
|
2019-09-03 11:46:36 +02:00
|
|
|
|
powerSupply,
|
2019-03-06 16:10:00 +01:00
|
|
|
|
systemInfo,
|
|
|
|
|
taskbar,
|
2019-12-05 11:54:43 +01:00
|
|
|
|
taskview,
|
2019-03-15 11:38:59 +01:00
|
|
|
|
text,
|
2022-04-19 18:21:29 +02:00
|
|
|
|
uiFactory);
|
2018-01-17 14:08:39 +01:00
|
|
|
|
|
2019-11-14 14:03:43 +01:00
|
|
|
|
context.Activators.Add(new ActionCenterKeyboardActivator(ModuleLogger(nameof(ActionCenterKeyboardActivator)), nativeMethods));
|
|
|
|
|
context.Activators.Add(new ActionCenterTouchActivator(ModuleLogger(nameof(ActionCenterTouchActivator)), nativeMethods));
|
2022-05-06 15:52:37 +02:00
|
|
|
|
context.Activators.Add(new TaskbarKeyboardActivator(ModuleLogger(nameof(TaskbarKeyboardActivator)), nativeMethods));
|
2019-12-06 17:42:46 +01:00
|
|
|
|
context.Activators.Add(new TaskviewKeyboardActivator(ModuleLogger(nameof(TaskviewKeyboardActivator)), nativeMethods));
|
2019-11-14 14:03:43 +01:00
|
|
|
|
context.Activators.Add(new TerminationActivator(ModuleLogger(nameof(TerminationActivator)), nativeMethods));
|
2019-10-11 15:46:15 +02:00
|
|
|
|
|
2018-02-12 12:21:55 +01:00
|
|
|
|
return operation;
|
2018-01-16 08:14:57 +01:00
|
|
|
|
}
|
2018-02-21 14:01:21 +01:00
|
|
|
|
|
2020-01-22 15:16:11 +01:00
|
|
|
|
private IFileSystemDialog BuildFileSystemDialog()
|
|
|
|
|
{
|
|
|
|
|
switch (uiMode)
|
|
|
|
|
{
|
|
|
|
|
case UserInterfaceMode.Mobile:
|
2023-09-01 12:28:03 +02:00
|
|
|
|
return new Mobile.FileSystemDialogFactory(systemInfo, text);
|
2020-01-22 15:16:11 +01:00
|
|
|
|
default:
|
2023-09-01 12:28:03 +02:00
|
|
|
|
return new Desktop.FileSystemDialogFactory(systemInfo, text);
|
2020-01-22 15:16:11 +01:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2019-03-21 16:05:16 +01:00
|
|
|
|
private IMessageBox BuildMessageBox()
|
|
|
|
|
{
|
|
|
|
|
switch (uiMode)
|
|
|
|
|
{
|
|
|
|
|
case UserInterfaceMode.Mobile:
|
2020-03-17 11:07:40 +01:00
|
|
|
|
return new Mobile.MessageBoxFactory(text);
|
2019-11-14 14:03:43 +01:00
|
|
|
|
default:
|
2020-03-17 11:07:40 +01:00
|
|
|
|
return new Desktop.MessageBoxFactory(text);
|
2019-11-14 14:03:43 +01:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2019-03-21 16:05:16 +01:00
|
|
|
|
private IUserInterfaceFactory BuildUserInterfaceFactory()
|
|
|
|
|
{
|
|
|
|
|
switch (uiMode)
|
|
|
|
|
{
|
|
|
|
|
case UserInterfaceMode.Mobile:
|
2019-03-22 10:09:51 +01:00
|
|
|
|
return new Mobile.UserInterfaceFactory(text);
|
2019-03-21 16:05:16 +01:00
|
|
|
|
default:
|
2019-03-22 10:09:51 +01:00
|
|
|
|
return new Desktop.UserInterfaceFactory(text);
|
2019-03-21 16:05:16 +01:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2018-08-10 13:23:24 +02:00
|
|
|
|
private void UpdateAppConfig()
|
2018-02-21 14:01:21 +01:00
|
|
|
|
{
|
2019-10-01 16:24:10 +02:00
|
|
|
|
ClientController.UpdateAppConfig();
|
2018-02-21 14:01:21 +01:00
|
|
|
|
}
|
2019-10-04 16:36:12 +02:00
|
|
|
|
|
|
|
|
|
private IModuleLogger ModuleLogger(string moduleInfo)
|
|
|
|
|
{
|
|
|
|
|
return new ModuleLogger(logger, moduleInfo);
|
|
|
|
|
}
|
2018-01-16 08:14:57 +01:00
|
|
|
|
}
|
|
|
|
|
}
|