seb-win-refactoring/SafeExamBrowser.Configuration.Contracts/Settings/Browser/BrowserSettings.cs

88 lines
2.7 KiB
C#
Raw Normal View History

2017-07-28 14:52:15 +02:00
/*
* Copyright (c) 2019 ETH Zürich, Educational Development and Technology (LET)
2017-07-28 14:52:15 +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-02-15 15:42:54 +01:00
using System;
using System.Collections.Generic;
2018-02-15 15:42:54 +01:00
namespace SafeExamBrowser.Configuration.Contracts.Settings.Browser
2017-07-28 14:52:15 +02:00
{
/// <summary>
/// Defines all configuration options for the browser engine of the application.
/// </summary>
2018-02-15 15:42:54 +01:00
[Serializable]
public class BrowserSettings
2017-07-28 14:52:15 +02:00
{
/// <summary>
/// The configuration to be used for additional browser windows.
2017-07-28 14:52:15 +02:00
/// </summary>
public BrowserWindowSettings AdditionalWindowSettings { get; set; }
2017-07-28 14:52:15 +02:00
/// <summary>
/// Determines whether the user will be allowed to download configuration files.
/// </summary>
public bool AllowConfigurationDownloads { get; set; }
/// <summary>
/// Determines whether the user will be allowed to download files (excluding configuration files).
/// </summary>
public bool AllowDownloads { get; set; }
2019-01-15 10:44:35 +01:00
/// <summary>
/// Determines whether the user will be allowed to zoom webpages.
2019-01-15 10:44:35 +01:00
/// </summary>
public bool AllowPageZoom { get; set; }
2017-07-28 14:52:15 +02:00
/// <summary>
/// Determines whether popup windows will be opened or not.
/// </summary>
public bool AllowPopups { get; set; }
/// <summary>
/// The custom user agent to optionally be used for all requests.
/// </summary>
public string CustomUserAgent { get; set; }
/// <summary>
/// Defines whether all content requests for a web page should be filtered according to the defined <see cref="FilterRules"/>.
/// </summary>
public bool FilterContentRequests { get; set; }
/// <summary>
/// Defines whether the main request for a web page should be filtered according to the defined <see cref="FilterRules"/>.
/// </summary>
public bool FilterMainRequests { get; set; }
/// <summary>
/// Defines all rules to be used to filter web requests.
/// </summary>
public IList<FilterRule> FilterRules { get; set; }
2017-07-28 14:52:15 +02:00
/// <summary>
/// The configuration to be used for the main browser window.
2017-07-28 14:52:15 +02:00
/// </summary>
public BrowserWindowSettings MainWindowSettings { get; set; }
/// <summary>
/// The URL with which the main browser window will be loaded.
/// </summary>
2018-02-15 15:42:54 +01:00
public string StartUrl { get; set; }
/// <summary>
/// Determines whether a custom user agent will be used for all requests, see <see cref="CustomUserAgent"/>.
/// </summary>
public bool UseCustomUserAgent { get; set; }
public BrowserSettings()
{
AdditionalWindowSettings = new BrowserWindowSettings();
FilterRules = new List<FilterRule>();
MainWindowSettings = new BrowserWindowSettings();
}
2017-07-28 14:52:15 +02:00
}
}