2018-01-24 12:34:32 +01:00
|
|
|
|
/*
|
2019-01-09 11:25:21 +01:00
|
|
|
|
* Copyright (c) 2019 ETH Zürich, Educational Development and Technology (LET)
|
2018-01-24 12:34:32 +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-08 13:32:48 +01:00
|
|
|
|
using System;
|
2019-06-11 09:53:33 +02:00
|
|
|
|
using SafeExamBrowser.Contracts.Configuration;
|
2018-02-08 13:32:48 +01:00
|
|
|
|
|
2018-03-15 14:32:07 +01:00
|
|
|
|
namespace SafeExamBrowser.Contracts.Communication.Proxies
|
2018-01-24 12:34:32 +01:00
|
|
|
|
{
|
2018-03-06 11:38:12 +01:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Defines the functionality for a proxy to the communication host of the service application component.
|
|
|
|
|
/// </summary>
|
2018-02-14 15:26:05 +01:00
|
|
|
|
public interface IServiceProxy : ICommunicationProxy
|
2018-01-24 12:34:32 +01:00
|
|
|
|
{
|
2018-01-25 09:50:46 +01:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Instructs the proxy to ignore all operations or simulate a connection, where applicable. To be set e.g. when the service
|
|
|
|
|
/// policy is optional and the service is not available.
|
|
|
|
|
/// </summary>
|
|
|
|
|
bool Ignore { set; }
|
|
|
|
|
|
2019-06-06 15:44:03 +02:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Indicates whether a connection to the communication host of the service has been established.
|
|
|
|
|
/// </summary>
|
|
|
|
|
bool IsConnected { get; }
|
|
|
|
|
|
2018-02-08 13:32:48 +01:00
|
|
|
|
/// <summary>
|
2019-06-11 09:53:33 +02:00
|
|
|
|
/// Instructs the service to start a new session according to the given configuration.
|
2018-02-08 13:32:48 +01:00
|
|
|
|
/// </summary>
|
2019-06-11 09:53:33 +02:00
|
|
|
|
CommunicationResult StartSession(ServiceConfiguration configuration);
|
2018-02-08 13:32:48 +01:00
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Instructs the service to stop the specified session.
|
|
|
|
|
/// </summary>
|
2018-08-10 13:23:24 +02:00
|
|
|
|
CommunicationResult StopSession(Guid sessionId);
|
2018-01-24 12:34:32 +01:00
|
|
|
|
}
|
|
|
|
|
}
|