/* * 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.Collections.Generic; using System.Linq; using System.Threading; using SafeExamBrowser.Contracts.Behaviour; using SafeExamBrowser.Contracts.Configuration; using SafeExamBrowser.Contracts.I18n; using SafeExamBrowser.Contracts.Logging; using SafeExamBrowser.Contracts.UserInterface; namespace SafeExamBrowser.Core.Behaviour { public class StartupController : IStartupController { private IApplicationController browserController; private IApplicationInfo browserInfo; private ILogger logger; private IMessageBox messageBox; private ISettings settings; private ISplashScreen splashScreen; private ITaskbar taskbar; private IText text; private IUiElementFactory uiFactory; private IEnumerable StartupOperations { get { yield return HandleCommandLineArguments; yield return DetectOperatingSystem; yield return EstablishWcfServiceConnection; yield return DeactivateWindowsFeatures; yield return InitializeProcessMonitoring; yield return InitializeWorkArea; yield return InitializeTaskbar; yield return InitializeBrowser; yield return FinishInitialization; } } public StartupController( IApplicationController browserController, IApplicationInfo browserInfo, ILogger logger, IMessageBox messageBox, ISettings settings, ISplashScreen splashScreen, ITaskbar taskbar, IText text, IUiElementFactory uiFactory) { this.browserController = browserController ?? throw new ArgumentNullException(nameof(browserController)); this.browserInfo = browserInfo ?? throw new ArgumentNullException(nameof(browserInfo)); this.logger = logger ?? throw new ArgumentNullException(nameof(logger)); ; this.messageBox = messageBox ?? throw new ArgumentNullException(nameof(messageBox)); ; this.settings = settings ?? throw new ArgumentNullException(nameof(settings)); ; this.splashScreen = splashScreen ?? throw new ArgumentNullException(nameof(splashScreen)); ; this.taskbar = taskbar ?? throw new ArgumentNullException(nameof(taskbar)); ; this.text = text ?? throw new ArgumentNullException(nameof(text)); ; this.uiFactory = uiFactory ?? throw new ArgumentNullException(nameof(uiFactory)); ; } public bool TryInitializeApplication() { try { InitializeApplicationLog(); InitializeSplashScreen(); foreach (var operation in StartupOperations) { operation(); splashScreen.UpdateProgress(); // TODO: Remove! Thread.Sleep(250); } return true; } catch (Exception e) { logger.Error($"Failed to initialize application!", e); messageBox.Show(text.Get(Key.MessageBox_StartupError), text.Get(Key.MessageBox_StartupErrorTitle), icon: MessageBoxIcon.Error); return false; } } private void InitializeApplicationLog() { var titleLine = $"/* {settings.ProgramTitle}, Version {settings.ProgramVersion}{Environment.NewLine}"; var copyrightLine = $"/* {settings.ProgramCopyright}{Environment.NewLine}"; var emptyLine = $"/* {Environment.NewLine}"; var githubLine = $"/* Please visit https://github.com/SafeExamBrowser for more information."; logger.Log($"{titleLine}{copyrightLine}{emptyLine}{githubLine}"); logger.Log($"{Environment.NewLine}# Application started at {DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff")}{Environment.NewLine}"); logger.Info("Initiating startup procedure."); } private void InitializeSplashScreen() { splashScreen.SetMaxProgress(StartupOperations.Count()); splashScreen.UpdateText(Key.SplashScreen_StartupProcedure); } private void HandleCommandLineArguments() { logger.Info("Parsing command line arguments."); // TODO } private void DetectOperatingSystem() { logger.Info("Detecting operating system."); // TODO } private void EstablishWcfServiceConnection() { logger.Info("Establishing connection to WCF service."); // TODO } private void DeactivateWindowsFeatures() { logger.Info("Deactivating Windows Update."); // TODO logger.Info("Disabling lock screen options."); // TODO } private void InitializeProcessMonitoring() { logger.Info("Initializing process monitoring."); // TODO } private void InitializeWorkArea() { logger.Info("Initializing work area."); // TODO // - Killing explorer.exe // - Minimizing all open windows // - Emptying clipboard } private void InitializeTaskbar() { logger.Info("Initializing taskbar."); // TODO } private void InitializeBrowser() { logger.Info("Initializing browser."); splashScreen.UpdateText(Key.SplashScreen_InitializeBrowser); var browserButton = uiFactory.CreateApplicationButton(browserInfo); browserController.RegisterApplicationButton(browserButton); // TODO taskbar.AddButton(browserButton); } private void FinishInitialization() { logger.Info("Application successfully initialized!"); } } }