SEBWIN-444: Ensured server connectivity is maintained when reconfiguring and fixed detection of Moodle sessions.
This commit is contained in:
parent
786193aff4
commit
a3292a7977
5 changed files with 23 additions and 9 deletions
|
@ -286,7 +286,7 @@ namespace SafeExamBrowser.Browser.Handlers
|
||||||
{
|
{
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
var location = locations.FirstOrDefault(l => l.Contains("moodle/login/index.php?testsession"));
|
var location = locations.FirstOrDefault(l => l.Contains("/login/index.php?testsession"));
|
||||||
|
|
||||||
if (location != default(string))
|
if (location != default(string))
|
||||||
{
|
{
|
||||||
|
|
|
@ -41,8 +41,6 @@ namespace SafeExamBrowser.Client.Operations
|
||||||
|
|
||||||
public override OperationResult Perform()
|
public override OperationResult Perform()
|
||||||
{
|
{
|
||||||
var result = OperationResult.Success;
|
|
||||||
|
|
||||||
if (Context.Settings.SessionMode == SessionMode.Server)
|
if (Context.Settings.SessionMode == SessionMode.Server)
|
||||||
{
|
{
|
||||||
logger.Info("Initializing server...");
|
logger.Info("Initializing server...");
|
||||||
|
@ -54,15 +52,18 @@ namespace SafeExamBrowser.Client.Operations
|
||||||
Context.AppConfig.ServerExamId,
|
Context.AppConfig.ServerExamId,
|
||||||
Context.AppConfig.ServerOauth2Token,
|
Context.AppConfig.ServerOauth2Token,
|
||||||
Context.Settings.Server);
|
Context.Settings.Server);
|
||||||
|
|
||||||
|
if (Context.AppConfig.ServerConnectivityAutoStart)
|
||||||
|
{
|
||||||
|
server.StartConnectivity();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return result;
|
return OperationResult.Success;
|
||||||
}
|
}
|
||||||
|
|
||||||
public override OperationResult Revert()
|
public override OperationResult Revert()
|
||||||
{
|
{
|
||||||
var result = OperationResult.Success;
|
|
||||||
|
|
||||||
if (Context.Settings?.SessionMode == SessionMode.Server)
|
if (Context.Settings?.SessionMode == SessionMode.Server)
|
||||||
{
|
{
|
||||||
logger.Info("Finalizing server...");
|
logger.Info("Finalizing server...");
|
||||||
|
@ -71,7 +72,7 @@ namespace SafeExamBrowser.Client.Operations
|
||||||
server.StopConnectivity();
|
server.StopConnectivity();
|
||||||
}
|
}
|
||||||
|
|
||||||
return result;
|
return OperationResult.Success;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -161,6 +161,11 @@ namespace SafeExamBrowser.Configuration.Contracts
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public string ServerConnectionToken { get; set; }
|
public string ServerConnectionToken { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Determines whether the server connectivity should automatically be started in case of a reconfiguration.
|
||||||
|
/// </summary>
|
||||||
|
public bool ServerConnectivityAutoStart { get; set; }
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// The identifier of the selected server exam.
|
/// The identifier of the selected server exam.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
|
|
@ -135,8 +135,11 @@ namespace SafeExamBrowser.Runtime.Operations
|
||||||
{
|
{
|
||||||
if (Context.Current.Settings.SessionMode == SessionMode.Server)
|
if (Context.Current.Settings.SessionMode == SessionMode.Server)
|
||||||
{
|
{
|
||||||
|
logger.Info("Initializing server configuration for next session...");
|
||||||
|
|
||||||
Context.Next.AppConfig.ServerApi = Context.Current.AppConfig.ServerApi;
|
Context.Next.AppConfig.ServerApi = Context.Current.AppConfig.ServerApi;
|
||||||
Context.Next.AppConfig.ServerConnectionToken = Context.Current.AppConfig.ServerConnectionToken;
|
Context.Next.AppConfig.ServerConnectionToken = Context.Current.AppConfig.ServerConnectionToken;
|
||||||
|
Context.Next.AppConfig.ServerConnectivityAutoStart = true;
|
||||||
Context.Next.AppConfig.ServerExamId = Context.Current.AppConfig.ServerExamId;
|
Context.Next.AppConfig.ServerExamId = Context.Current.AppConfig.ServerExamId;
|
||||||
Context.Next.AppConfig.ServerOauth2Token = Context.Current.AppConfig.ServerOauth2Token;
|
Context.Next.AppConfig.ServerOauth2Token = Context.Current.AppConfig.ServerOauth2Token;
|
||||||
|
|
||||||
|
|
|
@ -321,9 +321,14 @@ namespace SafeExamBrowser.Server
|
||||||
|
|
||||||
if (success)
|
if (success)
|
||||||
{
|
{
|
||||||
if (TryParseInstruction(response.Content, out var instruction) && instruction == "SEB_QUIT")
|
if (TryParseInstruction(response.Content, out var instruction))
|
||||||
{
|
{
|
||||||
|
switch (instruction)
|
||||||
|
{
|
||||||
|
case "SEB_QUIT":
|
||||||
Task.Run(() => TerminationRequested?.Invoke());
|
Task.Run(() => TerminationRequested?.Invoke());
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
|
Loading…
Reference in a new issue