2019-07-16 14:39:59 +02:00
|
|
|
|
/*
|
|
|
|
|
* 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/.
|
|
|
|
|
*/
|
|
|
|
|
|
2019-07-17 16:17:20 +02:00
|
|
|
|
|
2019-07-16 14:39:59 +02:00
|
|
|
|
using System;
|
2019-07-17 16:17:20 +02:00
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
using System.IO;
|
|
|
|
|
using System.Linq;
|
|
|
|
|
using SafeExamBrowser.Contracts.Configuration;
|
|
|
|
|
using SafeExamBrowser.Contracts.Lockdown;
|
2019-07-16 14:39:59 +02:00
|
|
|
|
|
|
|
|
|
namespace SafeExamBrowser.ResetUtility.Procedure
|
|
|
|
|
{
|
|
|
|
|
internal class Restore : ProcedureStep
|
|
|
|
|
{
|
2019-07-17 16:17:20 +02:00
|
|
|
|
private ProcedureStep next;
|
|
|
|
|
|
2019-07-18 10:36:41 +02:00
|
|
|
|
public Restore(ProcedureContext context) : base(context)
|
2019-07-16 14:39:59 +02:00
|
|
|
|
{
|
2019-07-17 16:17:20 +02:00
|
|
|
|
next = new MainMenu(Context);
|
2019-07-16 14:39:59 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
internal override ProcedureStepResult Execute()
|
|
|
|
|
{
|
2019-07-17 16:17:20 +02:00
|
|
|
|
var filePath = $@"config\systemprofile\AppData\Local\{nameof(SafeExamBrowser)}\{AppConfig.BACKUP_FILE_NAME}";
|
|
|
|
|
var x86FilePath = Environment.ExpandEnvironmentVariables($@"%WINDIR%\system32\{filePath}");
|
|
|
|
|
var x64FilePath = Environment.ExpandEnvironmentVariables($@"%WINDIR%\SysWOW64\{filePath}");
|
|
|
|
|
|
|
|
|
|
InitializeConsole();
|
|
|
|
|
|
|
|
|
|
Logger.Info("Searching backup file...");
|
|
|
|
|
Logger.Debug($"x86 path => {x86FilePath}");
|
|
|
|
|
Logger.Debug($"x64 path => {x64FilePath}");
|
|
|
|
|
Console.WriteLine("Searching backup file...");
|
|
|
|
|
|
|
|
|
|
if (File.Exists(x86FilePath))
|
|
|
|
|
{
|
|
|
|
|
RestoreBackup(x86FilePath);
|
|
|
|
|
}
|
|
|
|
|
else if (File.Exists(x64FilePath))
|
|
|
|
|
{
|
|
|
|
|
RestoreBackup(x64FilePath);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
HandleNoBackupFile();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return ProcedureStepResult.Continue;
|
2019-07-16 14:39:59 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
internal override ProcedureStep GetNextStep()
|
|
|
|
|
{
|
2019-07-17 16:17:20 +02:00
|
|
|
|
return next;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void RestoreBackup(string filePath)
|
|
|
|
|
{
|
|
|
|
|
var backup = Context.CreateBackup(filePath);
|
|
|
|
|
var configurations = backup.GetAllConfigurations();
|
|
|
|
|
var failed = new List<IFeatureConfiguration>();
|
|
|
|
|
|
|
|
|
|
Logger.Info($"Found backup file '{filePath}' with {configurations.Count} items. Initiating restore procedure...");
|
|
|
|
|
Console.WriteLine($"Found backup file with {configurations.Count} items.");
|
2019-07-18 10:36:41 +02:00
|
|
|
|
Console.WriteLine();
|
2019-07-17 16:17:20 +02:00
|
|
|
|
Console.WriteLine("Initiating restore procedure...");
|
|
|
|
|
|
|
|
|
|
foreach (var configuration in configurations)
|
|
|
|
|
{
|
|
|
|
|
var success = configuration.Restore();
|
|
|
|
|
|
|
|
|
|
if (success)
|
|
|
|
|
{
|
|
|
|
|
backup.Delete(configuration);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
failed.Add(configuration);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
ShowProgress(configurations.IndexOf(configuration) + 1, configurations.Count);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
PerformUpdate();
|
|
|
|
|
|
|
|
|
|
if (failed.Any())
|
|
|
|
|
{
|
|
|
|
|
HandleFailure(failed);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
HandleSuccess();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Console.WriteLine();
|
|
|
|
|
Console.WriteLine("Press any key to return to the main menu.");
|
|
|
|
|
Console.ReadKey();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void PerformUpdate()
|
|
|
|
|
{
|
|
|
|
|
Logger.Info("Starting system configuration update...");
|
|
|
|
|
Console.WriteLine();
|
|
|
|
|
Console.WriteLine("Performing system configuration update, please wait...");
|
2019-07-18 10:36:41 +02:00
|
|
|
|
StartProgressAnimation();
|
2019-07-17 16:17:20 +02:00
|
|
|
|
Context.Update.Execute();
|
2019-07-18 10:36:41 +02:00
|
|
|
|
StopProgressAnimation();
|
2019-07-17 16:17:20 +02:00
|
|
|
|
Logger.Info("Update completed.");
|
|
|
|
|
Console.WriteLine("Update completed.");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void HandleFailure(IList<IFeatureConfiguration> configurations)
|
|
|
|
|
{
|
|
|
|
|
Logger.Warn($"Failed to restore {configurations.Count} items!");
|
|
|
|
|
Console.WriteLine();
|
|
|
|
|
Console.ForegroundColor = ConsoleColor.Red;
|
|
|
|
|
Console.WriteLine($"Failed to restore {configurations.Count} items!");
|
|
|
|
|
|
|
|
|
|
foreach (var configuration in configurations)
|
|
|
|
|
{
|
|
|
|
|
Console.WriteLine($" - {configuration.GetType().Name}");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Console.ForegroundColor = ForegroundColor;
|
|
|
|
|
Console.WriteLine();
|
|
|
|
|
Console.WriteLine("Some configuration values may be user specific. In order to restore these values, the user who used SEB needs to be logged in.");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void HandleSuccess()
|
|
|
|
|
{
|
|
|
|
|
Logger.Info("Successfully restored all changes!");
|
|
|
|
|
Console.WriteLine();
|
|
|
|
|
Console.ForegroundColor = ConsoleColor.DarkGreen;
|
|
|
|
|
Console.WriteLine("Successfully restored all changes!");
|
|
|
|
|
Console.ForegroundColor = ForegroundColor;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void HandleNoBackupFile()
|
|
|
|
|
{
|
|
|
|
|
var yes = new MenuOption { IsSelected = true, Text = "Yes" };
|
|
|
|
|
var no = new MenuOption { Text = "No" };
|
|
|
|
|
|
|
|
|
|
Logger.Warn("Could not find any backup file!");
|
|
|
|
|
|
|
|
|
|
Console.ForegroundColor = ConsoleColor.DarkYellow;
|
|
|
|
|
Console.WriteLine("Could not find any backup file!");
|
|
|
|
|
Console.ForegroundColor = ForegroundColor;
|
|
|
|
|
Console.WriteLine();
|
|
|
|
|
Console.WriteLine("Would you like to reset all configuration values possibly changed by SEB?");
|
|
|
|
|
|
|
|
|
|
ShowMenu(new List<MenuOption> { yes, no });
|
|
|
|
|
|
|
|
|
|
if (yes.IsSelected)
|
|
|
|
|
{
|
|
|
|
|
next = new Reset(Context);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Logger.Info($"The user chose {(yes.IsSelected ? "" : "not ")}to perform a reset for now.");
|
2019-07-16 14:39:59 +02:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|