/* * Copyright (c) 2020 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/. */ using System; namespace SafeExamBrowser.Settings.Browser { /// <summary> /// Defines all settings for the integrated browser application. /// </summary> [Serializable] public class BrowserSettings { /// <summary> /// The settings to be used for additional browser windows. /// </summary> public WindowSettings AdditionalWindow { get; set; } /// <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 select a custom location when down- or uploading a file (excluding configuration files). /// </summary> public bool AllowCustomDownAndUploadLocation { get; set; } /// <summary> /// Determines whether the user will be allowed to download files (excluding configuration files). /// </summary> public bool AllowDownloads { get; set; } /// <summary> /// Determines whether the user will be allowed to search page contents. /// </summary> public bool AllowFind { get; set; } /// <summary> /// Determines whether the user will be allowed to zoom webpages. /// </summary> public bool AllowPageZoom { get; set; } /// <summary> /// Determines whether the internal PDF reader of the browser application is enabled. If not, documents will be downloaded by default. /// </summary> public bool AllowPdfReader { get; set; } /// <summary> /// Determines whether the toolbar of the internal PDF reader (which allows to e.g. download or print a document) will be enabled. /// </summary> public bool AllowPdfReaderToolbar { get; set; } /// <summary> /// Determines whether spell checking is enabled for input fields. /// </summary> public bool AllowSpellChecking { get; set; } /// <summary> /// Determines whether the user will be allowed to upload files. /// </summary> public bool AllowUploads { get; set; } /// <summary> /// The configuration key used for integrity checks with server applications (see also <see cref="SendConfigurationKey"/>). /// </summary> public string ConfigurationKey { get; set; } /// <summary> /// Determines whether the user needs to confirm the termination of SEB by <see cref="QuitUrl"/>. /// </summary> public bool ConfirmQuitUrl { get; set; } /// <summary> /// The custom user agent to optionally be used for all requests. /// </summary> public string CustomUserAgent { get; set; } /// <summary> /// Determines whether the entire browser cache is deleted when terminating the application. IMPORTANT: If <see cref="DeleteCookiesOnShutdown"/> /// is set to <c>false</c>, the cache will not be deleted in order to keep the cookies for the next session. /// </summary> public bool DeleteCacheOnShutdown { get; set; } /// <summary> /// Determines whether all cookies are deleted when terminating the browser application. IMPORTANT: The browser cache will not be deleted /// if set to <c>false</c>, even if <see cref="DeleteCacheOnShutdown"/> is set to <c>true</c>! /// </summary> public bool DeleteCookiesOnShutdown { get; set; } /// <summary> /// Determines whether all cookies are deleted when starting the browser application. /// </summary> public bool DeleteCookiesOnStartup { get; set; } /// <summary> /// Defines a custom directory for file down- and uploads. If not defined, all operations will be directed to the current user's download directory. /// </summary> public string DownAndUploadDirectory { get; set; } /// <summary> /// Determines whether the user is allowed to use the integrated browser application. /// </summary> public bool EnableBrowser { get; set; } /// <summary> /// The salt value for the calculation of the exam key which is used for integrity checks with server applications (see also <see cref="SendExamKey"/>). /// </summary> public byte[] ExamKeySalt { get; set; } /// <summary> /// The settings to be used for the browser request filter. /// </summary> public FilterSettings Filter { get; set; } /// <summary> /// An optional custom message shown before navigating home. /// </summary> public string HomeNavigationMessage { get; set; } /// <summary> /// Determines whether a password is required to navigate home. /// </summary> public bool HomeNavigationRequiresPassword { get; set; } /// <summary> /// The hash code of the password optionally required to navigate home. /// </summary> public string HomePasswordHash { get; set; } /// <summary> /// An optional custom URL to be used when navigating home. /// </summary> public string HomeUrl { get; set; } /// <summary> /// The settings to be used for the main browser window. /// </summary> public WindowSettings MainWindow { get; set; } /// <summary> /// Determines how attempts to open a popup are handled. /// </summary> public PopupPolicy PopupPolicy { get; set; } /// <summary> /// Determines the proxy settings to be used by the browser. /// </summary> public ProxySettings Proxy { get; set; } /// <summary> /// An URL which will initiate the termination of SEB (or reset the browser if <see cref="ResetOnQuitUrl"/> is <c>true</c>) when visited by the user. /// </summary> public string QuitUrl { get; set; } /// <summary> /// Determines whether the browser should be reset when a <see cref="QuitUrl"/> is detected. /// </summary> public bool ResetOnQuitUrl { get; set; } /// <summary> /// Determines whether the configuration key header is sent with every HTTP request (see also <see cref="ConfigurationKey"/>). /// </summary> public bool SendConfigurationKey { get; set; } /// <summary> /// Determines whether the exam key header is sent with every HTTP request (see also <see cref="ExamKeySalt"/>). /// </summary> public bool SendExamKey { get; set; } /// <summary> /// The URL with which the main browser window will be loaded. /// </summary> public string StartUrl { get; set; } /// <summary> /// A query for the <see cref="StartUrl"/> which SEB automatically extracts from the configuration URL. /// </summary> public string StartUrlQuery { 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; } /// <summary> /// Determines whether the <see cref="StartUrlQuery"/> will be appended to the <see cref="StartUrl"/>. /// </summary> public bool UseQueryParameter { get; set; } /// <summary> /// Determines whether the start URL will be used when navigating home. /// </summary> public bool UseStartUrlAsHomeUrl { get; set; } /// <summary> /// A custom suffix to be appended to the user agent. /// </summary> public string UserAgentSuffix { get; set; } public BrowserSettings() { AdditionalWindow = new WindowSettings(); Filter = new FilterSettings(); MainWindow = new WindowSettings(); Proxy = new ProxySettings(); } } }