mirror of
https://github.com/Sonarr/Sonarr.git
synced 2025-01-17 10:45:49 +02:00
updates to static pipeline
This commit is contained in:
parent
059028da02
commit
dbcabd6df6
@ -26,7 +26,9 @@ private Response CompressResponse(Request request, Response response)
|
||||
{
|
||||
try
|
||||
{
|
||||
if (!response.ContentType.Contains("image")
|
||||
if (
|
||||
!response.ContentType.Contains("image")
|
||||
&& !response.ContentType.Contains("font")
|
||||
&& request.Headers.AcceptEncoding.Any(x => x.Contains("gzip"))
|
||||
&& (!response.Headers.ContainsKey("Content-Encoding") || response.Headers["Content-Encoding"] != "gzip"))
|
||||
{
|
||||
|
@ -51,7 +51,16 @@ public override Response GetResponse(string resourceUrl)
|
||||
|
||||
protected override Stream GetContentStream(string filePath)
|
||||
{
|
||||
return StringToStream(GetIndexText());
|
||||
var text = GetIndexText();
|
||||
|
||||
var stream = new MemoryStream();
|
||||
using (var writer = new StreamWriter(stream))
|
||||
{
|
||||
writer.Write(text);
|
||||
writer.Flush();
|
||||
}
|
||||
stream.Position = 0;
|
||||
return stream;
|
||||
}
|
||||
|
||||
private string GetIndexText()
|
||||
|
@ -51,14 +51,5 @@ protected virtual Stream GetContentStream(string filePath)
|
||||
return File.OpenRead(filePath);
|
||||
}
|
||||
|
||||
protected static Stream StringToStream(string text)
|
||||
{
|
||||
var stream = new MemoryStream();
|
||||
var writer = new StreamWriter(stream);
|
||||
writer.Write(text);
|
||||
writer.Flush();
|
||||
stream.Position = 0;
|
||||
return stream;
|
||||
}
|
||||
}
|
||||
}
|
26
src/NzbDrone.Common/Crypto/Md5HashProvider.cs
Normal file
26
src/NzbDrone.Common/Crypto/Md5HashProvider.cs
Normal file
@ -0,0 +1,26 @@
|
||||
using System.Security.Cryptography;
|
||||
using NzbDrone.Common.Disk;
|
||||
|
||||
namespace NzbDrone.Common.Crypto
|
||||
{
|
||||
public class Md5HashProvider
|
||||
{
|
||||
private readonly IDiskProvider _diskProvider;
|
||||
|
||||
public Md5HashProvider(IDiskProvider diskProvider)
|
||||
{
|
||||
_diskProvider = diskProvider;
|
||||
}
|
||||
|
||||
public byte[] ComputeHash(string path)
|
||||
{
|
||||
using (var md5 = MD5.Create())
|
||||
{
|
||||
using (var stream = _diskProvider.StreamFile(path))
|
||||
{
|
||||
return md5.ComputeHash(stream);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
17
src/NzbDrone.Common/Extensions/Base64Extentions.cs
Normal file
17
src/NzbDrone.Common/Extensions/Base64Extentions.cs
Normal file
@ -0,0 +1,17 @@
|
||||
using System;
|
||||
|
||||
namespace NzbDrone.Common.Extensions
|
||||
{
|
||||
public static class Base64Extentions
|
||||
{
|
||||
public static string ToBase64(this byte[] bytes)
|
||||
{
|
||||
return Convert.ToBase64String(bytes);
|
||||
}
|
||||
|
||||
public static string ToBase64(this long input)
|
||||
{
|
||||
return BitConverter.GetBytes(input).ToBase64();
|
||||
}
|
||||
}
|
||||
}
|
@ -1,16 +1,10 @@
|
||||
using System;
|
||||
using System.Text;
|
||||
using System.Threading;
|
||||
|
||||
namespace NzbDrone.Common
|
||||
{
|
||||
public static class HashUtil
|
||||
{
|
||||
//This should never be changed. very bad things will happen!
|
||||
private static readonly DateTime Epoch = new DateTime(2010, 1, 1);
|
||||
|
||||
private static readonly object _lock = new object();
|
||||
|
||||
public static string CalculateCrc(string input)
|
||||
{
|
||||
uint mCrc = 0xffffffff;
|
||||
@ -32,36 +26,5 @@ public static string CalculateCrc(string input)
|
||||
}
|
||||
return String.Format("{0:x8}", mCrc);
|
||||
}
|
||||
|
||||
public static string GenerateCommandId()
|
||||
{
|
||||
return GenerateId("c");
|
||||
}
|
||||
|
||||
private static string GenerateId(string prefix)
|
||||
{
|
||||
lock (_lock)
|
||||
{
|
||||
Thread.Sleep(1);
|
||||
var tick = (DateTime.Now - Epoch).Ticks;
|
||||
return prefix + "." + ToBase(tick);
|
||||
}
|
||||
}
|
||||
|
||||
private static string ToBase(long input)
|
||||
{
|
||||
const string BASE_CHARS = "0123456789abcdefghijklmnopqrstuvwxyz";
|
||||
int targetBase = BASE_CHARS.Length;
|
||||
|
||||
var result = new StringBuilder();
|
||||
do
|
||||
{
|
||||
result.Append(BASE_CHARS[(int)(input % targetBase)]);
|
||||
input /= targetBase;
|
||||
} while (input > 0);
|
||||
|
||||
return result.ToString();
|
||||
}
|
||||
|
||||
}
|
||||
}
|
@ -73,6 +73,7 @@
|
||||
<Compile Include="Composition\IContainer.cs" />
|
||||
<Compile Include="ConsoleService.cs" />
|
||||
<Compile Include="ConvertBase32.cs" />
|
||||
<Compile Include="Crypto\Md5HashProvider.cs" />
|
||||
<Compile Include="DictionaryExtensions.cs" />
|
||||
<Compile Include="Disk\DiskProviderBase.cs" />
|
||||
<Compile Include="Disk\IDiskProvider.cs" />
|
||||
@ -110,6 +111,7 @@
|
||||
<Compile Include="Expansive\Tree.cs" />
|
||||
<Compile Include="Expansive\TreeNode.cs" />
|
||||
<Compile Include="Expansive\TreeNodeList.cs" />
|
||||
<Compile Include="Extensions\Base64Extentions.cs" />
|
||||
<Compile Include="Extensions\StreamExtensions.cs" />
|
||||
<Compile Include="HashUtil.cs" />
|
||||
<Compile Include="Http\HttpProvider.cs" />
|
||||
|
Loading…
Reference in New Issue
Block a user