|
|
@ -4,6 +4,7 @@ using System.IO;
|
|
|
|
using System.Linq;
|
|
|
|
using System.Linq;
|
|
|
|
using NLog;
|
|
|
|
using NLog;
|
|
|
|
using NzbDrone.Common.Disk;
|
|
|
|
using NzbDrone.Common.Disk;
|
|
|
|
|
|
|
|
using NzbDrone.Core.MediaFiles;
|
|
|
|
using NzbDrone.Core.MediaFiles.Events;
|
|
|
|
using NzbDrone.Core.MediaFiles.Events;
|
|
|
|
using NzbDrone.Core.Messaging.Events;
|
|
|
|
using NzbDrone.Core.Messaging.Events;
|
|
|
|
using NzbDrone.Core.Tv;
|
|
|
|
using NzbDrone.Core.Tv;
|
|
|
@ -31,19 +32,30 @@ namespace NzbDrone.Core.Extras.Files
|
|
|
|
private readonly IExtraFileRepository<TExtraFile> _repository;
|
|
|
|
private readonly IExtraFileRepository<TExtraFile> _repository;
|
|
|
|
private readonly ISeriesService _seriesService;
|
|
|
|
private readonly ISeriesService _seriesService;
|
|
|
|
private readonly IDiskProvider _diskProvider;
|
|
|
|
private readonly IDiskProvider _diskProvider;
|
|
|
|
|
|
|
|
private readonly IRecycleBinProvider _recycleBinProvider;
|
|
|
|
private readonly Logger _logger;
|
|
|
|
private readonly Logger _logger;
|
|
|
|
|
|
|
|
|
|
|
|
public ExtraFileService(IExtraFileRepository<TExtraFile> repository,
|
|
|
|
public ExtraFileService(IExtraFileRepository<TExtraFile> repository,
|
|
|
|
ISeriesService seriesService,
|
|
|
|
ISeriesService seriesService,
|
|
|
|
IDiskProvider diskProvider,
|
|
|
|
IDiskProvider diskProvider,
|
|
|
|
|
|
|
|
IRecycleBinProvider recycleBinProvider,
|
|
|
|
Logger logger)
|
|
|
|
Logger logger)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
_repository = repository;
|
|
|
|
_repository = repository;
|
|
|
|
_seriesService = seriesService;
|
|
|
|
_seriesService = seriesService;
|
|
|
|
_diskProvider = diskProvider;
|
|
|
|
_diskProvider = diskProvider;
|
|
|
|
|
|
|
|
_recycleBinProvider = recycleBinProvider;
|
|
|
|
_logger = logger;
|
|
|
|
_logger = logger;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public virtual bool PermanentlyDelete
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
get
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
return false;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public List<TExtraFile> GetFilesBySeries(int seriesId)
|
|
|
|
public List<TExtraFile> GetFilesBySeries(int seriesId)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
return _repository.GetFilesBySeries(seriesId);
|
|
|
|
return _repository.GetFilesBySeries(seriesId);
|
|
|
@ -106,9 +118,18 @@ namespace NzbDrone.Core.Extras.Files
|
|
|
|
var path = Path.Combine(series.Path, extra.RelativePath);
|
|
|
|
var path = Path.Combine(series.Path, extra.RelativePath);
|
|
|
|
|
|
|
|
|
|
|
|
if (_diskProvider.FileExists(path))
|
|
|
|
if (_diskProvider.FileExists(path))
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if (PermanentlyDelete)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
_diskProvider.DeleteFile(path);
|
|
|
|
_diskProvider.DeleteFile(path);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
// Send extra files to the recycling bin so they can be recovered if necessary
|
|
|
|
|
|
|
|
_recycleBinProvider.DeleteFile(path);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
_logger.Debug("Deleting Extra from database for episode file: {0}", episodeFile);
|
|
|
|
_logger.Debug("Deleting Extra from database for episode file: {0}", episodeFile);
|
|
|
|