|
|
@ -1,20 +1,28 @@
|
|
|
|
|
|
|
|
using System;
|
|
|
|
using System.IO;
|
|
|
|
using System.IO;
|
|
|
|
using Nancy;
|
|
|
|
using Nancy;
|
|
|
|
|
|
|
|
using Nancy.Responses;
|
|
|
|
using NLog;
|
|
|
|
using NLog;
|
|
|
|
using NzbDrone.Common;
|
|
|
|
using NzbDrone.Common;
|
|
|
|
using NzbDrone.Common.EnvironmentInfo;
|
|
|
|
using NzbDrone.Common.EnvironmentInfo;
|
|
|
|
|
|
|
|
using NzbDrone.Core.Configuration;
|
|
|
|
|
|
|
|
|
|
|
|
namespace NzbDrone.Api.Frontend.Mappers
|
|
|
|
namespace NzbDrone.Api.Frontend.Mappers
|
|
|
|
{
|
|
|
|
{
|
|
|
|
public class IndexHtmlMapper : StaticResourceMapperBase
|
|
|
|
public class IndexHtmlMapper : StaticResourceMapperBase
|
|
|
|
{
|
|
|
|
{
|
|
|
|
private readonly IDiskProvider _diskProvider;
|
|
|
|
private readonly IDiskProvider _diskProvider;
|
|
|
|
|
|
|
|
private readonly IConfigFileProvider _configFileProvider;
|
|
|
|
private readonly string _indexPath;
|
|
|
|
private readonly string _indexPath;
|
|
|
|
|
|
|
|
|
|
|
|
public IndexHtmlMapper(IAppFolderInfo appFolderInfo, IDiskProvider diskProvider, Logger logger)
|
|
|
|
public IndexHtmlMapper(IAppFolderInfo appFolderInfo,
|
|
|
|
|
|
|
|
IDiskProvider diskProvider,
|
|
|
|
|
|
|
|
IConfigFileProvider configFileProvider,
|
|
|
|
|
|
|
|
Logger logger)
|
|
|
|
: base(diskProvider, logger)
|
|
|
|
: base(diskProvider, logger)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
_diskProvider = diskProvider;
|
|
|
|
_diskProvider = diskProvider;
|
|
|
|
|
|
|
|
_configFileProvider = configFileProvider;
|
|
|
|
_indexPath = Path.Combine(appFolderInfo.StartUpFolder, "UI", "index.html");
|
|
|
|
_indexPath = Path.Combine(appFolderInfo.StartUpFolder, "UI", "index.html");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -30,7 +38,21 @@ namespace NzbDrone.Api.Frontend.Mappers
|
|
|
|
|
|
|
|
|
|
|
|
public override Response GetResponse(string resourceUrl)
|
|
|
|
public override Response GetResponse(string resourceUrl)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
|
|
|
|
string content;
|
|
|
|
var response = base.GetResponse(resourceUrl);
|
|
|
|
var response = base.GetResponse(resourceUrl);
|
|
|
|
|
|
|
|
var stream = new MemoryStream();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
response.Contents.Invoke(stream);
|
|
|
|
|
|
|
|
stream.Position = 0;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
using (var reader = new StreamReader(stream))
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
content = reader.ReadToEnd();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
content = content.Replace("API_KEY", _configFileProvider.ApiKey);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
response = new StreamResponse(() => StringToStream(content), response.ContentType);
|
|
|
|
response.Headers["X-UA-Compatible"] = "IE=edge";
|
|
|
|
response.Headers["X-UA-Compatible"] = "IE=edge";
|
|
|
|
|
|
|
|
|
|
|
|
return response;
|
|
|
|
return response;
|
|
|
@ -51,6 +73,5 @@ namespace NzbDrone.Api.Frontend.Mappers
|
|
|
|
|
|
|
|
|
|
|
|
return text;
|
|
|
|
return text;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|