@ -9,6 +9,7 @@ using NzbDrone.Core.History;
using NzbDrone.Core.Messaging.Commands ;
using NzbDrone.Core.Messaging.Commands ;
using NzbDrone.Core.Messaging.Events ;
using NzbDrone.Core.Messaging.Events ;
using NzbDrone.Core.Lifecycle ;
using NzbDrone.Core.Lifecycle ;
using NzbDrone.Core.Parser ;
using NzbDrone.Core.Queue ;
using NzbDrone.Core.Queue ;
namespace NzbDrone.Core.Download
namespace NzbDrone.Core.Download
@ -22,7 +23,10 @@ namespace NzbDrone.Core.Download
void MarkAsFailed ( Int32 historyId ) ;
void MarkAsFailed ( Int32 historyId ) ;
}
}
public class DownloadTrackingService : IDownloadTrackingService , IExecute < CheckForFinishedDownloadCommand > , IHandleAsync < ApplicationStartedEvent > , IHandle < EpisodeGrabbedEvent >
public class DownloadTrackingService : IDownloadTrackingService ,
IExecute < CheckForFinishedDownloadCommand > ,
IHandleAsync < ApplicationStartedEvent > ,
IHandle < EpisodeGrabbedEvent >
{
{
private readonly IProvideDownloadClient _downloadClientProvider ;
private readonly IProvideDownloadClient _downloadClientProvider ;
private readonly IHistoryService _historyService ;
private readonly IHistoryService _historyService ;
@ -30,6 +34,7 @@ namespace NzbDrone.Core.Download
private readonly IConfigService _configService ;
private readonly IConfigService _configService ;
private readonly IFailedDownloadService _failedDownloadService ;
private readonly IFailedDownloadService _failedDownloadService ;
private readonly ICompletedDownloadService _completedDownloadService ;
private readonly ICompletedDownloadService _completedDownloadService ;
private readonly IParsingService _parsingService ;
private readonly Logger _logger ;
private readonly Logger _logger ;
private readonly ICached < TrackedDownload [ ] > _trackedDownloadCache ;
private readonly ICached < TrackedDownload [ ] > _trackedDownloadCache ;
@ -44,6 +49,7 @@ namespace NzbDrone.Core.Download
ICacheManager cacheManager ,
ICacheManager cacheManager ,
IFailedDownloadService failedDownloadService ,
IFailedDownloadService failedDownloadService ,
ICompletedDownloadService completedDownloadService ,
ICompletedDownloadService completedDownloadService ,
IParsingService parsingService ,
Logger logger )
Logger logger )
{
{
_downloadClientProvider = downloadClientProvider ;
_downloadClientProvider = downloadClientProvider ;
@ -52,6 +58,7 @@ namespace NzbDrone.Core.Download
_configService = configService ;
_configService = configService ;
_failedDownloadService = failedDownloadService ;
_failedDownloadService = failedDownloadService ;
_completedDownloadService = completedDownloadService ;
_completedDownloadService = completedDownloadService ;
_parsingService = parsingService ;
_logger = logger ;
_logger = logger ;
_trackedDownloadCache = cacheManager . GetCache < TrackedDownload [ ] > ( GetType ( ) ) ;
_trackedDownloadCache = cacheManager . GetCache < TrackedDownload [ ] > ( GetType ( ) ) ;
@ -73,7 +80,7 @@ namespace NzbDrone.Core.Download
{
{
return _trackedDownloadCache . Get ( "queued" , ( ) = >
return _trackedDownloadCache . Get ( "queued" , ( ) = >
{
{
UpdateTrackedDownloads ( ) ;
UpdateTrackedDownloads ( _historyService . Grabbed ( ) ) ;
return FilterQueuedDownloads ( GetTrackedDownloads ( ) ) ;
return FilterQueuedDownloads ( GetTrackedDownloads ( ) ) ;
@ -119,7 +126,7 @@ namespace NzbDrone.Core.Download
. ToList ( ) ;
. ToList ( ) ;
}
}
private Boolean UpdateTrackedDownloads ( )
private Boolean UpdateTrackedDownloads ( List < History . History > grabbedHistory )
{
{
var downloadClients = _downloadClientProvider . GetDownloadClients ( ) ;
var downloadClients = _downloadClientProvider . GetDownloadClients ( ) ;
@ -140,13 +147,9 @@ namespace NzbDrone.Core.Download
if ( ! oldTrackedDownloads . TryGetValue ( trackingId , out trackedDownload ) )
if ( ! oldTrackedDownloads . TryGetValue ( trackingId , out trackedDownload ) )
{
{
trackedDownload = new TrackedDownload
trackedDownload = GetTrackedDownload ( trackingId , downloadClient . Definition . Id , downloadItem , grabbedHistory ) ;
{
TrackingId = trackingId ,
if ( trackedDownload = = null ) continue ;
DownloadClient = downloadClient . Definition . Id ,
StartedTracking = DateTime . UtcNow ,
State = TrackedDownloadState . Unknown
} ;
_logger . Debug ( "[{0}] Started tracking download with id {1}." , downloadItem . Title , trackingId ) ;
_logger . Debug ( "[{0}] Started tracking download with id {1}." , downloadItem . Title , trackingId ) ;
stateChanged = true ;
stateChanged = true ;
@ -182,9 +185,9 @@ namespace NzbDrone.Core.Download
var failedHistory = _historyService . Failed ( ) ;
var failedHistory = _historyService . Failed ( ) ;
var importedHistory = _historyService . Imported ( ) ;
var importedHistory = _historyService . Imported ( ) ;
var stateChanged = UpdateTrackedDownloads ( ) ;
var stateChanged = UpdateTrackedDownloads ( grabbedHistory ) ;
var downloadClients = _downloadClientProvider . GetDownloadClients ( ) ;
var downloadClients = _downloadClientProvider . GetDownloadClients ( ) .ToList ( ) ;
var trackedDownloads = GetTrackedDownloads ( ) ;
var trackedDownloads = GetTrackedDownloads ( ) ;
foreach ( var trackedDownload in trackedDownloads )
foreach ( var trackedDownload in trackedDownloads )
@ -215,6 +218,50 @@ namespace NzbDrone.Core.Download
}
}
}
}
private TrackedDownload GetTrackedDownload ( String trackingId , Int32 downloadClient , DownloadClientItem downloadItem , List < History . History > grabbedHistory )
{
var trackedDownload = new TrackedDownload
{
TrackingId = trackingId ,
DownloadClient = downloadClient ,
DownloadItem = downloadItem ,
StartedTracking = DateTime . UtcNow ,
State = TrackedDownloadState . Unknown ,
Status = TrackedDownloadStatus . Ok ,
} ;
var historyItems = grabbedHistory . Where ( h = >
{
var downloadClientId = h . Data . GetValueOrDefault ( DOWNLOAD_CLIENT_ID ) ;
if ( downloadClientId = = null ) return false ;
return downloadClientId . Equals ( trackedDownload . DownloadItem . DownloadClientId ) ;
} ) . ToList ( ) ;
var parsedEpisodeInfo = Parser . Parser . ParseTitle ( trackedDownload . DownloadItem . Title ) ;
if ( parsedEpisodeInfo = = null ) return null ;
var remoteEpisode = _parsingService . Map ( parsedEpisodeInfo , 0 ) ;
if ( remoteEpisode . Series = = null )
{
if ( historyItems . Empty ( ) ) return null ;
trackedDownload . Status = TrackedDownloadStatus . Warning ;
trackedDownload . StatusMessages . Add ( new TrackedDownloadStatusMessage (
trackedDownload . DownloadItem . Title ,
"Series title mismatch, automatic import is not possible" )
) ;
remoteEpisode = _parsingService . Map ( parsedEpisodeInfo , historyItems . First ( ) . SeriesId , historyItems . Select ( h = > h . EpisodeId ) ) ;
}
trackedDownload . RemoteEpisode = remoteEpisode ;
return trackedDownload ;
}
public void Execute ( CheckForFinishedDownloadCommand message )
public void Execute ( CheckForFinishedDownloadCommand message )
{
{
ProcessTrackedDownloads ( ) ;
ProcessTrackedDownloads ( ) ;