2018-11-08 09:39:52 +01:00
|
|
|
|
/*
|
|
|
|
|
* Copyright (c) 2018 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.IO;
|
|
|
|
|
using SafeExamBrowser.Contracts.Configuration;
|
2018-12-14 09:50:10 +01:00
|
|
|
|
using SafeExamBrowser.Contracts.Configuration.DataResources;
|
2018-11-08 09:39:52 +01:00
|
|
|
|
using SafeExamBrowser.Contracts.Logging;
|
|
|
|
|
|
2018-12-14 09:50:10 +01:00
|
|
|
|
namespace SafeExamBrowser.Configuration.DataResources
|
2018-11-08 09:39:52 +01:00
|
|
|
|
{
|
2018-12-21 11:36:20 +01:00
|
|
|
|
public class FileResourceLoader : IResourceLoader
|
2018-11-08 09:39:52 +01:00
|
|
|
|
{
|
|
|
|
|
private ILogger logger;
|
|
|
|
|
|
2018-12-21 11:36:20 +01:00
|
|
|
|
public FileResourceLoader(ILogger logger)
|
2018-11-08 09:39:52 +01:00
|
|
|
|
{
|
|
|
|
|
this.logger = logger;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public bool CanLoad(Uri resource)
|
|
|
|
|
{
|
2018-11-15 08:45:17 +01:00
|
|
|
|
var exists = resource.IsFile && File.Exists(resource.LocalPath);
|
2018-11-09 14:15:56 +01:00
|
|
|
|
|
|
|
|
|
if (exists)
|
2018-11-08 09:39:52 +01:00
|
|
|
|
{
|
2018-12-21 11:36:20 +01:00
|
|
|
|
logger.Debug($"Can load '{resource}' as it is an existing file.");
|
2018-11-09 14:15:56 +01:00
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
2018-12-21 11:36:20 +01:00
|
|
|
|
logger.Debug($"Can't load '{resource}' as it isn't an existing file.");
|
2018-11-08 09:39:52 +01:00
|
|
|
|
}
|
|
|
|
|
|
2018-11-09 14:15:56 +01:00
|
|
|
|
return exists;
|
2018-11-08 09:39:52 +01:00
|
|
|
|
}
|
|
|
|
|
|
2018-11-09 14:15:56 +01:00
|
|
|
|
public LoadStatus TryLoad(Uri resource, out Stream data)
|
2018-11-08 09:39:52 +01:00
|
|
|
|
{
|
|
|
|
|
logger.Debug($"Loading data from '{resource}'...");
|
2018-11-15 08:45:17 +01:00
|
|
|
|
data = new FileStream(resource.LocalPath, FileMode.Open, FileAccess.Read);
|
|
|
|
|
logger.Debug($"Created '{data}' for {data.Length / 1000.0} KB data in '{resource}'.");
|
2018-11-08 09:39:52 +01:00
|
|
|
|
|
2018-11-09 14:15:56 +01:00
|
|
|
|
return LoadStatus.Success;
|
2018-11-08 09:39:52 +01:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|