2021-02-19 22:03:52 +01:00
|
|
|
|
/*
|
2023-03-08 00:30:20 +01:00
|
|
|
|
* Copyright (c) 2023 ETH Zürich, Educational Development and Technology (LET)
|
2021-02-19 22:03:52 +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/.
|
|
|
|
|
*/
|
|
|
|
|
|
2021-03-10 21:26:45 +01:00
|
|
|
|
using Microsoft.Web.WebView2.Core;
|
2021-02-19 22:03:52 +01:00
|
|
|
|
using Microsoft.Web.WebView2.Wpf;
|
2021-06-29 09:44:16 +02:00
|
|
|
|
using Newtonsoft.Json.Linq;
|
2021-03-10 21:26:45 +01:00
|
|
|
|
using SafeExamBrowser.Logging.Contracts;
|
2021-06-29 09:44:16 +02:00
|
|
|
|
using SafeExamBrowser.Settings.Proctoring;
|
2021-02-19 22:03:52 +01:00
|
|
|
|
using SafeExamBrowser.UserInterface.Contracts.Proctoring;
|
2021-03-23 21:12:47 +01:00
|
|
|
|
using SafeExamBrowser.UserInterface.Contracts.Proctoring.Events;
|
2021-02-19 22:03:52 +01:00
|
|
|
|
|
|
|
|
|
namespace SafeExamBrowser.Proctoring
|
|
|
|
|
{
|
|
|
|
|
internal class ProctoringControl : WebView2, IProctoringControl
|
|
|
|
|
{
|
2021-03-10 21:26:45 +01:00
|
|
|
|
private readonly ILogger logger;
|
2021-06-29 09:44:16 +02:00
|
|
|
|
private readonly ProctoringSettings settings;
|
2021-03-10 21:26:45 +01:00
|
|
|
|
|
2021-03-23 21:12:47 +01:00
|
|
|
|
public event FullScreenChangedEventHandler FullScreenChanged;
|
|
|
|
|
|
2021-06-29 09:44:16 +02:00
|
|
|
|
internal ProctoringControl(ILogger logger, ProctoringSettings settings)
|
2021-03-10 21:26:45 +01:00
|
|
|
|
{
|
|
|
|
|
this.logger = logger;
|
2021-06-29 09:44:16 +02:00
|
|
|
|
this.settings = settings;
|
|
|
|
|
|
2021-03-10 21:26:45 +01:00
|
|
|
|
CoreWebView2InitializationCompleted += ProctoringControl_CoreWebView2InitializationCompleted;
|
|
|
|
|
}
|
|
|
|
|
|
2021-03-23 21:12:47 +01:00
|
|
|
|
private void ProctoringControl_CoreWebView2InitializationCompleted(object sender, CoreWebView2InitializationCompletedEventArgs e)
|
2021-03-10 21:26:45 +01:00
|
|
|
|
{
|
2021-03-23 21:12:47 +01:00
|
|
|
|
if (e.IsSuccess)
|
2021-03-10 21:26:45 +01:00
|
|
|
|
{
|
2021-04-18 17:37:35 +02:00
|
|
|
|
CoreWebView2.Settings.AreDefaultContextMenusEnabled = false;
|
|
|
|
|
CoreWebView2.Settings.AreDevToolsEnabled = false;
|
|
|
|
|
CoreWebView2.Settings.IsStatusBarEnabled = false;
|
2021-03-23 21:12:47 +01:00
|
|
|
|
CoreWebView2.ContainsFullScreenElementChanged += CoreWebView2_ContainsFullScreenElementChanged;
|
|
|
|
|
CoreWebView2.PermissionRequested += CoreWebView2_PermissionRequested;
|
2021-06-29 09:44:16 +02:00
|
|
|
|
CoreWebView2.WebMessageReceived += CoreWebView2_WebMessageReceived;
|
2021-03-23 21:12:47 +01:00
|
|
|
|
logger.Info("Successfully initialized.");
|
2021-03-10 21:26:45 +01:00
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
2021-03-23 21:12:47 +01:00
|
|
|
|
logger.Error("Failed to initialize!", e.InitializationException);
|
2021-03-10 21:26:45 +01:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2021-03-23 21:12:47 +01:00
|
|
|
|
private void CoreWebView2_ContainsFullScreenElementChanged(object sender, object e)
|
2021-02-19 22:03:52 +01:00
|
|
|
|
{
|
2021-03-23 21:12:47 +01:00
|
|
|
|
FullScreenChanged?.Invoke(CoreWebView2.ContainsFullScreenElement);
|
2021-11-05 15:06:13 +01:00
|
|
|
|
logger.Debug($"Full screen {(CoreWebView2.ContainsFullScreenElement ? "activated" : "deactivated")}.");
|
2021-03-23 21:12:47 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void CoreWebView2_PermissionRequested(object sender, CoreWebView2PermissionRequestedEventArgs e)
|
|
|
|
|
{
|
|
|
|
|
if (e.PermissionKind == CoreWebView2PermissionKind.Camera || e.PermissionKind == CoreWebView2PermissionKind.Microphone)
|
2021-03-10 21:26:45 +01:00
|
|
|
|
{
|
2021-03-23 21:12:47 +01:00
|
|
|
|
e.State = CoreWebView2PermissionState.Allow;
|
|
|
|
|
logger.Info($"Granted access to {e.PermissionKind}.");
|
2021-03-10 21:26:45 +01:00
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
2021-03-23 21:12:47 +01:00
|
|
|
|
logger.Info($"Denied access to {e.PermissionKind}.");
|
2021-03-10 21:26:45 +01:00
|
|
|
|
}
|
2021-02-19 22:03:52 +01:00
|
|
|
|
}
|
2021-06-29 09:44:16 +02:00
|
|
|
|
|
|
|
|
|
private void CoreWebView2_WebMessageReceived(object sender, CoreWebView2WebMessageReceivedEventArgs e)
|
|
|
|
|
{
|
|
|
|
|
var message = e.TryGetWebMessageAsString();
|
|
|
|
|
|
|
|
|
|
logger.Debug($"Received web message '{message}'.");
|
|
|
|
|
|
|
|
|
|
switch (message)
|
|
|
|
|
{
|
|
|
|
|
case "credentials":
|
|
|
|
|
SendCredentials();
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void SendCredentials()
|
|
|
|
|
{
|
|
|
|
|
var message = new JObject();
|
|
|
|
|
var credentials = new JObject();
|
|
|
|
|
|
|
|
|
|
if (settings.JitsiMeet.Enabled)
|
|
|
|
|
{
|
|
|
|
|
credentials.Add(new JProperty("domain", settings.JitsiMeet.ServerUrl));
|
|
|
|
|
credentials.Add(new JProperty("roomName", settings.JitsiMeet.RoomName));
|
|
|
|
|
credentials.Add(new JProperty("subject", settings.JitsiMeet.ShowMeetingName ? settings.JitsiMeet.Subject : ""));
|
|
|
|
|
credentials.Add(new JProperty("token", settings.JitsiMeet.Token));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
message.Add("credentials", credentials);
|
|
|
|
|
logger.Debug("Sending credentials to proctoring client.");
|
|
|
|
|
|
|
|
|
|
CoreWebView2.PostWebMessageAsJson(message.ToString());
|
|
|
|
|
}
|
2021-02-19 22:03:52 +01:00
|
|
|
|
}
|
|
|
|
|
}
|