/* * Copyright (c) 2023 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 System.Collections.Generic; using SafeExamBrowser.Core.Contracts.Notifications; using SafeExamBrowser.Proctoring.Contracts.Events; using SafeExamBrowser.Settings.Proctoring; namespace SafeExamBrowser.Proctoring.Contracts { /// /// Defines the remote proctoring functionality. /// public interface IProctoringController { /// /// Indicates whether the hand is currently raised. /// bool IsHandRaised { get; } /// /// The notifications for all active proctoring providers. /// IEnumerable Notifications { get; } /// /// Fired when the hand has been lowered. /// event ProctoringEventHandler HandLowered; /// /// Fired when the hand has been raised. /// event ProctoringEventHandler HandRaised; /// /// Event fired when the status of the remaining work has been updated. /// event RemainingWorkUpdatedEventHandler RemainingWorkUpdated; /// /// Executes any remaining work like e.g. the transmission of cached screen shots. Make sure to do so before calling . /// void ExecuteRemainingWork(); /// /// Indicates whether there is any remaining work which needs to be done before the proctoring can be terminated. /// bool HasRemainingWork(); /// /// Initializes the given settings and starts the proctoring if the settings are valid. /// void Initialize(ProctoringSettings settings); /// /// Lowers the hand. /// void LowerHand(); /// /// Raises the hand, optionally with the given message. /// void RaiseHand(string message = default); /// /// Stops the proctoring functionality. Make sure to call beforehand if necessary. /// void Terminate(); } }