2020-07-13 22:57:19 +02:00
|
|
|
|
/*
|
2023-03-08 00:30:20 +01:00
|
|
|
|
* Copyright (c) 2023 ETH Zürich, Educational Development and Technology (LET)
|
2020-07-13 22:57:19 +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 System;
|
|
|
|
|
using System.Collections.Generic;
|
2020-07-28 19:56:25 +02:00
|
|
|
|
using SafeExamBrowser.Server.Contracts.Data;
|
2020-08-01 17:55:18 +02:00
|
|
|
|
using SafeExamBrowser.Server.Contracts.Events;
|
2024-02-01 17:36:11 +01:00
|
|
|
|
using SafeExamBrowser.Server.Contracts.Events.Proctoring;
|
2020-07-13 22:57:19 +02:00
|
|
|
|
using SafeExamBrowser.Settings.Server;
|
|
|
|
|
|
|
|
|
|
namespace SafeExamBrowser.Server.Contracts
|
|
|
|
|
{
|
|
|
|
|
/// <summary>
|
2020-07-22 18:11:51 +02:00
|
|
|
|
/// Defines the communication options with a server.
|
2020-07-13 22:57:19 +02:00
|
|
|
|
/// </summary>
|
|
|
|
|
public interface IServerProxy
|
|
|
|
|
{
|
2021-04-12 10:59:31 +02:00
|
|
|
|
/// <summary>
|
2021-09-17 10:47:02 +02:00
|
|
|
|
/// Event fired when the proxy receives a confirmation for a raise hand notification.
|
|
|
|
|
/// </summary>
|
|
|
|
|
event ServerEventHandler HandConfirmed;
|
|
|
|
|
|
2022-08-31 14:11:19 +02:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Event fired when the proxy receives a confirmation for a lock screen notification.
|
|
|
|
|
/// </summary>
|
|
|
|
|
event ServerEventHandler LockScreenConfirmed;
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
2022-09-02 14:56:49 +02:00
|
|
|
|
/// Event fired when the proxy receives a lock screen instruction.
|
2022-08-31 14:11:19 +02:00
|
|
|
|
/// </summary>
|
|
|
|
|
event LockScreenRequestedEventHandler LockScreenRequested;
|
|
|
|
|
|
2021-09-17 10:47:02 +02:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Event fired when the proxy receives new proctoring configuration values.
|
2021-04-12 10:59:31 +02:00
|
|
|
|
/// </summary>
|
|
|
|
|
event ProctoringConfigurationReceivedEventHandler ProctoringConfigurationReceived;
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
2021-09-17 10:47:02 +02:00
|
|
|
|
/// Event fired when the proxy receives a proctoring instruction.
|
2021-04-12 10:59:31 +02:00
|
|
|
|
/// </summary>
|
|
|
|
|
event ProctoringInstructionReceivedEventHandler ProctoringInstructionReceived;
|
|
|
|
|
|
2020-08-01 17:55:18 +02:00
|
|
|
|
/// <summary>
|
2021-09-17 10:47:02 +02:00
|
|
|
|
/// Event fired when the proxy detects an instruction to terminate SEB.
|
2020-08-01 17:55:18 +02:00
|
|
|
|
/// </summary>
|
2022-09-02 14:56:49 +02:00
|
|
|
|
event TerminationRequestedEventHandler TerminationRequested;
|
2020-08-01 17:55:18 +02:00
|
|
|
|
|
2020-07-13 22:57:19 +02:00
|
|
|
|
/// <summary>
|
2023-02-24 21:33:26 +01:00
|
|
|
|
/// Sends a lock screen confirm notification to the server.
|
2020-07-13 22:57:19 +02:00
|
|
|
|
/// </summary>
|
2023-02-24 21:33:26 +01:00
|
|
|
|
ServerResponse ConfirmLockScreen();
|
2020-07-13 22:57:19 +02:00
|
|
|
|
|
2022-09-02 14:56:49 +02:00
|
|
|
|
/// <summary>
|
2023-02-24 21:33:26 +01:00
|
|
|
|
/// Attempts to initialize a connection with the server.
|
2022-09-02 14:56:49 +02:00
|
|
|
|
/// </summary>
|
2023-02-24 21:33:26 +01:00
|
|
|
|
ServerResponse Connect();
|
2022-09-02 14:56:49 +02:00
|
|
|
|
|
2020-07-13 22:57:19 +02:00
|
|
|
|
/// <summary>
|
2020-07-31 13:24:42 +02:00
|
|
|
|
/// Terminates a connection with the server.
|
2020-07-13 22:57:19 +02:00
|
|
|
|
/// </summary>
|
|
|
|
|
ServerResponse Disconnect();
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
2020-11-30 18:30:29 +01:00
|
|
|
|
/// Retrieves a list of all currently available exams, or a list containing the specified exam.
|
2020-07-13 22:57:19 +02:00
|
|
|
|
/// </summary>
|
2022-09-02 14:56:49 +02:00
|
|
|
|
ServerResponse<IEnumerable<Exam>> GetAvailableExams(string examId = default);
|
2020-07-13 22:57:19 +02:00
|
|
|
|
|
|
|
|
|
/// <summary>
|
2020-07-28 19:56:25 +02:00
|
|
|
|
/// Retrieves the URI of the configuration file for the given exam.
|
2020-07-13 22:57:19 +02:00
|
|
|
|
/// </summary>
|
|
|
|
|
ServerResponse<Uri> GetConfigurationFor(Exam exam);
|
|
|
|
|
|
2020-07-28 19:56:25 +02:00
|
|
|
|
/// <summary>
|
2020-07-31 13:24:42 +02:00
|
|
|
|
/// Retrieves the information required to establish a connection with the server.
|
2020-07-28 19:56:25 +02:00
|
|
|
|
/// </summary>
|
|
|
|
|
ConnectionInfo GetConnectionInfo();
|
|
|
|
|
|
2020-07-22 18:11:51 +02:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Initializes the server settings to be used for communication.
|
|
|
|
|
/// </summary>
|
|
|
|
|
void Initialize(ServerSettings settings);
|
|
|
|
|
|
2020-07-13 22:57:19 +02:00
|
|
|
|
/// <summary>
|
2020-07-28 19:56:25 +02:00
|
|
|
|
/// Initializes the configuration and server settings to be used for communication.
|
|
|
|
|
/// </summary>
|
2020-07-29 23:39:05 +02:00
|
|
|
|
void Initialize(string api, string connectionToken, string examId, string oauth2Token, ServerSettings settings);
|
2020-07-28 19:56:25 +02:00
|
|
|
|
|
2021-09-17 10:47:02 +02:00
|
|
|
|
/// <summary>
|
2022-09-02 14:56:49 +02:00
|
|
|
|
/// Sends a lock screen notification to the server.
|
2021-09-17 10:47:02 +02:00
|
|
|
|
/// </summary>
|
2022-09-02 14:56:49 +02:00
|
|
|
|
ServerResponse LockScreen(string message = default);
|
2021-09-17 10:47:02 +02:00
|
|
|
|
|
2022-08-31 14:11:19 +02:00
|
|
|
|
/// <summary>
|
2022-09-02 14:56:49 +02:00
|
|
|
|
/// Sends a lower hand notification to the server.
|
2022-08-31 14:11:19 +02:00
|
|
|
|
/// </summary>
|
2022-09-02 14:56:49 +02:00
|
|
|
|
ServerResponse LowerHand();
|
2022-08-31 14:11:19 +02:00
|
|
|
|
|
2023-02-24 21:33:26 +01:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Sends a raise hand notification to the server.
|
|
|
|
|
/// </summary>
|
|
|
|
|
ServerResponse RaiseHand(string message = default);
|
|
|
|
|
|
2023-02-24 15:48:54 +01:00
|
|
|
|
/// <summary>
|
2023-03-08 22:24:29 +01:00
|
|
|
|
/// Sends the selected exam to the server. Optionally returns a custom browser exam key to be used for the active session.
|
2023-02-24 15:48:54 +01:00
|
|
|
|
/// </summary>
|
2023-03-08 22:24:29 +01:00
|
|
|
|
ServerResponse<string> SendSelectedExam(Exam exam);
|
2023-02-24 15:48:54 +01:00
|
|
|
|
|
2020-07-28 19:56:25 +02:00
|
|
|
|
/// <summary>
|
2023-11-01 13:52:39 +01:00
|
|
|
|
/// Sends the given user identifier of an LMS and thus establishes a connection with the server.
|
2020-07-13 22:57:19 +02:00
|
|
|
|
/// </summary>
|
2023-11-01 13:52:39 +01:00
|
|
|
|
ServerResponse SendUserIdentifier(string identifier);
|
2020-07-29 23:39:05 +02:00
|
|
|
|
|
|
|
|
|
/// <summary>
|
2020-07-31 14:37:12 +02:00
|
|
|
|
/// Starts sending ping and log data to the server.
|
2020-07-29 23:39:05 +02:00
|
|
|
|
/// </summary>
|
|
|
|
|
void StartConnectivity();
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
2020-07-31 14:37:12 +02:00
|
|
|
|
/// Stops sending ping and log data to the server.
|
2020-07-29 23:39:05 +02:00
|
|
|
|
/// </summary>
|
|
|
|
|
void StopConnectivity();
|
2020-07-13 22:57:19 +02:00
|
|
|
|
}
|
|
|
|
|
}
|