2020-07-28 19:56:25 +02:00
|
|
|
|
/*
|
2022-01-21 16:33:52 +01:00
|
|
|
|
* Copyright (c) 2022 ETH Zürich, Educational Development and Technology (LET)
|
2020-07-28 19:56:25 +02: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/.
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
using SafeExamBrowser.Core.Contracts.OperationModel;
|
|
|
|
|
using SafeExamBrowser.Core.Contracts.OperationModel.Events;
|
|
|
|
|
using SafeExamBrowser.I18n.Contracts;
|
|
|
|
|
using SafeExamBrowser.Logging.Contracts;
|
|
|
|
|
using SafeExamBrowser.Server.Contracts;
|
|
|
|
|
using SafeExamBrowser.Settings;
|
|
|
|
|
|
|
|
|
|
namespace SafeExamBrowser.Client.Operations
|
|
|
|
|
{
|
|
|
|
|
internal class ServerOperation : ClientOperation
|
|
|
|
|
{
|
|
|
|
|
private readonly ILogger logger;
|
|
|
|
|
private readonly IServerProxy server;
|
|
|
|
|
|
|
|
|
|
public override event ActionRequiredEventHandler ActionRequired { add { } remove { } }
|
|
|
|
|
public override event StatusChangedEventHandler StatusChanged;
|
|
|
|
|
|
2021-07-22 14:21:06 +02:00
|
|
|
|
public ServerOperation(ClientContext context, ILogger logger, IServerProxy server) : base(context)
|
2020-07-28 19:56:25 +02:00
|
|
|
|
{
|
|
|
|
|
this.logger = logger;
|
|
|
|
|
this.server = server;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public override OperationResult Perform()
|
|
|
|
|
{
|
|
|
|
|
if (Context.Settings.SessionMode == SessionMode.Server)
|
|
|
|
|
{
|
|
|
|
|
logger.Info("Initializing server...");
|
|
|
|
|
StatusChanged?.Invoke(TextKey.OperationStatus_InitializeServer);
|
|
|
|
|
|
2020-07-29 23:39:05 +02:00
|
|
|
|
server.Initialize(
|
|
|
|
|
Context.AppConfig.ServerApi,
|
|
|
|
|
Context.AppConfig.ServerConnectionToken,
|
|
|
|
|
Context.AppConfig.ServerExamId,
|
|
|
|
|
Context.AppConfig.ServerOauth2Token,
|
|
|
|
|
Context.Settings.Server);
|
2021-06-21 11:18:15 +02:00
|
|
|
|
server.StartConnectivity();
|
2020-07-28 19:56:25 +02:00
|
|
|
|
}
|
|
|
|
|
|
2020-12-02 17:43:02 +01:00
|
|
|
|
return OperationResult.Success;
|
2020-07-28 19:56:25 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public override OperationResult Revert()
|
|
|
|
|
{
|
|
|
|
|
if (Context.Settings?.SessionMode == SessionMode.Server)
|
|
|
|
|
{
|
|
|
|
|
logger.Info("Finalizing server...");
|
|
|
|
|
StatusChanged?.Invoke(TextKey.OperationStatus_FinalizeServer);
|
|
|
|
|
|
2020-07-31 13:24:42 +02:00
|
|
|
|
server.StopConnectivity();
|
2020-07-28 19:56:25 +02:00
|
|
|
|
}
|
|
|
|
|
|
2020-12-02 17:43:02 +01:00
|
|
|
|
return OperationResult.Success;
|
2020-07-28 19:56:25 +02:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|