app.js is no longer cached.

pull/4/head
kay.one 12 years ago
parent 8f9b9c901c
commit 0f52a5de22

@ -0,0 +1,31 @@
using Nancy;
using NzbDrone.Api.Extensions;
using NzbDrone.Common.EnvironmentInfo;
namespace NzbDrone.Api.Frontend
{
public interface IAddCacheHeaders
{
void ToResponse(Request request, Response response);
}
public class AddCacheHeaders : IAddCacheHeaders
{
public void ToResponse(Request request, Response response)
{
if (!RuntimeInfo.IsProduction)
{
response.Headers.DisableCache();
return;
}
if (request.Url.Path.ToLower() == "app.js")
{
response.Headers.DisableCache();
return;
}
response.Headers.EnableCache();
}
}
}

@ -19,14 +19,17 @@ namespace NzbDrone.Api.Frontend
{
private readonly IDiskProvider _diskProvider;
private readonly IEnumerable<IMapHttpRequestsToDisk> _requestMappers;
private readonly IAddCacheHeaders _addCacheHeaders;
private readonly Logger _logger;
public StaticResourceProvider(IDiskProvider diskProvider,
IEnumerable<IMapHttpRequestsToDisk> requestMappers,
IAddCacheHeaders addCacheHeaders,
Logger logger)
{
_diskProvider = diskProvider;
_requestMappers = requestMappers;
_addCacheHeaders = addCacheHeaders;
_logger = logger;
}
@ -48,18 +51,8 @@ namespace NzbDrone.Api.Frontend
if (_diskProvider.FileExists(filePath))
{
var response = new StreamResponse(() => File.OpenRead(filePath), MimeTypes.GetMimeType(filePath));
_addCacheHeaders.ToResponse(context.Request, response);
if (RuntimeInfo.IsProduction)
{
response.Headers.EnableCache();
}
else
{
response.Headers.DisableCache();
}
//return response.CompressResponse(context.Request);
return response;
}

@ -106,6 +106,7 @@
<Compile Include="Episodes\EpisodeResource.cs" />
<Compile Include="Extensions\GZipPipeline.cs" />
<Compile Include="Extensions\NancyJsonSerializer.cs" />
<Compile Include="Frontend\IAddCacheHeaders.cs" />
<Compile Include="Frontend\MediaCoverMapper.cs" />
<Compile Include="Frontend\IMapHttpRequestsToDisk.cs" />
<Compile Include="Frontend\IndexModule.cs" />

Loading…
Cancel
Save