2021-02-19 22:03:52 +01:00
|
|
|
|
/*
|
|
|
|
|
* Copyright (c) 2021 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/.
|
|
|
|
|
*/
|
|
|
|
|
|
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-03-10 21:26:45 +01:00
|
|
|
|
using SafeExamBrowser.Logging.Contracts;
|
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-03-23 21:12:47 +01:00
|
|
|
|
public event FullScreenChangedEventHandler FullScreenChanged;
|
|
|
|
|
|
2021-03-10 21:26:45 +01:00
|
|
|
|
internal ProctoringControl(ILogger logger)
|
|
|
|
|
{
|
|
|
|
|
this.logger = logger;
|
|
|
|
|
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;
|
|
|
|
|
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);
|
|
|
|
|
logger.Debug($"Full screen ${(CoreWebView2.ContainsFullScreenElement ? "activated" : "deactivated")}.");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
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
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|