2017-07-14 10:28:59 +02:00
|
|
|
|
/*
|
2018-01-16 08:24:00 +01:00
|
|
|
|
* Copyright (c) 2018 ETH Zürich, Educational Development and Technology (LET)
|
2017-07-14 10:28:59 +02: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/.
|
|
|
|
|
*/
|
|
|
|
|
|
2018-03-08 07:35:58 +01:00
|
|
|
|
using SafeExamBrowser.Browser.Handlers;
|
2018-06-21 07:56:25 +02:00
|
|
|
|
using SafeExamBrowser.Contracts.Browser;
|
2017-07-14 10:28:59 +02:00
|
|
|
|
using SafeExamBrowser.Contracts.Configuration;
|
2017-07-31 20:22:53 +02:00
|
|
|
|
using SafeExamBrowser.Contracts.Configuration.Settings;
|
2018-08-31 15:29:36 +02:00
|
|
|
|
using SafeExamBrowser.Contracts.Core;
|
|
|
|
|
using SafeExamBrowser.Contracts.Core.Events;
|
2017-07-31 20:22:53 +02:00
|
|
|
|
using SafeExamBrowser.Contracts.I18n;
|
2018-08-31 15:29:36 +02:00
|
|
|
|
using SafeExamBrowser.Contracts.Logging;
|
2017-07-24 17:31:28 +02:00
|
|
|
|
using SafeExamBrowser.Contracts.UserInterface;
|
2018-03-14 12:07:20 +01:00
|
|
|
|
using SafeExamBrowser.Contracts.UserInterface.Browser;
|
|
|
|
|
using SafeExamBrowser.Contracts.UserInterface.Windows;
|
2017-07-14 10:28:59 +02:00
|
|
|
|
|
|
|
|
|
namespace SafeExamBrowser.Browser
|
|
|
|
|
{
|
2018-03-08 07:35:58 +01:00
|
|
|
|
internal class BrowserApplicationInstance : IApplicationInstance
|
2017-07-14 10:28:59 +02:00
|
|
|
|
{
|
2018-06-29 09:50:20 +02:00
|
|
|
|
private AppConfig appConfig;
|
2017-07-31 20:22:53 +02:00
|
|
|
|
private IBrowserControl control;
|
|
|
|
|
private IBrowserWindow window;
|
2018-03-14 11:13:30 +01:00
|
|
|
|
private bool isMainInstance;
|
2018-08-31 15:29:36 +02:00
|
|
|
|
private IModuleLogger logger;
|
2018-03-14 11:13:30 +01:00
|
|
|
|
private BrowserSettings settings;
|
|
|
|
|
private IText text;
|
|
|
|
|
private IUserInterfaceFactory uiFactory;
|
2017-07-31 20:22:53 +02:00
|
|
|
|
|
2018-08-31 07:49:41 +02:00
|
|
|
|
public InstanceIdentifier Id { get; private set; }
|
2017-07-14 10:28:59 +02:00
|
|
|
|
public string Name { get; private set; }
|
2017-07-31 20:22:53 +02:00
|
|
|
|
public IWindow Window { get { return window; } }
|
2017-07-14 10:28:59 +02:00
|
|
|
|
|
2018-06-21 07:56:25 +02:00
|
|
|
|
public event DownloadRequestedEventHandler ConfigurationDownloadRequested;
|
2017-07-31 20:22:53 +02:00
|
|
|
|
public event NameChangedEventHandler NameChanged;
|
2018-07-06 15:57:38 +02:00
|
|
|
|
public event InstanceTerminatedEventHandler Terminated;
|
2017-07-28 09:12:17 +02:00
|
|
|
|
|
2018-06-21 07:56:25 +02:00
|
|
|
|
public BrowserApplicationInstance(
|
2018-06-29 09:50:20 +02:00
|
|
|
|
AppConfig appConfig,
|
2018-06-21 07:56:25 +02:00
|
|
|
|
BrowserSettings settings,
|
2018-08-31 07:49:41 +02:00
|
|
|
|
InstanceIdentifier id,
|
|
|
|
|
bool isMainInstance,
|
2018-08-31 15:29:36 +02:00
|
|
|
|
IModuleLogger logger,
|
2018-06-21 07:56:25 +02:00
|
|
|
|
IText text,
|
2018-08-31 07:49:41 +02:00
|
|
|
|
IUserInterfaceFactory uiFactory)
|
2018-03-14 11:13:30 +01:00
|
|
|
|
{
|
2018-06-29 09:50:20 +02:00
|
|
|
|
this.appConfig = appConfig;
|
2018-08-31 07:49:41 +02:00
|
|
|
|
this.Id = id;
|
2018-03-14 11:13:30 +01:00
|
|
|
|
this.isMainInstance = isMainInstance;
|
2018-08-31 15:29:36 +02:00
|
|
|
|
this.logger = logger;
|
2018-03-14 11:13:30 +01:00
|
|
|
|
this.settings = settings;
|
|
|
|
|
this.text = text;
|
|
|
|
|
this.uiFactory = uiFactory;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
internal void Initialize()
|
2017-07-14 10:28:59 +02:00
|
|
|
|
{
|
2018-08-31 15:29:36 +02:00
|
|
|
|
var controlLogger = logger.CloneFor($"{nameof(BrowserControl)} {Id}");
|
|
|
|
|
var downloadLogger = logger.CloneFor($"{nameof(DownloadHandler)} {Id}");
|
|
|
|
|
var downloadHandler = new DownloadHandler(appConfig, settings, downloadLogger);
|
2018-06-21 07:56:25 +02:00
|
|
|
|
|
2018-10-30 11:24:28 +01:00
|
|
|
|
downloadHandler.ConfigurationDownloadRequested += DownloadHandler_ConfigurationDownloadRequested;
|
2017-07-31 20:22:53 +02:00
|
|
|
|
|
2018-08-31 15:29:36 +02:00
|
|
|
|
control = new BrowserControl(appConfig, settings, controlLogger, text);
|
2017-07-31 20:22:53 +02:00
|
|
|
|
control.AddressChanged += Control_AddressChanged;
|
2018-03-01 08:50:08 +01:00
|
|
|
|
control.LoadingStateChanged += Control_LoadingStateChanged;
|
2017-07-31 20:22:53 +02:00
|
|
|
|
control.TitleChanged += Control_TitleChanged;
|
2018-06-21 07:56:25 +02:00
|
|
|
|
(control as BrowserControl).DownloadHandler = downloadHandler;
|
|
|
|
|
(control as BrowserControl).Initialize();
|
2017-07-31 20:22:53 +02:00
|
|
|
|
|
2018-08-31 15:29:36 +02:00
|
|
|
|
logger.Debug("Initialized browser control.");
|
|
|
|
|
|
2017-07-31 20:22:53 +02:00
|
|
|
|
window = uiFactory.CreateBrowserWindow(control, settings);
|
|
|
|
|
window.IsMainWindow = isMainInstance;
|
|
|
|
|
window.Closing += () => Terminated?.Invoke(Id);
|
|
|
|
|
window.AddressChanged += Window_AddressChanged;
|
|
|
|
|
window.ReloadRequested += Window_ReloadRequested;
|
|
|
|
|
window.BackwardNavigationRequested += Window_BackwardNavigationRequested;
|
|
|
|
|
window.ForwardNavigationRequested += Window_ForwardNavigationRequested;
|
2018-08-31 15:29:36 +02:00
|
|
|
|
|
|
|
|
|
logger.Debug("Initialized browser window.");
|
2017-07-31 20:22:53 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void Control_AddressChanged(string address)
|
|
|
|
|
{
|
|
|
|
|
window.UpdateAddress(address);
|
|
|
|
|
}
|
|
|
|
|
|
2018-03-01 08:50:08 +01:00
|
|
|
|
private void Control_LoadingStateChanged(bool isLoading)
|
|
|
|
|
{
|
|
|
|
|
window.UpdateLoadingState(isLoading);
|
|
|
|
|
}
|
|
|
|
|
|
2017-07-31 20:22:53 +02:00
|
|
|
|
private void Control_TitleChanged(string title)
|
|
|
|
|
{
|
|
|
|
|
window.UpdateTitle(title);
|
|
|
|
|
NameChanged?.Invoke(title);
|
|
|
|
|
}
|
|
|
|
|
|
2018-10-30 11:24:28 +01:00
|
|
|
|
private void DownloadHandler_ConfigurationDownloadRequested(string fileName, DownloadEventArgs args)
|
|
|
|
|
{
|
2018-11-08 09:39:52 +01:00
|
|
|
|
if (settings.AllowConfigurationDownloads)
|
|
|
|
|
{
|
|
|
|
|
args.BrowserWindow = window;
|
|
|
|
|
logger.Debug($"Forwarding download request for configuration file '{fileName}'.");
|
|
|
|
|
|
|
|
|
|
ConfigurationDownloadRequested?.Invoke(fileName, args);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
logger.Debug($"Discarded download request for configuration file '{fileName}'.");
|
|
|
|
|
}
|
2018-10-30 11:24:28 +01:00
|
|
|
|
}
|
|
|
|
|
|
2017-07-31 20:22:53 +02:00
|
|
|
|
private void Window_AddressChanged(string address)
|
|
|
|
|
{
|
2018-08-31 15:29:36 +02:00
|
|
|
|
logger.Debug($"The user requested to navigate to '{address}'.");
|
2017-07-31 20:22:53 +02:00
|
|
|
|
control.NavigateTo(address);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void Window_ReloadRequested()
|
|
|
|
|
{
|
2018-08-31 15:29:36 +02:00
|
|
|
|
logger.Debug($"The user requested to reload the current page.");
|
2017-07-31 20:22:53 +02:00
|
|
|
|
control.Reload();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void Window_BackwardNavigationRequested()
|
|
|
|
|
{
|
2018-08-31 15:29:36 +02:00
|
|
|
|
logger.Debug($"The user requested to navigate backwards.");
|
2017-07-31 20:22:53 +02:00
|
|
|
|
control.NavigateBackwards();
|
2017-07-14 10:28:59 +02:00
|
|
|
|
}
|
2017-07-24 17:31:28 +02:00
|
|
|
|
|
2017-07-31 20:22:53 +02:00
|
|
|
|
private void Window_ForwardNavigationRequested()
|
2017-07-24 17:31:28 +02:00
|
|
|
|
{
|
2018-08-31 15:29:36 +02:00
|
|
|
|
logger.Debug($"The user requested to navigate forwards.");
|
2017-07-31 20:22:53 +02:00
|
|
|
|
control.NavigateForwards();
|
2017-07-24 17:31:28 +02:00
|
|
|
|
}
|
2017-07-14 10:28:59 +02:00
|
|
|
|
}
|
|
|
|
|
}
|