Sonarr/NzbDrone.Core/MediaCover/CoverAlreadyExistsSpecifica...

50 lines
1.4 KiB
C#
Raw Normal View History

2013-06-03 05:39:42 +00:00
using NLog;
using NzbDrone.Common;
2013-06-03 05:51:16 +00:00
using NzbDrone.Common.Serializer;
namespace NzbDrone.Core.MediaCover
{
public interface ICoverExistsSpecification
{
2013-06-03 05:39:42 +00:00
bool AlreadyExists(string url, string path);
}
public class CoverAlreadyExistsSpecification : ICoverExistsSpecification
{
private readonly IDiskProvider _diskProvider;
private readonly IHttpProvider _httpProvider;
2013-06-03 05:39:42 +00:00
private readonly Logger _logger;
2013-06-03 05:39:42 +00:00
public CoverAlreadyExistsSpecification(IDiskProvider diskProvider, IHttpProvider httpProvider, Logger logger)
{
_diskProvider = diskProvider;
_httpProvider = httpProvider;
2013-06-03 05:39:42 +00:00
_logger = logger;
}
public bool AlreadyExists(string url, string path)
{
if (!_diskProvider.FileExists(path))
{
return false;
}
2013-06-03 06:12:31 +00:00
var headers = _httpProvider.GetHeader(url);
2013-06-03 05:39:42 +00:00
string sizeString;
2013-06-03 05:51:16 +00:00
if (headers.TryGetValue(HttpProvider.ContentLenghtHeader, out sizeString))
{
int size;
int.TryParse(sizeString, out size);
var fileSize = _diskProvider.GetFileSize(path);
2013-06-03 05:39:42 +00:00
return fileSize == size;
}
2013-06-03 05:51:16 +00:00
_logger.Warn("Couldn't find content-length header {0}", headers.ToJson());
2013-06-03 05:39:42 +00:00
return false;
}
}
}