SEBWIN-414: Implemented new mechanism to allow or deny reconfiguration.
This commit is contained in:
parent
8a385a55d0
commit
252e807c44
15 changed files with 1185 additions and 953 deletions
|
@ -27,5 +27,10 @@ namespace SafeExamBrowser.Browser.Contracts.Events
|
|||
/// The full path under which the specified file should be saved.
|
||||
/// </summary>
|
||||
public string DownloadPath { get; set; }
|
||||
|
||||
/// <summary>
|
||||
/// The URL of the resource to be downloaded.
|
||||
/// </summary>
|
||||
public string Url { get; set; }
|
||||
}
|
||||
}
|
||||
|
|
|
@ -137,7 +137,7 @@ namespace SafeExamBrowser.Browser.Handlers
|
|||
|
||||
private void RequestConfigurationFileDownload(DownloadItem downloadItem, IBeforeDownloadCallback callback)
|
||||
{
|
||||
var args = new DownloadEventArgs();
|
||||
var args = new DownloadEventArgs { Url = downloadItem.Url };
|
||||
|
||||
logger.Debug($"Handling download of configuration file '{downloadItem.SuggestedFileName}'.");
|
||||
ConfigurationDownloadRequested?.Invoke(downloadItem.SuggestedFileName, args);
|
||||
|
|
|
@ -610,18 +610,87 @@ namespace SafeExamBrowser.Client.UnitTests
|
|||
}
|
||||
|
||||
[TestMethod]
|
||||
public void Reconfiguration_MustDenyIfInExamMode()
|
||||
public void Reconfiguration_MustAllowIfNoQuitPasswordSet()
|
||||
{
|
||||
settings.ConfigurationMode = ConfigurationMode.Exam;
|
||||
messageBox.Setup(m => m.Show(
|
||||
It.IsAny<TextKey>(),
|
||||
It.IsAny<TextKey>(),
|
||||
It.IsAny<MessageBoxAction>(),
|
||||
It.IsAny<MessageBoxIcon>(),
|
||||
It.IsAny<IWindow>())).Returns(MessageBoxResult.Ok);
|
||||
var args = new DownloadEventArgs();
|
||||
|
||||
appConfig.TemporaryDirectory = @"C:\Folder\Does\Not\Exist";
|
||||
runtimeProxy.Setup(r => r.RequestReconfiguration(It.IsAny<string>())).Returns(new CommunicationResult(true));
|
||||
|
||||
sut.TryStart();
|
||||
browser.Raise(b => b.ConfigurationDownloadRequested += null, "filepath.seb", new DownloadEventArgs());
|
||||
browser.Raise(b => b.ConfigurationDownloadRequested += null, "filepath.seb", args);
|
||||
args.Callback(true, string.Empty);
|
||||
|
||||
runtimeProxy.Verify(r => r.RequestReconfiguration(It.IsAny<string>()), Times.Once);
|
||||
Assert.IsTrue(args.AllowDownload);
|
||||
}
|
||||
|
||||
[TestMethod]
|
||||
public void Reconfiguration_MustAllowWithQuitPasswordAndNoUrl()
|
||||
{
|
||||
var args = new DownloadEventArgs();
|
||||
|
||||
appConfig.TemporaryDirectory = @"C:\Folder\Does\Not\Exist";
|
||||
settings.Security.AllowReconfiguration = true;
|
||||
settings.Security.QuitPasswordHash = "abc123";
|
||||
runtimeProxy.Setup(r => r.RequestReconfiguration(It.IsAny<string>())).Returns(new CommunicationResult(true));
|
||||
|
||||
sut.TryStart();
|
||||
browser.Raise(b => b.ConfigurationDownloadRequested += null, "filepath.seb", args);
|
||||
args.Callback(true, string.Empty);
|
||||
|
||||
runtimeProxy.Verify(r => r.RequestReconfiguration(It.IsAny<string>()), Times.Once);
|
||||
Assert.IsTrue(args.AllowDownload);
|
||||
}
|
||||
|
||||
[TestMethod]
|
||||
public void Reconfiguration_MustAllowIfUrlMatches()
|
||||
{
|
||||
var args = new DownloadEventArgs { Url = "sebs://www.somehost.org/some/path/some_configuration.seb?query=123" };
|
||||
|
||||
appConfig.TemporaryDirectory = @"C:\Folder\Does\Not\Exist";
|
||||
settings.Security.AllowReconfiguration = true;
|
||||
settings.Security.QuitPasswordHash = "abc123";
|
||||
settings.Security.ReconfigurationUrl = "sebs://www.somehost.org/some/path/*.seb?query=123";
|
||||
runtimeProxy.Setup(r => r.RequestReconfiguration(It.IsAny<string>())).Returns(new CommunicationResult(true));
|
||||
|
||||
sut.TryStart();
|
||||
browser.Raise(b => b.ConfigurationDownloadRequested += null, "filepath.seb", args);
|
||||
args.Callback(true, string.Empty);
|
||||
|
||||
runtimeProxy.Verify(r => r.RequestReconfiguration(It.IsAny<string>()), Times.Once);
|
||||
Assert.IsTrue(args.AllowDownload);
|
||||
}
|
||||
|
||||
[TestMethod]
|
||||
public void Reconfiguration_MustDenyIfNotAllowed()
|
||||
{
|
||||
var args = new DownloadEventArgs();
|
||||
|
||||
settings.Security.AllowReconfiguration = false;
|
||||
settings.Security.QuitPasswordHash = "abc123";
|
||||
|
||||
sut.TryStart();
|
||||
browser.Raise(b => b.ConfigurationDownloadRequested += null, "filepath.seb", args);
|
||||
|
||||
runtimeProxy.Verify(r => r.RequestReconfiguration(It.IsAny<string>()), Times.Never);
|
||||
Assert.IsFalse(args.AllowDownload);
|
||||
}
|
||||
|
||||
[TestMethod]
|
||||
public void Reconfiguration_MustDenyIfUrlDoesNotMatch()
|
||||
{
|
||||
var args = new DownloadEventArgs { Url = "sebs://www.somehost.org/some/path/some_configuration.seb?query=123" };
|
||||
|
||||
settings.Security.AllowReconfiguration = false;
|
||||
settings.Security.QuitPasswordHash = "abc123";
|
||||
settings.Security.ReconfigurationUrl = "sebs://www.somehost.org/some/path/other_configuration.seb?query=123";
|
||||
|
||||
sut.TryStart();
|
||||
browser.Raise(b => b.ConfigurationDownloadRequested += null, "filepath.seb", args);
|
||||
|
||||
runtimeProxy.Verify(r => r.RequestReconfiguration(It.IsAny<string>()), Times.Never);
|
||||
Assert.IsFalse(args.AllowDownload);
|
||||
}
|
||||
|
||||
[TestMethod]
|
||||
|
|
|
@ -10,6 +10,7 @@ using System;
|
|||
using System.Collections.Generic;
|
||||
using System.IO;
|
||||
using System.Linq;
|
||||
using System.Text.RegularExpressions;
|
||||
using System.Threading;
|
||||
using SafeExamBrowser.Applications.Contracts;
|
||||
using SafeExamBrowser.Browser.Contracts;
|
||||
|
@ -330,7 +331,26 @@ namespace SafeExamBrowser.Client
|
|||
|
||||
private void Browser_ConfigurationDownloadRequested(string fileName, DownloadEventArgs args)
|
||||
{
|
||||
if (Settings.Security.AllowReconfiguration)
|
||||
var allow = true;
|
||||
var hasQuitPassword = !string.IsNullOrWhiteSpace(Settings.Security.QuitPasswordHash);
|
||||
var hasUrl = !string.IsNullOrWhiteSpace(Settings.Security.ReconfigurationUrl);
|
||||
|
||||
if (hasQuitPassword)
|
||||
{
|
||||
if (hasUrl)
|
||||
{
|
||||
var expression = Regex.Escape(Settings.Security.ReconfigurationUrl).Replace(@"\*", ".*");
|
||||
var regex = new Regex($"^{expression}$", RegexOptions.IgnoreCase);
|
||||
|
||||
allow = Settings.Security.AllowReconfiguration && regex.IsMatch(args.Url);
|
||||
}
|
||||
else
|
||||
{
|
||||
allow = Settings.Security.AllowReconfiguration;
|
||||
}
|
||||
}
|
||||
|
||||
if (allow)
|
||||
{
|
||||
args.AllowDownload = true;
|
||||
args.Callback = Browser_ConfigurationDownloadFinished;
|
||||
|
|
|
@ -29,19 +29,27 @@ namespace SafeExamBrowser.Configuration.UnitTests.ConfigurationData
|
|||
}
|
||||
|
||||
[TestMethod]
|
||||
public void MustAllowReconfigurationAccordingToMode()
|
||||
public void MustAllowBrowserToolbarForReloading()
|
||||
{
|
||||
var settings1 = new AppSettings { ConfigurationMode = ConfigurationMode.ConfigureClient };
|
||||
var settings2 = new AppSettings { ConfigurationMode = ConfigurationMode.Exam };
|
||||
var raw = new Dictionary<string, object>();
|
||||
var settings = new AppSettings();
|
||||
|
||||
settings1.Security.AllowReconfiguration = false;
|
||||
settings2.Security.AllowReconfiguration = true;
|
||||
raw.Add(Keys.Browser.ShowReloadButton, true);
|
||||
settings.Browser.AdditionalWindow.AllowReloading = false;
|
||||
settings.Browser.MainWindow.AllowReloading = false;
|
||||
|
||||
sut.Process(new Dictionary<string, object>(), settings1);
|
||||
sut.Process(new Dictionary<string, object>(), settings2);
|
||||
sut.Process(raw, settings);
|
||||
|
||||
Assert.IsTrue(settings1.Security.AllowReconfiguration);
|
||||
Assert.IsFalse(settings2.Security.AllowReconfiguration);
|
||||
Assert.IsFalse(settings.Browser.AdditionalWindow.ShowToolbar);
|
||||
Assert.IsFalse(settings.Browser.MainWindow.ShowToolbar);
|
||||
|
||||
settings.Browser.AdditionalWindow.AllowReloading = true;
|
||||
settings.Browser.MainWindow.AllowReloading = true;
|
||||
|
||||
sut.Process(raw, settings);
|
||||
|
||||
Assert.IsTrue(settings.Browser.AdditionalWindow.ShowToolbar);
|
||||
Assert.IsTrue(settings.Browser.MainWindow.ShowToolbar);
|
||||
}
|
||||
|
||||
[TestMethod]
|
||||
|
|
|
@ -21,6 +21,9 @@ namespace SafeExamBrowser.Configuration.ConfigurationData.DataMapping
|
|||
case Keys.Security.AdminPasswordHash:
|
||||
MapAdminPasswordHash(settings, value);
|
||||
break;
|
||||
case Keys.Security.AllowReconfiguration:
|
||||
MapAllowReconfiguration(settings, value);
|
||||
break;
|
||||
case Keys.Security.AllowTermination:
|
||||
MapAllowTermination(settings, value);
|
||||
break;
|
||||
|
@ -30,6 +33,9 @@ namespace SafeExamBrowser.Configuration.ConfigurationData.DataMapping
|
|||
case Keys.Security.QuitPasswordHash:
|
||||
MapQuitPasswordHash(settings, value);
|
||||
break;
|
||||
case Keys.Security.ReconfigurationUrl:
|
||||
MapReconfigurationUrl(settings, value);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -47,6 +53,14 @@ namespace SafeExamBrowser.Configuration.ConfigurationData.DataMapping
|
|||
}
|
||||
}
|
||||
|
||||
private void MapAllowReconfiguration(AppSettings settings, object value)
|
||||
{
|
||||
if (value is bool allow)
|
||||
{
|
||||
settings.Security.AllowReconfiguration = allow;
|
||||
}
|
||||
}
|
||||
|
||||
private void MapAllowTermination(AppSettings settings, object value)
|
||||
{
|
||||
if (value is bool allow)
|
||||
|
@ -111,5 +125,13 @@ namespace SafeExamBrowser.Configuration.ConfigurationData.DataMapping
|
|||
settings.Security.VirtualMachinePolicy = allow ? VirtualMachinePolicy.Allow : VirtualMachinePolicy.Deny;
|
||||
}
|
||||
}
|
||||
|
||||
private void MapReconfigurationUrl(AppSettings settings, object value)
|
||||
{
|
||||
if (value is string url)
|
||||
{
|
||||
settings.Security.ReconfigurationUrl = url;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -19,17 +19,11 @@ namespace SafeExamBrowser.Configuration.ConfigurationData
|
|||
{
|
||||
internal void Process(IDictionary<string, object> rawData, AppSettings settings)
|
||||
{
|
||||
AllowReconfiguration(settings);
|
||||
AllowBrowserToolbarForReloading(rawData, settings);
|
||||
CalculateConfigurationKey(rawData, settings);
|
||||
RemoveLegacyBrowsers(settings);
|
||||
}
|
||||
|
||||
private void AllowReconfiguration(AppSettings settings)
|
||||
{
|
||||
settings.Security.AllowReconfiguration = settings.ConfigurationMode == ConfigurationMode.ConfigureClient;
|
||||
}
|
||||
|
||||
private void AllowBrowserToolbarForReloading(IDictionary<string, object> rawData, AppSettings settings)
|
||||
{
|
||||
var showReloadButton = rawData.TryGetValue(Keys.Browser.ShowReloadButton, out var v) && v is bool show && show;
|
||||
|
|
|
@ -210,11 +210,13 @@ namespace SafeExamBrowser.Configuration.ConfigurationData
|
|||
{
|
||||
internal const string AdminPasswordHash = "hashedAdminPassword";
|
||||
internal const string AllowApplicationLog = "allowApplicationLog";
|
||||
internal const string AllowReconfiguration = "examSessionReconfigureAllow";
|
||||
internal const string AllowTermination = "allowQuit";
|
||||
internal const string AllowVirtualMachine = "allowVirtualMachine";
|
||||
internal const string KioskModeCreateNewDesktop = "createNewDesktop";
|
||||
internal const string KioskModeDisableExplorerShell = "killExplorerShell";
|
||||
internal const string QuitPasswordHash = "hashedQuitPassword";
|
||||
internal const string ReconfigurationUrl = "examSessionReconfigureConfigURL";
|
||||
}
|
||||
|
||||
internal static class Server
|
||||
|
|
|
@ -163,7 +163,6 @@ namespace SafeExamBrowser.Runtime.UnitTests
|
|||
var args = new ReconfigurationEventArgs { ConfigurationPath = "C:\\Some\\File\\Path.seb" };
|
||||
|
||||
StartSession();
|
||||
currentSettings.Security.AllowReconfiguration = true;
|
||||
bootstrapSequence.Reset();
|
||||
sessionSequence.Reset();
|
||||
sessionSequence.Setup(s => s.TryRepeat()).Returns(OperationResult.Success);
|
||||
|
@ -182,7 +181,6 @@ namespace SafeExamBrowser.Runtime.UnitTests
|
|||
public void Communication_MustInformClientAboutAbortedReconfiguration()
|
||||
{
|
||||
StartSession();
|
||||
currentSettings.Security.AllowReconfiguration = true;
|
||||
sessionSequence.Reset();
|
||||
sessionSequence.Setup(s => s.TryRepeat()).Returns(OperationResult.Aborted);
|
||||
|
||||
|
@ -191,25 +189,6 @@ namespace SafeExamBrowser.Runtime.UnitTests
|
|||
clientProxy.Verify(c => c.InformReconfigurationAborted(), Times.Once);
|
||||
}
|
||||
|
||||
[TestMethod]
|
||||
public void Communication_MustInformClientAboutDeniedReconfiguration()
|
||||
{
|
||||
var args = new ReconfigurationEventArgs { ConfigurationPath = "C:\\Some\\File\\Path.seb" };
|
||||
|
||||
StartSession();
|
||||
currentSettings.Security.AllowReconfiguration = false;
|
||||
bootstrapSequence.Reset();
|
||||
sessionSequence.Reset();
|
||||
|
||||
runtimeHost.Raise(r => r.ReconfigurationRequested += null, args);
|
||||
|
||||
bootstrapSequence.VerifyNoOtherCalls();
|
||||
clientProxy.Verify(c => c.InformReconfigurationDenied(It.Is<string>(s => s == args.ConfigurationPath)), Times.Once);
|
||||
sessionSequence.VerifyNoOtherCalls();
|
||||
|
||||
Assert.AreNotEqual(sessionContext.ReconfigurationFilePath, args.ConfigurationPath);
|
||||
}
|
||||
|
||||
[TestMethod]
|
||||
public void Communication_MustShutdownUponRequest()
|
||||
{
|
||||
|
|
|
@ -343,20 +343,12 @@ namespace SafeExamBrowser.Runtime
|
|||
}
|
||||
|
||||
private void RuntimeHost_ReconfigurationRequested(ReconfigurationEventArgs args)
|
||||
{
|
||||
if (Session.Settings.Security.AllowReconfiguration)
|
||||
{
|
||||
logger.Info($"Accepted request for reconfiguration with '{args.ConfigurationPath}'.");
|
||||
sessionContext.ReconfigurationFilePath = args.ConfigurationPath;
|
||||
|
||||
StartSession();
|
||||
}
|
||||
else
|
||||
{
|
||||
logger.Info($"Denied request for reconfiguration with '{args.ConfigurationPath}'!");
|
||||
sessionContext.ClientProxy.InformReconfigurationDenied(args.ConfigurationPath);
|
||||
}
|
||||
}
|
||||
|
||||
private void RuntimeHost_ShutdownRequested()
|
||||
{
|
||||
|
|
|
@ -46,6 +46,11 @@ namespace SafeExamBrowser.Settings.Security
|
|||
/// </summary>
|
||||
public string QuitPasswordHash { get; set; }
|
||||
|
||||
/// <summary>
|
||||
/// An URL to optionally restrict with which resource SEB may be reconfigured. Allows the usage of a wildcard character (<c>*</c>).
|
||||
/// </summary>
|
||||
public string ReconfigurationUrl { get; set; }
|
||||
|
||||
/// <summary>
|
||||
/// Determines whether SEB is allowed to run in a virtual machine.
|
||||
/// </summary>
|
||||
|
|
|
@ -197,6 +197,8 @@ namespace SebWindowsConfig
|
|||
public const String KeyRestartExamURL = "restartExamURL";
|
||||
public const String KeyRestartExamUseStartURL = "restartExamUseStartURL";
|
||||
public const String KeyRestartExamPasswordProtected = "restartExamPasswordProtected";
|
||||
public const String KeyAllowReconfiguration = "examSessionReconfigureAllow";
|
||||
public const String KeyReconfigurationUrl = "examSessionReconfigureConfigURL";
|
||||
|
||||
// Group Additional Resources
|
||||
public const String KeyAdditionalResources = "additionalResources";
|
||||
|
@ -712,6 +714,8 @@ namespace SebWindowsConfig
|
|||
SEBSettings.settingsDefault.Add(SEBSettings.KeyRestartExamUseStartURL, false);
|
||||
SEBSettings.settingsDefault.Add(SEBSettings.KeyRestartExamText, "");
|
||||
SEBSettings.settingsDefault.Add(SEBSettings.KeyRestartExamPasswordProtected, true);
|
||||
SEBSettings.settingsDefault.Add(SEBSettings.KeyAllowReconfiguration, false);
|
||||
SEBSettings.settingsDefault.Add(SEBSettings.KeyReconfigurationUrl, "");
|
||||
|
||||
// Default settings for group "Additional Resources"
|
||||
SEBSettings.settingsDefault.Add(SEBSettings.KeyAdditionalResources, new ListObj());
|
||||
|
|
95
SebWindowsConfig/SebWindowsConfigForm.Designer.cs
generated
95
SebWindowsConfig/SebWindowsConfigForm.Designer.cs
generated
|
@ -30,8 +30,8 @@ namespace SebWindowsConfig
|
|||
{
|
||||
this.components = new System.ComponentModel.Container();
|
||||
System.ComponentModel.ComponentResourceManager resources = new System.ComponentModel.ComponentResourceManager(typeof(SebWindowsConfigForm));
|
||||
System.Windows.Forms.DataGridViewCellStyle dataGridViewCellStyle1 = new System.Windows.Forms.DataGridViewCellStyle();
|
||||
System.Windows.Forms.DataGridViewCellStyle dataGridViewCellStyle2 = new System.Windows.Forms.DataGridViewCellStyle();
|
||||
System.Windows.Forms.DataGridViewCellStyle dataGridViewCellStyle7 = new System.Windows.Forms.DataGridViewCellStyle();
|
||||
System.Windows.Forms.DataGridViewCellStyle dataGridViewCellStyle8 = new System.Windows.Forms.DataGridViewCellStyle();
|
||||
this.openFileDialogSebConfigFile = new System.Windows.Forms.OpenFileDialog();
|
||||
this.saveFileDialogSebConfigFile = new System.Windows.Forms.SaveFileDialog();
|
||||
this.imageListTabIcons = new System.Windows.Forms.ImageList(this.components);
|
||||
|
@ -291,6 +291,7 @@ namespace SebWindowsConfig
|
|||
this.radioButtonUserAgentDesktopDefault = new System.Windows.Forms.RadioButton();
|
||||
this.radioButtonUserAgentDesktopCustom = new System.Windows.Forms.RadioButton();
|
||||
this.groupBox11 = new System.Windows.Forms.GroupBox();
|
||||
this.checkBoxAllowFind = new System.Windows.Forms.CheckBox();
|
||||
this.checkBoxAllowPdfReaderToolbar = new System.Windows.Forms.CheckBox();
|
||||
this.checkBoxShowReloadWarningNewWindow = new System.Windows.Forms.CheckBox();
|
||||
this.checkBoxAllowReloadNewWindow = new System.Windows.Forms.CheckBox();
|
||||
|
@ -440,7 +441,11 @@ namespace SebWindowsConfig
|
|||
this.editDuplicateToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem();
|
||||
this.configureClientToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem();
|
||||
this.applyAndStartSEBToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem();
|
||||
this.checkBoxAllowFind = new System.Windows.Forms.CheckBox();
|
||||
this.groupBox15 = new System.Windows.Forms.GroupBox();
|
||||
this.checkBoxAllowReconfiguration = new System.Windows.Forms.CheckBox();
|
||||
this.label21 = new System.Windows.Forms.Label();
|
||||
this.textBoxReconfigurationUrl = new System.Windows.Forms.TextBox();
|
||||
this.label22 = new System.Windows.Forms.Label();
|
||||
this.tabPageHookedKeys.SuspendLayout();
|
||||
this.groupBoxFunctionKeys.SuspendLayout();
|
||||
this.groupBoxSpecialKeys.SuspendLayout();
|
||||
|
@ -495,6 +500,7 @@ namespace SebWindowsConfig
|
|||
this.groupBoxExitSequence.SuspendLayout();
|
||||
this.tabControlSebWindowsConfig.SuspendLayout();
|
||||
this.menuStrip1.SuspendLayout();
|
||||
this.groupBox15.SuspendLayout();
|
||||
this.SuspendLayout();
|
||||
//
|
||||
// openFileDialogSebConfigFile
|
||||
|
@ -1809,8 +1815,8 @@ namespace SebWindowsConfig
|
|||
//
|
||||
// Type
|
||||
//
|
||||
dataGridViewCellStyle1.BackColor = System.Drawing.Color.Silver;
|
||||
this.Type.DefaultCellStyle = dataGridViewCellStyle1;
|
||||
dataGridViewCellStyle7.BackColor = System.Drawing.Color.Silver;
|
||||
this.Type.DefaultCellStyle = dataGridViewCellStyle7;
|
||||
this.Type.HeaderText = "Type";
|
||||
this.Type.Name = "Type";
|
||||
this.Type.ReadOnly = true;
|
||||
|
@ -3003,6 +3009,7 @@ namespace SebWindowsConfig
|
|||
//
|
||||
// tabPageExam
|
||||
//
|
||||
this.tabPageExam.Controls.Add(this.groupBox15);
|
||||
this.tabPageExam.Controls.Add(this.groupBox2);
|
||||
this.tabPageExam.Controls.Add(this.groupBox9);
|
||||
this.tabPageExam.Controls.Add(this.groupBox8);
|
||||
|
@ -3832,6 +3839,17 @@ namespace SebWindowsConfig
|
|||
this.groupBox11.TabStop = false;
|
||||
this.groupBox11.Text = "Browser security";
|
||||
//
|
||||
// checkBoxAllowFind
|
||||
//
|
||||
this.checkBoxAllowFind.AutoSize = true;
|
||||
this.checkBoxAllowFind.Location = new System.Drawing.Point(14, 81);
|
||||
this.checkBoxAllowFind.Name = "checkBoxAllowFind";
|
||||
this.checkBoxAllowFind.Size = new System.Drawing.Size(106, 17);
|
||||
this.checkBoxAllowFind.TabIndex = 15;
|
||||
this.checkBoxAllowFind.Text = "Allow text search";
|
||||
this.checkBoxAllowFind.UseVisualStyleBackColor = true;
|
||||
this.checkBoxAllowFind.CheckedChanged += new System.EventHandler(this.checkBoxAllowFind_CheckedChanged);
|
||||
//
|
||||
// checkBoxAllowPdfReaderToolbar
|
||||
//
|
||||
this.checkBoxAllowPdfReaderToolbar.AutoSize = true;
|
||||
|
@ -4329,8 +4347,8 @@ namespace SebWindowsConfig
|
|||
// spellCheckerDictionaryFilesColumn
|
||||
//
|
||||
this.spellCheckerDictionaryFilesColumn.AutoSizeMode = System.Windows.Forms.DataGridViewAutoSizeColumnMode.Fill;
|
||||
dataGridViewCellStyle2.WrapMode = System.Windows.Forms.DataGridViewTriState.True;
|
||||
this.spellCheckerDictionaryFilesColumn.DefaultCellStyle = dataGridViewCellStyle2;
|
||||
dataGridViewCellStyle8.WrapMode = System.Windows.Forms.DataGridViewTriState.True;
|
||||
this.spellCheckerDictionaryFilesColumn.DefaultCellStyle = dataGridViewCellStyle8;
|
||||
this.spellCheckerDictionaryFilesColumn.HeaderText = "Files";
|
||||
this.spellCheckerDictionaryFilesColumn.Name = "spellCheckerDictionaryFilesColumn";
|
||||
this.spellCheckerDictionaryFilesColumn.ReadOnly = true;
|
||||
|
@ -5727,16 +5745,54 @@ namespace SebWindowsConfig
|
|||
this.applyAndStartSEBToolStripMenuItem.Visible = false;
|
||||
this.applyAndStartSEBToolStripMenuItem.Click += new System.EventHandler(this.applyAndStartSEBToolStripMenuItem_Click);
|
||||
//
|
||||
// checkBoxAllowFind
|
||||
// groupBox15
|
||||
//
|
||||
this.checkBoxAllowFind.AutoSize = true;
|
||||
this.checkBoxAllowFind.Location = new System.Drawing.Point(14, 81);
|
||||
this.checkBoxAllowFind.Name = "checkBoxAllowFind";
|
||||
this.checkBoxAllowFind.Size = new System.Drawing.Size(106, 17);
|
||||
this.checkBoxAllowFind.TabIndex = 15;
|
||||
this.checkBoxAllowFind.Text = "Allow text search";
|
||||
this.checkBoxAllowFind.UseVisualStyleBackColor = true;
|
||||
this.checkBoxAllowFind.CheckedChanged += new System.EventHandler(this.checkBoxAllowFind_CheckedChanged);
|
||||
this.groupBox15.Controls.Add(this.label22);
|
||||
this.groupBox15.Controls.Add(this.textBoxReconfigurationUrl);
|
||||
this.groupBox15.Controls.Add(this.label21);
|
||||
this.groupBox15.Controls.Add(this.checkBoxAllowReconfiguration);
|
||||
this.groupBox15.Location = new System.Drawing.Point(26, 413);
|
||||
this.groupBox15.Name = "groupBox15";
|
||||
this.groupBox15.Size = new System.Drawing.Size(553, 144);
|
||||
this.groupBox15.TabIndex = 123;
|
||||
this.groupBox15.TabStop = false;
|
||||
this.groupBox15.Text = "Reconfiguring Secure Session";
|
||||
//
|
||||
// checkBoxAllowReconfiguration
|
||||
//
|
||||
this.checkBoxAllowReconfiguration.AutoSize = true;
|
||||
this.checkBoxAllowReconfiguration.Location = new System.Drawing.Point(13, 78);
|
||||
this.checkBoxAllowReconfiguration.Name = "checkBoxAllowReconfiguration";
|
||||
this.checkBoxAllowReconfiguration.Size = new System.Drawing.Size(120, 17);
|
||||
this.checkBoxAllowReconfiguration.TabIndex = 0;
|
||||
this.checkBoxAllowReconfiguration.Text = "Allow Reconfiguring";
|
||||
this.checkBoxAllowReconfiguration.UseVisualStyleBackColor = true;
|
||||
this.checkBoxAllowReconfiguration.CheckedChanged += new System.EventHandler(this.checkBoxAllowReconfiguration_CheckedChanged);
|
||||
//
|
||||
// label21
|
||||
//
|
||||
this.label21.AutoSize = true;
|
||||
this.label21.Location = new System.Drawing.Point(10, 111);
|
||||
this.label21.Name = "label21";
|
||||
this.label21.Size = new System.Drawing.Size(98, 13);
|
||||
this.label21.TabIndex = 1;
|
||||
this.label21.Text = "Reconfiguring URL";
|
||||
//
|
||||
// textBoxReconfigurationUrl
|
||||
//
|
||||
this.textBoxReconfigurationUrl.Location = new System.Drawing.Point(114, 108);
|
||||
this.textBoxReconfigurationUrl.Name = "textBoxReconfigurationUrl";
|
||||
this.textBoxReconfigurationUrl.Size = new System.Drawing.Size(423, 20);
|
||||
this.textBoxReconfigurationUrl.TabIndex = 2;
|
||||
this.textBoxReconfigurationUrl.TextChanged += new System.EventHandler(this.textBoxReconfigurationUrl_TextChanged);
|
||||
//
|
||||
// label22
|
||||
//
|
||||
this.label22.Location = new System.Drawing.Point(10, 26);
|
||||
this.label22.Name = "label22";
|
||||
this.label22.Size = new System.Drawing.Size(527, 43);
|
||||
this.label22.TabIndex = 4;
|
||||
this.label22.Text = resources.GetString("label22.Text");
|
||||
//
|
||||
// SebWindowsConfigForm
|
||||
//
|
||||
|
@ -5855,6 +5911,8 @@ namespace SebWindowsConfig
|
|||
this.tabControlSebWindowsConfig.ResumeLayout(false);
|
||||
this.menuStrip1.ResumeLayout(false);
|
||||
this.menuStrip1.PerformLayout();
|
||||
this.groupBox15.ResumeLayout(false);
|
||||
this.groupBox15.PerformLayout();
|
||||
this.ResumeLayout(false);
|
||||
this.PerformLayout();
|
||||
|
||||
|
@ -6272,6 +6330,11 @@ namespace SebWindowsConfig
|
|||
private System.Windows.Forms.GroupBox groupBoxSebService;
|
||||
private System.Windows.Forms.CheckBox checkBoxAllowCustomDownloadLocation;
|
||||
private System.Windows.Forms.CheckBox checkBoxAllowFind;
|
||||
private System.Windows.Forms.GroupBox groupBox15;
|
||||
private System.Windows.Forms.TextBox textBoxReconfigurationUrl;
|
||||
private System.Windows.Forms.Label label21;
|
||||
private System.Windows.Forms.CheckBox checkBoxAllowReconfiguration;
|
||||
private System.Windows.Forms.Label label22;
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -551,6 +551,8 @@ namespace SebWindowsConfig
|
|||
checkBoxRestartExamPasswordProtected.Checked = (Boolean)SEBSettings.settingsCurrent[SEBSettings.KeyRestartExamPasswordProtected];
|
||||
textBoxRestartExamLink.Text = (String)SEBSettings.settingsCurrent[SEBSettings.KeyRestartExamURL];
|
||||
textBoxRestartExamText.Text = (String)SEBSettings.settingsCurrent[SEBSettings.KeyRestartExamText];
|
||||
checkBoxAllowReconfiguration.Checked = (Boolean)SEBSettings.settingsCurrent[SEBSettings.KeyAllowReconfiguration];
|
||||
textBoxReconfigurationUrl.Text = (String)SEBSettings.settingsCurrent[SEBSettings.KeyReconfigurationUrl];
|
||||
|
||||
// Group AdditionalResources
|
||||
tabControlSebWindowsConfig.TabPages.Remove(tabPageAdditionalResources);
|
||||
|
@ -4590,5 +4592,15 @@ namespace SebWindowsConfig
|
|||
{
|
||||
SEBSettings.settingsCurrent[SEBSettings.KeyAllowFind] = checkBoxAllowFind.Checked;
|
||||
}
|
||||
|
||||
private void checkBoxAllowReconfiguration_CheckedChanged(object sender, EventArgs e)
|
||||
{
|
||||
SEBSettings.settingsCurrent[SEBSettings.KeyAllowReconfiguration] = checkBoxAllowReconfiguration.Checked;
|
||||
}
|
||||
|
||||
private void textBoxReconfigurationUrl_TextChanged(object sender, EventArgs e)
|
||||
{
|
||||
SEBSettings.settingsCurrent[SEBSettings.KeyReconfigurationUrl] = textBoxReconfigurationUrl.Text;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
File diff suppressed because it is too large
Load diff
Loading…
Reference in a new issue