SEBWIN-304: Implemented browser popup policy.
This commit is contained in:
parent
a54513259d
commit
1f4043619f
8 changed files with 77 additions and 25 deletions
|
@ -249,14 +249,19 @@ namespace SafeExamBrowser.Browser
|
||||||
|
|
||||||
private void LifeSpanHandler_PopupRequested(PopupRequestedEventArgs args)
|
private void LifeSpanHandler_PopupRequested(PopupRequestedEventArgs args)
|
||||||
{
|
{
|
||||||
if (settings.AllowPopups)
|
switch (settings.PopupPolicy)
|
||||||
{
|
{
|
||||||
logger.Debug($"Forwarding request to open new window for '{args.Url}'...");
|
case PopupPolicy.Allow:
|
||||||
PopupRequested?.Invoke(args);
|
logger.Debug($"Forwarding request to open new window for '{args.Url}'...");
|
||||||
}
|
PopupRequested?.Invoke(args);
|
||||||
else
|
break;
|
||||||
{
|
case PopupPolicy.SameWindow:
|
||||||
logger.Debug($"Blocked attempt to open new window for '{args.Url}'.");
|
logger.Info($"Discarding request to open new window and loading '{args.Url}' directly...");
|
||||||
|
control.NavigateTo(args.Url);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
logger.Info($"Blocked attempt to open new window for '{args.Url}'.");
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -82,14 +82,6 @@ namespace SafeExamBrowser.Configuration.ConfigurationData
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void MapAllowPopups(AppSettings settings, object value)
|
|
||||||
{
|
|
||||||
if (value is bool block)
|
|
||||||
{
|
|
||||||
settings.Browser.AllowPopups = !block;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private void MapAllowReload(AppSettings settings, object value)
|
private void MapAllowReload(AppSettings settings, object value)
|
||||||
{
|
{
|
||||||
if (value is bool allow)
|
if (value is bool allow)
|
||||||
|
@ -116,6 +108,29 @@ namespace SafeExamBrowser.Configuration.ConfigurationData
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void MapPopupPolicy(AppSettings settings, object value)
|
||||||
|
{
|
||||||
|
const int ALLOW = 2;
|
||||||
|
const int BLOCK = 0;
|
||||||
|
const int SAME_WINDOW = 1;
|
||||||
|
|
||||||
|
if (value is int policy)
|
||||||
|
{
|
||||||
|
switch (policy)
|
||||||
|
{
|
||||||
|
case ALLOW:
|
||||||
|
settings.Browser.PopupPolicy = PopupPolicy.Allow;
|
||||||
|
break;
|
||||||
|
case BLOCK:
|
||||||
|
settings.Browser.PopupPolicy = PopupPolicy.Block;
|
||||||
|
break;
|
||||||
|
case SAME_WINDOW:
|
||||||
|
settings.Browser.PopupPolicy = PopupPolicy.SameWindow;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private void MapRequestFilter(IDictionary<string, object> rawData, AppSettings settings)
|
private void MapRequestFilter(IDictionary<string, object> rawData, AppSettings settings)
|
||||||
{
|
{
|
||||||
var processMainRequests = rawData.TryGetValue(Keys.Browser.Filter.EnableMainRequestFilter, out var value) && value as bool? == true;
|
var processMainRequests = rawData.TryGetValue(Keys.Browser.Filter.EnableMainRequestFilter, out var value) && value as bool? == true;
|
||||||
|
|
|
@ -78,8 +78,8 @@ namespace SafeExamBrowser.Configuration.ConfigurationData
|
||||||
case Keys.Browser.AllowPageZoom:
|
case Keys.Browser.AllowPageZoom:
|
||||||
MapAllowPageZoom(settings, value);
|
MapAllowPageZoom(settings, value);
|
||||||
break;
|
break;
|
||||||
case Keys.Browser.AllowPopups:
|
case Keys.Browser.PopupPolicy:
|
||||||
MapAllowPopups(settings, value);
|
MapPopupPolicy(settings, value);
|
||||||
break;
|
break;
|
||||||
case Keys.Browser.AdditionalWindow.AllowAddressBar:
|
case Keys.Browser.AdditionalWindow.AllowAddressBar:
|
||||||
MapAllowAddressBarAdditionalWindow(settings, value);
|
MapAllowAddressBarAdditionalWindow(settings, value);
|
||||||
|
|
|
@ -114,7 +114,7 @@ namespace SafeExamBrowser.Configuration.ConfigurationData
|
||||||
settings.Browser.AllowConfigurationDownloads = true;
|
settings.Browser.AllowConfigurationDownloads = true;
|
||||||
settings.Browser.AllowDownloads = true;
|
settings.Browser.AllowDownloads = true;
|
||||||
settings.Browser.AllowPageZoom = true;
|
settings.Browser.AllowPageZoom = true;
|
||||||
settings.Browser.AllowPopups = true;
|
settings.Browser.PopupPolicy = PopupPolicy.Allow;
|
||||||
settings.Browser.AdditionalWindow.AllowAddressBar = false;
|
settings.Browser.AdditionalWindow.AllowAddressBar = false;
|
||||||
settings.Browser.AdditionalWindow.AllowBackwardNavigation = true;
|
settings.Browser.AdditionalWindow.AllowBackwardNavigation = true;
|
||||||
settings.Browser.AdditionalWindow.AllowDeveloperConsole = false;
|
settings.Browser.AdditionalWindow.AllowDeveloperConsole = false;
|
||||||
|
|
|
@ -49,9 +49,9 @@ namespace SafeExamBrowser.Configuration.ConfigurationData
|
||||||
internal const string AllowDeveloperConsole = "allowDeveloperConsole";
|
internal const string AllowDeveloperConsole = "allowDeveloperConsole";
|
||||||
internal const string AllowDownloads = "allowDownUploads";
|
internal const string AllowDownloads = "allowDownUploads";
|
||||||
internal const string AllowPageZoom = "enableZoomPage";
|
internal const string AllowPageZoom = "enableZoomPage";
|
||||||
internal const string AllowPopups = "blockPopUpWindows";
|
|
||||||
internal const string CustomUserAgentDesktop = "browserUserAgentWinDesktopModeCustom";
|
internal const string CustomUserAgentDesktop = "browserUserAgentWinDesktopModeCustom";
|
||||||
internal const string CustomUserAgentMobile = "browserUserAgentWinTouchModeCustom";
|
internal const string CustomUserAgentMobile = "browserUserAgentWinTouchModeCustom";
|
||||||
|
internal const string PopupPolicy = "newBrowserWindowByLinkPolicy";
|
||||||
internal const string UserAgentModeDesktop = "browserUserAgentWinDesktopMode";
|
internal const string UserAgentModeDesktop = "browserUserAgentWinDesktopMode";
|
||||||
internal const string UserAgentModeMobile = "browserUserAgentWinTouchMode";
|
internal const string UserAgentModeMobile = "browserUserAgentWinTouchMode";
|
||||||
|
|
||||||
|
|
|
@ -36,11 +36,6 @@ namespace SafeExamBrowser.Settings.Browser
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public bool AllowPageZoom { get; set; }
|
public bool AllowPageZoom { get; set; }
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Determines whether popup windows will be opened or not.
|
|
||||||
/// </summary>
|
|
||||||
public bool AllowPopups { get; set; }
|
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// The custom user agent to optionally be used for all requests.
|
/// The custom user agent to optionally be used for all requests.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
@ -55,7 +50,12 @@ namespace SafeExamBrowser.Settings.Browser
|
||||||
/// The settings to be used for the main browser window.
|
/// The settings to be used for the main browser window.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public BrowserWindowSettings MainWindow { get; set; }
|
public BrowserWindowSettings MainWindow { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Determines how attempts to open a popup are handled.
|
||||||
|
/// </summary>
|
||||||
|
public PopupPolicy PopupPolicy { get; set; }
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// The URL with which the main browser window will be loaded.
|
/// The URL with which the main browser window will be loaded.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
|
31
SafeExamBrowser.Settings/Browser/PopupPolicy.cs
Normal file
31
SafeExamBrowser.Settings/Browser/PopupPolicy.cs
Normal file
|
@ -0,0 +1,31 @@
|
||||||
|
/*
|
||||||
|
* 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/.
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace SafeExamBrowser.Settings.Browser
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// Defines all policies for browser window popups.
|
||||||
|
/// </summary>
|
||||||
|
public enum PopupPolicy
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// Allows popups to be opened.
|
||||||
|
/// </summary>
|
||||||
|
Allow,
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Blocks all popups.
|
||||||
|
/// </summary>
|
||||||
|
Block,
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Opens popup requests in the same window from which they originate.
|
||||||
|
/// </summary>
|
||||||
|
SameWindow
|
||||||
|
}
|
||||||
|
}
|
|
@ -64,6 +64,7 @@
|
||||||
<Compile Include="Browser\FilterResult.cs" />
|
<Compile Include="Browser\FilterResult.cs" />
|
||||||
<Compile Include="Browser\FilterRuleSettings.cs" />
|
<Compile Include="Browser\FilterRuleSettings.cs" />
|
||||||
<Compile Include="Browser\FilterRuleType.cs" />
|
<Compile Include="Browser\FilterRuleType.cs" />
|
||||||
|
<Compile Include="Browser\PopupPolicy.cs" />
|
||||||
<Compile Include="ConfigurationMode.cs" />
|
<Compile Include="ConfigurationMode.cs" />
|
||||||
<Compile Include="KioskMode.cs" />
|
<Compile Include="KioskMode.cs" />
|
||||||
<Compile Include="Logging\LogLevel.cs" />
|
<Compile Include="Logging\LogLevel.cs" />
|
||||||
|
|
Loading…
Reference in a new issue