2024-02-01 17:36:11 +01:00
|
|
|
|
/*
|
2024-03-05 18:37:42 +01:00
|
|
|
|
* Copyright (c) 2024 ETH Zürich, IT Services
|
2024-02-01 17:36:11 +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.Net.Http;
|
|
|
|
|
using SafeExamBrowser.Logging.Contracts;
|
2024-02-13 11:04:36 +01:00
|
|
|
|
using SafeExamBrowser.Proctoring.ScreenProctoring.Data;
|
2024-02-01 17:36:11 +01:00
|
|
|
|
using SafeExamBrowser.Proctoring.ScreenProctoring.Imaging;
|
|
|
|
|
using SafeExamBrowser.Proctoring.ScreenProctoring.Service.Requests;
|
|
|
|
|
|
|
|
|
|
namespace SafeExamBrowser.Proctoring.ScreenProctoring.Service
|
|
|
|
|
{
|
|
|
|
|
internal class ServiceProxy
|
|
|
|
|
{
|
|
|
|
|
private readonly Api api;
|
|
|
|
|
private readonly ILogger logger;
|
|
|
|
|
private readonly Parser parser;
|
|
|
|
|
|
|
|
|
|
private HttpClient httpClient;
|
|
|
|
|
|
|
|
|
|
internal bool IsConnected => SessionId != default;
|
|
|
|
|
internal string SessionId { get; set; }
|
|
|
|
|
|
|
|
|
|
internal ServiceProxy(ILogger logger)
|
|
|
|
|
{
|
|
|
|
|
this.api = new Api();
|
|
|
|
|
this.logger = logger;
|
|
|
|
|
this.parser = new Parser(logger);
|
|
|
|
|
}
|
|
|
|
|
|
2024-08-12 14:42:09 +02:00
|
|
|
|
internal ServiceResponse Connect(string clientId, string clientSecret, string serviceUrl)
|
2024-02-01 17:36:11 +01:00
|
|
|
|
{
|
|
|
|
|
httpClient = new HttpClient { BaseAddress = new Uri(serviceUrl) };
|
|
|
|
|
|
|
|
|
|
var request = new OAuth2TokenRequest(api, httpClient, logger, parser);
|
2024-08-12 14:42:09 +02:00
|
|
|
|
var success = request.TryExecute(clientId, clientSecret, out var message);
|
2024-02-01 17:36:11 +01:00
|
|
|
|
|
|
|
|
|
if (success)
|
|
|
|
|
{
|
|
|
|
|
logger.Info("Successfully connected to service.");
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
logger.Error("Failed to connect to service!");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return new ServiceResponse(success, message);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
internal ServiceResponse CreateSession(string groupId)
|
|
|
|
|
{
|
|
|
|
|
var request = new CreateSessionRequest(api, httpClient, logger, parser);
|
|
|
|
|
var success = request.TryExecute(groupId, out var message, out var sessionId);
|
|
|
|
|
|
|
|
|
|
if (success)
|
|
|
|
|
{
|
|
|
|
|
SessionId = sessionId;
|
|
|
|
|
logger.Info("Successfully created session.");
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
logger.Error("Failed to create session!");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return new ServiceResponse(success, message);
|
|
|
|
|
}
|
|
|
|
|
|
2024-02-16 19:42:41 +01:00
|
|
|
|
internal ServiceResponse<int> GetHealth()
|
|
|
|
|
{
|
|
|
|
|
var request = new HealthRequest(api, httpClient, logger, parser);
|
|
|
|
|
var success = request.TryExecute(out var health, out var message);
|
|
|
|
|
|
|
|
|
|
if (success)
|
|
|
|
|
{
|
|
|
|
|
logger.Info($"Successfully queried health (value: {health}).");
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
logger.Error("Failed to query health!");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return new ServiceResponse<int>(success, health, message);
|
|
|
|
|
}
|
|
|
|
|
|
2024-02-21 19:17:08 +01:00
|
|
|
|
internal ServiceResponse<int> Send(MetaData metaData, ScreenShot screenShot)
|
2024-02-01 17:36:11 +01:00
|
|
|
|
{
|
|
|
|
|
var request = new ScreenShotRequest(api, httpClient, logger, parser);
|
2024-02-21 19:17:08 +01:00
|
|
|
|
var success = request.TryExecute(metaData, screenShot, SessionId, out var health, out var message);
|
2024-02-01 17:36:11 +01:00
|
|
|
|
|
|
|
|
|
if (success)
|
|
|
|
|
{
|
|
|
|
|
logger.Info($"Successfully sent screen shot ({screenShot}).");
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
logger.Error("Failed to send screen shot!");
|
|
|
|
|
}
|
|
|
|
|
|
2024-02-21 19:17:08 +01:00
|
|
|
|
return new ServiceResponse<int>(success, health, message);
|
2024-02-01 17:36:11 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
internal ServiceResponse TerminateSession()
|
|
|
|
|
{
|
|
|
|
|
var request = new TerminateSessionRequest(api, httpClient, logger, parser);
|
|
|
|
|
var success = request.TryExecute(SessionId, out var message);
|
|
|
|
|
|
|
|
|
|
if (success)
|
|
|
|
|
{
|
|
|
|
|
SessionId = default;
|
|
|
|
|
logger.Info("Successfully terminated session.");
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
logger.Error("Failed to terminate session!");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return new ServiceResponse(success, message);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|