2019-11-05 10:08:19 +01: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-11-13 10:11:11 +01:00
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
using System.Linq;
|
2019-11-05 10:08:19 +01:00
|
|
|
|
using SafeExamBrowser.Applications.Contracts;
|
|
|
|
|
using SafeExamBrowser.Applications.Contracts.Events;
|
2019-11-13 10:11:11 +01:00
|
|
|
|
using SafeExamBrowser.Logging.Contracts;
|
|
|
|
|
using SafeExamBrowser.WindowsApi.Contracts;
|
2019-11-05 10:08:19 +01:00
|
|
|
|
|
|
|
|
|
namespace SafeExamBrowser.Applications
|
|
|
|
|
{
|
|
|
|
|
internal class ExternalApplication : IApplication
|
|
|
|
|
{
|
2019-11-06 08:45:37 +01:00
|
|
|
|
private string executablePath;
|
2019-11-13 10:11:11 +01:00
|
|
|
|
private IModuleLogger logger;
|
|
|
|
|
private IList<IApplicationInstance> instances;
|
|
|
|
|
private IProcessFactory processFactory;
|
2019-11-06 08:45:37 +01:00
|
|
|
|
|
|
|
|
|
public ApplicationInfo Info { get; }
|
2019-11-05 10:08:19 +01:00
|
|
|
|
|
|
|
|
|
public event InstanceStartedEventHandler InstanceStarted;
|
|
|
|
|
|
2019-11-13 10:11:11 +01:00
|
|
|
|
internal ExternalApplication(string executablePath, ApplicationInfo info, IModuleLogger logger, IProcessFactory processFactory)
|
2019-11-06 08:45:37 +01:00
|
|
|
|
{
|
|
|
|
|
this.executablePath = executablePath;
|
|
|
|
|
this.Info = info;
|
2019-11-13 10:11:11 +01:00
|
|
|
|
this.logger = logger;
|
|
|
|
|
this.instances = new List<IApplicationInstance>();
|
|
|
|
|
this.processFactory = processFactory;
|
2019-11-06 08:45:37 +01:00
|
|
|
|
}
|
|
|
|
|
|
2019-11-05 10:08:19 +01:00
|
|
|
|
public void Initialize()
|
|
|
|
|
{
|
2019-11-13 10:11:11 +01:00
|
|
|
|
// Nothing to do here for now.
|
2019-11-05 10:08:19 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public void Start()
|
|
|
|
|
{
|
2019-11-13 10:11:11 +01:00
|
|
|
|
logger.Info("Starting application...");
|
|
|
|
|
|
|
|
|
|
var process = processFactory.StartNew(executablePath);
|
|
|
|
|
var id = new ApplicationInstanceIdentifier(process.Id);
|
|
|
|
|
var instance = new ExternalApplicationInstance(id, logger.CloneFor($"{Info.Name} {id}"), process);
|
|
|
|
|
|
|
|
|
|
instance.Initialize();
|
|
|
|
|
instances.Add(instance);
|
|
|
|
|
InstanceStarted?.Invoke(instance);
|
2019-11-05 10:08:19 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public void Terminate()
|
|
|
|
|
{
|
2019-11-13 10:11:11 +01:00
|
|
|
|
if (instances.Any())
|
|
|
|
|
{
|
|
|
|
|
logger.Info("Terminating application...");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
foreach (var instance in instances)
|
|
|
|
|
{
|
|
|
|
|
instance.Terminate();
|
|
|
|
|
}
|
2019-11-05 10:08:19 +01:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|