Fixed up StaticResourceProvider

This commit is contained in:
Mark McDowall 2013-05-17 18:18:02 -07:00
parent 92d913e4ac
commit 1edb1d211b
4 changed files with 33 additions and 44 deletions

View File

@ -8,12 +8,6 @@ namespace NzbDrone.Api.Frontend
public interface IMapHttpRequestsToDisk public interface IMapHttpRequestsToDisk
{ {
string Map(string resourceUrl); string Map(string resourceUrl);
RequestType IHandle { get; } bool CanHandle(string resourceUrl);
}
public enum RequestType
{
StaticResources,
MediaCovers
} }
} }

View File

@ -20,6 +20,9 @@ namespace NzbDrone.Api.Frontend
return Path.Combine(_environmentProvider.GetAppDataPath(), path); return Path.Combine(_environmentProvider.GetAppDataPath(), path);
} }
public RequestType IHandle { get { return RequestType.MediaCovers; } } public bool CanHandle(string resourceUrl)
{
return resourceUrl.StartsWith("/mediacover");
}
} }
} }

View File

@ -1,9 +1,12 @@
using System.IO; using System.IO;
using System.Linq;
namespace NzbDrone.Api.Frontend namespace NzbDrone.Api.Frontend
{ {
public class StaticResourceMapper : IMapHttpRequestsToDisk public class StaticResourceMapper : IMapHttpRequestsToDisk
{ {
private static readonly string[] Extensions = new[] { ".css", ".js", ".html", ".htm", ".jpg", ".jpeg", ".icon", ".gif", ".png", ".woff", ".ttf" };
public string Map(string resourceUrl) public string Map(string resourceUrl)
{ {
var path = resourceUrl.Replace('/', Path.DirectorySeparatorChar); var path = resourceUrl.Replace('/', Path.DirectorySeparatorChar);
@ -13,6 +16,14 @@ namespace NzbDrone.Api.Frontend
return Path.Combine("ui", path); return Path.Combine("ui", path);
} }
public RequestType IHandle { get { return RequestType.StaticResources; } } public bool CanHandle(string resourceUrl)
{
if (string.IsNullOrWhiteSpace(resourceUrl))
{
return false;
}
return Extensions.Any(resourceUrl.EndsWith);
}
} }
} }

View File

@ -30,45 +30,26 @@ namespace NzbDrone.Api.Frontend
{ {
var path = context.Request.Url.Path.ToLower(); var path = context.Request.Url.Path.ToLower();
if (path.StartsWith("/mediacover")) if (string.IsNullOrWhiteSpace(path))
{ {
var filePath = _requestMappers.Single(r => r.IHandle == RequestType.MediaCovers).Map(path);
if (_diskProvider.FileExists(filePath))
{
return new StreamResponse(() => File.OpenRead(filePath), "image/jpeg");
}
_logger.Warn("Couldn't find file [{0}] for [{1}]", filePath, path);
}
if (IsStaticResource(path))
{
var filePath = _requestMappers.Single(r => r.IHandle == RequestType.StaticResources).Map(path);
if (_diskProvider.FileExists(filePath))
{
return new GenericFileResponse(filePath);
}
_logger.Warn("Couldn't find file [{0}] for [{1}]", filePath, path);
}
return null; return null;
} }
foreach (var requestMapper in _requestMappers)
private static readonly string[] Extensions = new[] { ".css", ".js", ".html", ".htm", ".jpg", ".jpeg", ".icon", ".gif", ".png", ".woff", ".ttf" };
private bool IsStaticResource(string path)
{ {
if (string.IsNullOrWhiteSpace(path)) if (requestMapper.CanHandle(path))
{ {
return false; var filePath = requestMapper.Map(path);
if (_diskProvider.FileExists(filePath))
{
return new StreamResponse(() => File.OpenRead(filePath), MimeTypes.GetMimeType(filePath));
}
}
} }
return Extensions.Any(path.EndsWith); _logger.Warn("Couldn't find a matching file for: {0}", path);
return null;
} }
} }
} }