2018-01-23 15:33:54 +01:00
|
|
|
|
/*
|
2019-01-09 11:25:21 +01:00
|
|
|
|
* Copyright (c) 2019 ETH Zürich, Educational Development and Technology (LET)
|
2018-01-23 15:33:54 +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/.
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
using System;
|
|
|
|
|
using System.ServiceModel;
|
2018-03-15 14:32:07 +01:00
|
|
|
|
using SafeExamBrowser.Contracts.Communication.Data;
|
2018-02-15 15:42:54 +01:00
|
|
|
|
using SafeExamBrowser.Contracts.Configuration;
|
2018-01-23 15:33:54 +01:00
|
|
|
|
|
|
|
|
|
namespace SafeExamBrowser.Contracts.Communication
|
|
|
|
|
{
|
2018-03-06 11:38:12 +01:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Defines the API for all communication between the three application components (runtime, service and client).
|
|
|
|
|
/// </summary>
|
2018-01-23 15:33:54 +01:00
|
|
|
|
[ServiceContract(SessionMode = SessionMode.Required)]
|
2018-02-15 15:42:54 +01:00
|
|
|
|
[ServiceKnownType(typeof(AuthenticationResponse))]
|
|
|
|
|
[ServiceKnownType(typeof(ClientConfiguration))]
|
2018-03-08 15:27:12 +01:00
|
|
|
|
[ServiceKnownType(typeof(ConfigurationResponse))]
|
2018-12-14 12:31:31 +01:00
|
|
|
|
[ServiceKnownType(typeof(MessageBoxReplyMessage))]
|
|
|
|
|
[ServiceKnownType(typeof(MessageBoxRequestMessage))]
|
2018-07-04 09:53:33 +02:00
|
|
|
|
[ServiceKnownType(typeof(PasswordReplyMessage))]
|
|
|
|
|
[ServiceKnownType(typeof(PasswordRequestMessage))]
|
2018-03-08 15:27:12 +01:00
|
|
|
|
[ServiceKnownType(typeof(ReconfigurationMessage))]
|
2018-07-04 09:53:33 +02:00
|
|
|
|
[ServiceKnownType(typeof(ReconfigurationDeniedMessage))]
|
2018-03-08 15:27:12 +01:00
|
|
|
|
[ServiceKnownType(typeof(SimpleMessage))]
|
2018-02-16 13:15:16 +01:00
|
|
|
|
[ServiceKnownType(typeof(SimpleResponse))]
|
2018-01-24 12:34:32 +01:00
|
|
|
|
public interface ICommunication
|
2018-01-23 15:33:54 +01:00
|
|
|
|
{
|
|
|
|
|
/// <summary>
|
2018-02-14 15:26:05 +01:00
|
|
|
|
/// Initiates a connection and must thus be called before any other opertion. Where applicable, an authentication token should be
|
|
|
|
|
/// specified. Returns a response indicating whether the connection request was successful or not.
|
2018-01-23 15:33:54 +01:00
|
|
|
|
/// </summary>
|
|
|
|
|
[OperationContract(IsInitiating = true)]
|
2018-02-15 15:42:54 +01:00
|
|
|
|
ConnectionResponse Connect(Guid? token = null);
|
2018-01-23 15:33:54 +01:00
|
|
|
|
|
|
|
|
|
/// <summary>
|
2018-02-14 15:26:05 +01:00
|
|
|
|
/// Closes a connection. Returns a response indicating whether the disconnection request was successful or not.
|
2018-01-23 15:33:54 +01:00
|
|
|
|
/// </summary>
|
|
|
|
|
[OperationContract(IsInitiating = false, IsTerminating = true)]
|
2018-02-15 15:42:54 +01:00
|
|
|
|
DisconnectionResponse Disconnect(DisconnectionMessage message);
|
2018-01-23 15:33:54 +01:00
|
|
|
|
|
|
|
|
|
/// <summary>
|
2018-02-14 15:26:05 +01:00
|
|
|
|
/// Sends a message, optionally returning a response. If no response is expected, <c>null</c> will be returned.
|
2018-01-23 15:33:54 +01:00
|
|
|
|
/// </summary>
|
|
|
|
|
[OperationContract(IsInitiating = false)]
|
2018-02-15 15:42:54 +01:00
|
|
|
|
Response Send(Message message);
|
2018-01-23 15:33:54 +01:00
|
|
|
|
}
|
|
|
|
|
}
|