using System.IO;
using NLog;
using NzbDrone.Common;
using NzbDrone.Core.Parser.Model;

namespace NzbDrone.Core.MediaFiles.EpisodeImport.Specifications
{
    public class NotInUseSpecification : IImportDecisionEngineSpecification
    {
        private readonly IDiskProvider _diskProvider;
        private readonly Logger _logger;

        public NotInUseSpecification(IDiskProvider diskProvider, Logger logger)
        {
            _diskProvider = diskProvider;
            _logger = logger;
        }

        public string RejectionReason { get { return "File is in use"; } }

        public bool IsSatisfiedBy(LocalEpisode localEpisode)
        {
            if (_diskProvider.IsParent(localEpisode.Series.Path, localEpisode.Path))
            {
                _logger.Trace("{0} is in series folder, skipping in use check", localEpisode.Path);
                return true;
            }

            if (_diskProvider.IsFileLocked(new FileInfo(localEpisode.Path)))
            {
                _logger.Trace("{0} is in use");
                return false;
            }

            return true;
        }
    }
}