/* * Copyright (c) 2019 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; using SafeExamBrowser.Communication.Contracts; using SafeExamBrowser.Communication.Contracts.Data; using SafeExamBrowser.Communication.Contracts.Proxies; using SafeExamBrowser.Logging.Contracts; namespace SafeExamBrowser.Communication.Proxies { /// /// Default implementation of the , to be used for communication with the client application component. /// public class ClientProxy : BaseProxy, IClientProxy { public ClientProxy(string address, IProxyObjectFactory factory, ILogger logger, Interlocutor owner) : base(address, factory, logger, owner) { } public CommunicationResult InformReconfigurationDenied(string filePath) { try { var response = Send(new ReconfigurationDeniedMessage(filePath)); var success = IsAcknowledged(response); if (success) { Logger.Debug("Client acknowledged reconfiguration denial."); } else { Logger.Error($"Client did not acknowledge reconfiguration denial! Received: {ToString(response)}."); } return new CommunicationResult(success); } catch (Exception e) { Logger.Error($"Failed to perform '{nameof(InformReconfigurationDenied)}'", e); return new CommunicationResult(false); } } public CommunicationResult InitiateShutdown() { try { var response = Send(SimpleMessagePurport.Shutdown); var success = IsAcknowledged(response); if (success) { Logger.Debug("Client acknowledged shutdown request."); } else { Logger.Error($"Client did not acknowledge shutdown request! Received: {ToString(response)}."); } return new CommunicationResult(success); } catch (Exception e) { Logger.Error($"Failed to perform '{nameof(InitiateShutdown)}'", e); return new CommunicationResult(false); } } public CommunicationResult RequestAuthentication() { try { var response = Send(SimpleMessagePurport.Authenticate); var success = response is AuthenticationResponse; if (success) { Logger.Debug("Received authentication response."); } else { Logger.Error($"Did not receive authentication response! Received: {ToString(response)}."); } return new CommunicationResult(success, response as AuthenticationResponse); } catch (Exception e) { Logger.Error($"Failed to perform '{nameof(RequestAuthentication)}'", e); return new CommunicationResult(false, default(AuthenticationResponse)); } } public CommunicationResult RequestPassword(PasswordRequestPurpose purpose, Guid requestId) { try { var response = Send(new PasswordRequestMessage(purpose, requestId)); var success = IsAcknowledged(response); if (success) { Logger.Debug("Client acknowledged password request."); } else { Logger.Error($"Client did not acknowledge password request! Received: {ToString(response)}."); } return new CommunicationResult(success); } catch (Exception e) { Logger.Error($"Failed to perform '{nameof(RequestPassword)}'", e); return new CommunicationResult(false); } } // TODO public CommunicationResult ShowMessage(string message, string title, /*MessageBoxAction action, MessageBoxIcon icon, */Guid requestId) { try { var response = Send(new MessageBoxRequestMessage(/*action, icon, */message, requestId, title)); var success = IsAcknowledged(response); if (success) { Logger.Debug("Client acknowledged message box request."); } else { Logger.Error($"Client did not acknowledge message box request! Received: {ToString(response)}."); } return new CommunicationResult(success); } catch (Exception e) { Logger.Error($"Failed to perform '{nameof(ShowMessage)}'", e); return new CommunicationResult(false); } } } }