Working on browser configuration.

This commit is contained in:
dbuechel 2017-07-28 14:52:15 +02:00
parent f6d4a281a6
commit 714d300758
20 changed files with 181 additions and 49 deletions

View file

@ -12,6 +12,7 @@ using System.Linq;
using CefSharp; using CefSharp;
using SafeExamBrowser.Contracts.Behaviour; using SafeExamBrowser.Contracts.Behaviour;
using SafeExamBrowser.Contracts.Configuration; using SafeExamBrowser.Contracts.Configuration;
using SafeExamBrowser.Contracts.Configuration.Settings;
using SafeExamBrowser.Contracts.UserInterface; using SafeExamBrowser.Contracts.UserInterface;
namespace SafeExamBrowser.Browser namespace SafeExamBrowser.Browser
@ -33,8 +34,8 @@ namespace SafeExamBrowser.Browser
{ {
var cefSettings = new CefSettings var cefSettings = new CefSettings
{ {
CachePath = settings.BrowserCachePath, CachePath = settings.Browser.CachePath,
LogFile = settings.BrowserLogFile LogFile = settings.Browser.LogFile
}; };
var success = Cef.Initialize(cefSettings, true, null); var success = Cef.Initialize(cefSettings, true, null);
@ -65,7 +66,7 @@ namespace SafeExamBrowser.Browser
private void CreateNewInstance() private void CreateNewInstance()
{ {
var control = new BrowserControl("www.duckduckgo.com"); var control = new BrowserControl("www.duckduckgo.com");
var window = uiFactory.CreateBrowserWindow(control); var window = uiFactory.CreateBrowserWindow(control, settings.Browser);
var instance = new BrowserApplicationInstance("DuckDuckGo"); var instance = new BrowserApplicationInstance("DuckDuckGo");
instance.RegisterWindow(window); instance.RegisterWindow(window);

View file

@ -62,7 +62,8 @@
<ItemGroup> <ItemGroup>
<Compile Include="AboutNotificationIconResource.cs" /> <Compile Include="AboutNotificationIconResource.cs" />
<Compile Include="AboutNotificationInfo.cs" /> <Compile Include="AboutNotificationInfo.cs" />
<Compile Include="Settings.cs" /> <Compile Include="Settings\BrowserSettings.cs" />
<Compile Include="Settings\SettingsImpl.cs" />
<Compile Include="WorkingArea.cs" /> <Compile Include="WorkingArea.cs" />
<Compile Include="Properties\AssemblyInfo.cs" /> <Compile Include="Properties\AssemblyInfo.cs" />
</ItemGroup> </ItemGroup>

View file

@ -0,0 +1,46 @@
/*
* Copyright (c) 2017 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;
using System.IO;
using SafeExamBrowser.Contracts.Configuration.Settings;
namespace SafeExamBrowser.Configuration.Settings
{
public class BrowserSettings : IBrowserSettings
{
private ISettings settings;
public BrowserSettings(ISettings settings)
{
this.settings = settings;
}
public bool AllowAddressBar => true;
public bool AllowBackwardNavigation => false;
public bool AllowDebugConsole => true;
public bool AllowForwardNavigation => false;
public bool AllowReloading => false;
public string CachePath
{
get { return Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.ApplicationData), settings.AppDataFolderName, "Cache"); }
}
public bool FullScreenMode => throw new NotImplementedException();
public string LogFile
{
get { return Path.Combine(settings.LogFolderPath, $"{settings.RuntimeIdentifier}_Browser.txt"); }
}
}
}

View file

@ -9,33 +9,35 @@
using System; using System;
using System.IO; using System.IO;
using System.Reflection; using System.Reflection;
using SafeExamBrowser.Contracts.Configuration; using SafeExamBrowser.Configuration.Settings;
using SafeExamBrowser.Contracts.Configuration.Settings;
namespace SafeExamBrowser.Configuration namespace SafeExamBrowser.Configuration
{ {
public class Settings : ISettings /// <remarks>
/// TODO: Replace with proper implementation once configuration aspects are clear...
/// </remarks>
public class SettingsImpl : ISettings
{ {
private const string AppDataFolder = "SafeExamBrowser";
private static readonly string LogFileDate = DateTime.Now.ToString("yyyy-MM-dd\\_HH\\hmm\\mss\\s"); private static readonly string LogFileDate = DateTime.Now.ToString("yyyy-MM-dd\\_HH\\hmm\\mss\\s");
public SettingsImpl()
{
Browser = new BrowserSettings(this);
}
public string AppDataFolderName => "SafeExamBrowser";
public string ApplicationLogFile public string ApplicationLogFile
{ {
get { return Path.Combine(LogFolderPath, $"{LogFileDate}_Application.txt"); } get { return Path.Combine(LogFolderPath, $"{RuntimeIdentifier}_Application.txt"); }
} }
public string BrowserLogFile public IBrowserSettings Browser { get; private set; }
{
get { return Path.Combine(LogFolderPath, $"{LogFileDate}_Browser.txt"); }
}
public string BrowserCachePath
{
get { return Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.ApplicationData), AppDataFolder, "Cache"); }
}
public string LogFolderPath public string LogFolderPath
{ {
get { return Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.ApplicationData), AppDataFolder, "Logs"); } get { return Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.ApplicationData), AppDataFolderName, "Logs"); }
} }
public string ProgramCopyright public string ProgramCopyright
@ -70,5 +72,7 @@ namespace SafeExamBrowser.Configuration
return version; return version;
} }
} }
public string RuntimeIdentifier => LogFileDate;
} }
} }

View file

@ -0,0 +1,53 @@
/*
* Copyright (c) 2017 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.Contracts.Configuration.Settings
{
public interface IBrowserSettings
{
/// <summary>
/// Determines whether the user should be allowed to change the URL of a browser window.
/// </summary>
bool AllowAddressBar { get; }
/// <summary>
/// Determines whether the user should be allowed to navigate backwards in a browser window.
/// </summary>
bool AllowBackwardNavigation { get; }
/// <summary>
/// Determines whether the user should be allowed to open the debug console of a browser window.
/// </summary>
bool AllowDebugConsole { get; }
/// <summary>
/// Determines whether the user should be allowed to navigate forwards in a browser window.
/// </summary>
bool AllowForwardNavigation { get; }
/// <summary>
/// Determines whether the user should be allowed to reload webpages.
/// </summary>
bool AllowReloading { get; }
/// <summary>
/// The path where the browser cache is to be stored.
/// </summary>
string CachePath { get; }
/// <summary>
/// The file path under which the browser log is to be stored.
/// </summary>
string LogFile { get; }
/// <summary>
/// Determines whether the main browser window should be rendered in fullscreen mode, i.e. without window frame.
/// </summary>
bool FullScreenMode { get; }
}
}

View file

@ -6,24 +6,24 @@
* file, You can obtain one at http://mozilla.org/MPL/2.0/. * file, You can obtain one at http://mozilla.org/MPL/2.0/.
*/ */
namespace SafeExamBrowser.Contracts.Configuration namespace SafeExamBrowser.Contracts.Configuration.Settings
{ {
public interface ISettings public interface ISettings
{ {
/// <summary>
/// The name used for the application data folder.
/// </summary>
string AppDataFolderName { get; }
/// <summary> /// <summary>
/// The file path under which the application log is to be stored. /// The file path under which the application log is to be stored.
/// </summary> /// </summary>
string ApplicationLogFile { get; } string ApplicationLogFile { get; }
/// <summary> /// <summary>
/// The path where the browser cache is to be stored. /// All browser-related settings.
/// </summary> /// </summary>
string BrowserCachePath { get; } IBrowserSettings Browser { get; }
/// <summary>
/// The file path under which the browser log is to be stored.
/// </summary>
string BrowserLogFile { get; }
/// <summary> /// <summary>
/// The path where the log files are to be stored. /// The path where the log files are to be stored.
@ -44,5 +44,10 @@ namespace SafeExamBrowser.Contracts.Configuration
/// The program version of the application (i.e. the executing assembly). /// The program version of the application (i.e. the executing assembly).
/// </summary> /// </summary>
string ProgramVersion { get; } string ProgramVersion { get; }
/// <summary>
/// A string uniquely identifying the runtime of the application, used e.g. for the log file names.
/// </summary>
string RuntimeIdentifier { get; }
} }
} }

View file

@ -66,7 +66,8 @@
<Compile Include="Configuration\IApplicationInfo.cs" /> <Compile Include="Configuration\IApplicationInfo.cs" />
<Compile Include="Configuration\IApplicationInstance.cs" /> <Compile Include="Configuration\IApplicationInstance.cs" />
<Compile Include="Configuration\INotificationInfo.cs" /> <Compile Include="Configuration\INotificationInfo.cs" />
<Compile Include="Configuration\ISettings.cs" /> <Compile Include="Configuration\Settings\IBrowserSettings.cs" />
<Compile Include="Configuration\Settings\ISettings.cs" />
<Compile Include="Behaviour\IShutdownController.cs" /> <Compile Include="Behaviour\IShutdownController.cs" />
<Compile Include="Behaviour\IStartupController.cs" /> <Compile Include="Behaviour\IStartupController.cs" />
<Compile Include="Configuration\IWorkingArea.cs" /> <Compile Include="Configuration\IWorkingArea.cs" />

View file

@ -7,6 +7,7 @@
*/ */
using SafeExamBrowser.Contracts.Configuration; using SafeExamBrowser.Contracts.Configuration;
using SafeExamBrowser.Contracts.Configuration.Settings;
using SafeExamBrowser.Contracts.I18n; using SafeExamBrowser.Contracts.I18n;
namespace SafeExamBrowser.Contracts.UserInterface namespace SafeExamBrowser.Contracts.UserInterface
@ -21,7 +22,7 @@ namespace SafeExamBrowser.Contracts.UserInterface
/// <summary> /// <summary>
/// Creates a new browser window loaded with the given browser control. /// Creates a new browser window loaded with the given browser control.
/// </summary> /// </summary>
IBrowserWindow CreateBrowserWindow(IBrowserControl control); IBrowserWindow CreateBrowserWindow(IBrowserControl control, IBrowserSettings settings);
/// <summary> /// <summary>
/// Creates a taskbar notification, initialized with the given notification information. /// Creates a taskbar notification, initialized with the given notification information.

View file

@ -10,7 +10,7 @@ using System.Collections.Generic;
using Microsoft.VisualStudio.TestTools.UnitTesting; using Microsoft.VisualStudio.TestTools.UnitTesting;
using Moq; using Moq;
using SafeExamBrowser.Contracts.Behaviour; using SafeExamBrowser.Contracts.Behaviour;
using SafeExamBrowser.Contracts.Configuration; using SafeExamBrowser.Contracts.Configuration.Settings;
using SafeExamBrowser.Contracts.I18n; using SafeExamBrowser.Contracts.I18n;
using SafeExamBrowser.Contracts.Logging; using SafeExamBrowser.Contracts.Logging;
using SafeExamBrowser.Contracts.UserInterface; using SafeExamBrowser.Contracts.UserInterface;

View file

@ -11,7 +11,7 @@ using System.Collections.Generic;
using Microsoft.VisualStudio.TestTools.UnitTesting; using Microsoft.VisualStudio.TestTools.UnitTesting;
using Moq; using Moq;
using SafeExamBrowser.Contracts.Behaviour; using SafeExamBrowser.Contracts.Behaviour;
using SafeExamBrowser.Contracts.Configuration; using SafeExamBrowser.Contracts.Configuration.Settings;
using SafeExamBrowser.Contracts.I18n; using SafeExamBrowser.Contracts.I18n;
using SafeExamBrowser.Contracts.Logging; using SafeExamBrowser.Contracts.Logging;
using SafeExamBrowser.Contracts.UserInterface; using SafeExamBrowser.Contracts.UserInterface;

View file

@ -9,7 +9,7 @@
using System; using System;
using System.Collections.Generic; using System.Collections.Generic;
using SafeExamBrowser.Contracts.Behaviour; using SafeExamBrowser.Contracts.Behaviour;
using SafeExamBrowser.Contracts.Configuration; using SafeExamBrowser.Contracts.Configuration.Settings;
using SafeExamBrowser.Contracts.I18n; using SafeExamBrowser.Contracts.I18n;
using SafeExamBrowser.Contracts.Logging; using SafeExamBrowser.Contracts.Logging;
using SafeExamBrowser.Contracts.UserInterface; using SafeExamBrowser.Contracts.UserInterface;

View file

@ -10,7 +10,7 @@ using System;
using System.Collections.Generic; using System.Collections.Generic;
using System.Linq; using System.Linq;
using SafeExamBrowser.Contracts.Behaviour; using SafeExamBrowser.Contracts.Behaviour;
using SafeExamBrowser.Contracts.Configuration; using SafeExamBrowser.Contracts.Configuration.Settings;
using SafeExamBrowser.Contracts.I18n; using SafeExamBrowser.Contracts.I18n;
using SafeExamBrowser.Contracts.Logging; using SafeExamBrowser.Contracts.Logging;
using SafeExamBrowser.Contracts.UserInterface; using SafeExamBrowser.Contracts.UserInterface;

View file

@ -8,7 +8,7 @@
using System.IO; using System.IO;
using System.Text; using System.Text;
using SafeExamBrowser.Contracts.Configuration; using SafeExamBrowser.Contracts.Configuration.Settings;
using SafeExamBrowser.Contracts.Logging; using SafeExamBrowser.Contracts.Logging;
namespace SafeExamBrowser.Core.Logging namespace SafeExamBrowser.Core.Logging

View file

@ -7,20 +7,25 @@
*/ */
using System.Windows; using System.Windows;
using SafeExamBrowser.Contracts.Configuration.Settings;
using SafeExamBrowser.Contracts.UserInterface; using SafeExamBrowser.Contracts.UserInterface;
namespace SafeExamBrowser.UserInterface namespace SafeExamBrowser.UserInterface
{ {
public partial class BrowserWindow : Window, IBrowserWindow public partial class BrowserWindow : Window, IBrowserWindow
{ {
public BrowserWindow(IBrowserControl browserControl) private IBrowserSettings settings;
public event WindowCloseHandler OnClose;
public BrowserWindow(IBrowserControl browserControl, IBrowserSettings settings)
{ {
this.settings = settings;
InitializeComponent(); InitializeComponent();
InitializeBrowserWindow(browserControl); InitializeBrowserWindow(browserControl);
} }
public event WindowCloseHandler OnClose;
public void BringToForeground() public void BringToForeground()
{ {
if (WindowState == WindowState.Minimized) if (WindowState == WindowState.Minimized)
@ -38,6 +43,18 @@ namespace SafeExamBrowser.UserInterface
BrowserControlHost.Child = browserControl as System.Windows.Forms.Control; BrowserControlHost.Child = browserControl as System.Windows.Forms.Control;
} }
UrlTextBox.IsEnabled = settings.AllowAddressBar;
UrlTextBox.Visibility = settings.AllowAddressBar ? Visibility.Visible : Visibility.Collapsed;
ReloadButton.IsEnabled = settings.AllowReloading;
ReloadButton.Visibility = settings.AllowReloading ? Visibility.Visible : Visibility.Collapsed;
BackButton.IsEnabled = settings.AllowBackwardNavigation;
BackButton.Visibility = settings.AllowBackwardNavigation ? Visibility.Visible : Visibility.Collapsed;
ForwardButton.IsEnabled = settings.AllowForwardNavigation;
ForwardButton.Visibility = settings.AllowForwardNavigation ? Visibility.Visible : Visibility.Collapsed;
Closing += (o, args) => OnClose?.Invoke(); Closing += (o, args) => OnClose?.Invoke();
} }
} }

View file

@ -20,6 +20,7 @@ namespace SafeExamBrowser.UserInterface.Controls
private IApplicationInstance instance; private IApplicationInstance instance;
public delegate void OnClickHandler(Guid instanceId); public delegate void OnClickHandler(Guid instanceId);
public event OnClickHandler Click; public event OnClickHandler Click;
public ApplicationInstanceButton(IApplicationInstance instance, IApplicationInfo info) public ApplicationInstanceButton(IApplicationInstance instance, IApplicationInfo info)

View file

@ -8,7 +8,7 @@
using System.Windows; using System.Windows;
using System.Windows.Documents; using System.Windows.Documents;
using SafeExamBrowser.Contracts.Configuration; using SafeExamBrowser.Contracts.Configuration.Settings;
using SafeExamBrowser.Contracts.I18n; using SafeExamBrowser.Contracts.I18n;
using SafeExamBrowser.Contracts.UserInterface; using SafeExamBrowser.Contracts.UserInterface;
using SafeExamBrowser.UserInterface.ViewModels; using SafeExamBrowser.UserInterface.ViewModels;

View file

@ -9,6 +9,7 @@
using System.Threading; using System.Threading;
using System.Windows; using System.Windows;
using SafeExamBrowser.Contracts.Configuration; using SafeExamBrowser.Contracts.Configuration;
using SafeExamBrowser.Contracts.Configuration.Settings;
using SafeExamBrowser.Contracts.I18n; using SafeExamBrowser.Contracts.I18n;
using SafeExamBrowser.Contracts.UserInterface; using SafeExamBrowser.Contracts.UserInterface;
using SafeExamBrowser.UserInterface.Controls; using SafeExamBrowser.UserInterface.Controls;
@ -22,9 +23,9 @@ namespace SafeExamBrowser.UserInterface
return new ApplicationButton(info); return new ApplicationButton(info);
} }
public IBrowserWindow CreateBrowserWindow(IBrowserControl control) public IBrowserWindow CreateBrowserWindow(IBrowserControl control, IBrowserSettings settings)
{ {
return new BrowserWindow(control); return new BrowserWindow(control, settings);
} }
public ITaskbarNotification CreateNotification(INotificationInfo info) public ITaskbarNotification CreateNotification(INotificationInfo info)

View file

@ -16,6 +16,10 @@ namespace SafeExamBrowser.UserInterface.ViewModels
{ {
private Timer timer; private Timer timer;
public string Date { get; private set; }
public string Time { get; private set; }
public string ToolTip { get; private set; }
public event PropertyChangedEventHandler PropertyChanged; public event PropertyChangedEventHandler PropertyChanged;
public DateTimeViewModel() public DateTimeViewModel()
@ -25,10 +29,6 @@ namespace SafeExamBrowser.UserInterface.ViewModels
timer.Start(); timer.Start();
} }
public string Date { get; private set; }
public string Time { get; private set; }
public string ToolTip { get; private set; }
private void Timer_Elapsed(object sender, ElapsedEventArgs e) private void Timer_Elapsed(object sender, ElapsedEventArgs e)
{ {
var date = DateTime.Now; var date = DateTime.Now;

View file

@ -17,7 +17,7 @@ namespace SafeExamBrowser
{ {
public class App : Application public class App : Application
{ {
private static readonly Mutex mutex = new Mutex(true, "safe_exam_browser_single_instance_mutex"); private static readonly Mutex Mutex = new Mutex(true, "safe_exam_browser_single_instance_mutex");
private CompositionRoot instances = new CompositionRoot(); private CompositionRoot instances = new CompositionRoot();
[STAThread] [STAThread]
@ -33,7 +33,7 @@ namespace SafeExamBrowser
} }
finally finally
{ {
mutex.Close(); Mutex.Close();
} }
} }
@ -51,7 +51,7 @@ namespace SafeExamBrowser
private static bool NoInstanceRunning() private static bool NoInstanceRunning()
{ {
return mutex.WaitOne(TimeSpan.Zero, true); return Mutex.WaitOne(TimeSpan.Zero, true);
} }
protected override void OnStartup(StartupEventArgs e) protected override void OnStartup(StartupEventArgs e)

View file

@ -11,6 +11,7 @@ using SafeExamBrowser.Browser;
using SafeExamBrowser.Configuration; using SafeExamBrowser.Configuration;
using SafeExamBrowser.Contracts.Behaviour; using SafeExamBrowser.Contracts.Behaviour;
using SafeExamBrowser.Contracts.Configuration; using SafeExamBrowser.Contracts.Configuration;
using SafeExamBrowser.Contracts.Configuration.Settings;
using SafeExamBrowser.Contracts.I18n; using SafeExamBrowser.Contracts.I18n;
using SafeExamBrowser.Contracts.Logging; using SafeExamBrowser.Contracts.Logging;
using SafeExamBrowser.Contracts.Monitoring; using SafeExamBrowser.Contracts.Monitoring;
@ -53,7 +54,7 @@ namespace SafeExamBrowser
browserInfo = new BrowserApplicationInfo(); browserInfo = new BrowserApplicationInfo();
logger = new Logger(); logger = new Logger();
nativeMethods = new NativeMethods(); nativeMethods = new NativeMethods();
settings = new Settings(); settings = new SettingsImpl();
Taskbar = new Taskbar(); Taskbar = new Taskbar();
textResource = new XmlTextResource(); textResource = new XmlTextResource();
uiFactory = new UserInterfaceFactory(); uiFactory = new UserInterfaceFactory();