2013-08-12 19:01:15 -07:00
|
|
|
using System;
|
|
|
|
using System.Collections.Generic;
|
2013-07-18 22:23:04 -07:00
|
|
|
using System.Linq;
|
|
|
|
using NLog;
|
2013-09-10 23:33:47 -07:00
|
|
|
using NzbDrone.Core.Instrumentation;
|
2013-07-18 22:23:04 -07:00
|
|
|
using NzbDrone.Core.MediaFiles.Commands;
|
|
|
|
using NzbDrone.Core.MediaFiles.Events;
|
2013-09-10 23:33:47 -07:00
|
|
|
using NzbDrone.Core.Messaging;
|
2013-07-18 22:23:04 -07:00
|
|
|
using NzbDrone.Core.Tv;
|
|
|
|
|
|
|
|
namespace NzbDrone.Core.MediaFiles
|
|
|
|
{
|
2013-07-18 23:18:57 -07:00
|
|
|
public class RenameEpisodeFileService : IExecute<RenameSeasonCommand>, IExecute<RenameSeriesCommand>
|
2013-07-18 22:23:04 -07:00
|
|
|
{
|
|
|
|
private readonly ISeriesService _seriesService;
|
|
|
|
private readonly IMediaFileService _mediaFileService;
|
|
|
|
private readonly IMoveEpisodeFiles _episodeFileMover;
|
|
|
|
private readonly IMessageAggregator _messageAggregator;
|
|
|
|
private readonly Logger _logger;
|
|
|
|
|
|
|
|
public RenameEpisodeFileService(ISeriesService seriesService,
|
|
|
|
IMediaFileService mediaFileService,
|
|
|
|
IMoveEpisodeFiles episodeFileMover,
|
|
|
|
IMessageAggregator messageAggregator,
|
|
|
|
Logger logger)
|
|
|
|
{
|
|
|
|
_seriesService = seriesService;
|
|
|
|
_mediaFileService = mediaFileService;
|
|
|
|
_episodeFileMover = episodeFileMover;
|
|
|
|
_messageAggregator = messageAggregator;
|
|
|
|
_logger = logger;
|
|
|
|
}
|
|
|
|
|
|
|
|
private void RenameFiles(List<EpisodeFile> episodeFiles, Series series)
|
|
|
|
{
|
|
|
|
var renamed = new List<EpisodeFile>();
|
|
|
|
|
2013-08-29 23:41:49 -07:00
|
|
|
foreach (var episodeFile in episodeFiles)
|
2013-07-18 22:23:04 -07:00
|
|
|
{
|
2013-08-12 19:01:15 -07:00
|
|
|
try
|
|
|
|
{
|
|
|
|
_logger.Trace("Renaming episode file: {0}", episodeFile);
|
2013-08-29 23:41:49 -07:00
|
|
|
episodeFile.Path = _episodeFileMover.MoveEpisodeFile(episodeFile, series);
|
2013-07-18 22:23:04 -07:00
|
|
|
|
|
|
|
_mediaFileService.Update(episodeFile);
|
|
|
|
renamed.Add(episodeFile);
|
|
|
|
|
2013-08-12 19:01:15 -07:00
|
|
|
_logger.Trace("Renamed episode file: {0}", episodeFile);
|
|
|
|
}
|
|
|
|
catch (SameFilenameException ex)
|
|
|
|
{
|
|
|
|
_logger.Trace("File not renamed, source and destination are the same: {0}", ex.Filename);
|
|
|
|
}
|
|
|
|
catch (Exception ex)
|
|
|
|
{
|
2013-08-29 23:41:49 -07:00
|
|
|
_logger.ErrorException("Failed to rename file: " + episodeFile.Path, ex);
|
2013-08-12 19:01:15 -07:00
|
|
|
}
|
2013-07-18 22:23:04 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
if (renamed.Any())
|
|
|
|
{
|
|
|
|
_messageAggregator.PublishEvent(new SeriesRenamedEvent(series));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public void Execute(RenameSeasonCommand message)
|
|
|
|
{
|
|
|
|
var series = _seriesService.GetSeries(message.SeriesId);
|
|
|
|
var episodeFiles = _mediaFileService.GetFilesBySeason(message.SeriesId, message.SeasonNumber);
|
|
|
|
|
2013-09-10 23:33:47 -07:00
|
|
|
_logger.ProgressInfo("Renaming {0} files for {1} season {2}", episodeFiles.Count, series.Title, message.SeasonNumber);
|
2013-07-18 22:23:04 -07:00
|
|
|
RenameFiles(episodeFiles, series);
|
2013-09-10 23:33:47 -07:00
|
|
|
_logger.ProgressInfo("Episode Fies renamed for {0} season {1}", series.Title, message.SeasonNumber);
|
2013-07-18 22:23:04 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
public void Execute(RenameSeriesCommand message)
|
|
|
|
{
|
|
|
|
var series = _seriesService.GetSeries(message.SeriesId);
|
|
|
|
var episodeFiles = _mediaFileService.GetFilesBySeries(message.SeriesId);
|
|
|
|
|
2013-09-10 23:33:47 -07:00
|
|
|
_logger.ProgressInfo("Renaming {0} files for {1}", episodeFiles.Count, series.Title);
|
2013-07-18 22:23:04 -07:00
|
|
|
RenameFiles(episodeFiles, series);
|
2013-09-10 23:33:47 -07:00
|
|
|
_logger.ProgressInfo("Episode Fies renamed for {0}", series.Title);
|
2013-07-18 22:23:04 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|