@ -19,7 +19,8 @@ namespace NzbDrone.Core.MediaFiles.EpisodeImport
{
{
List < ImportDecision > GetImportDecisions ( List < string > videoFiles , Series series ) ;
List < ImportDecision > GetImportDecisions ( List < string > videoFiles , Series series ) ;
List < ImportDecision > GetImportDecisions ( List < string > videoFiles , Movie movie ) ;
List < ImportDecision > GetImportDecisions ( List < string > videoFiles , Movie movie ) ;
List < ImportDecision > GetImportDecisions ( List < string > videoFiles , Movie movie , ParsedMovieInfo folderInfo , bool sceneSource ) ; //TODO: Needs changing to ParsedMovieInfo!!
List < ImportDecision > GetImportDecisions ( List < string > videoFiles , Movie movie , bool shouldCheckQuality ) ;
List < ImportDecision > GetImportDecisions ( List < string > videoFiles , Movie movie , ParsedMovieInfo folderInfo , bool sceneSource , bool shouldCheckQuality ) ; //TODO: Needs changing to ParsedMovieInfo!!
List < ImportDecision > GetImportDecisions ( List < string > videoFiles , Series series , ParsedEpisodeInfo folderInfo , bool sceneSource ) ;
List < ImportDecision > GetImportDecisions ( List < string > videoFiles , Series series , ParsedEpisodeInfo folderInfo , bool sceneSource ) ;
}
}
@ -31,6 +32,7 @@ namespace NzbDrone.Core.MediaFiles.EpisodeImport
private readonly IDiskProvider _diskProvider ;
private readonly IDiskProvider _diskProvider ;
private readonly IVideoFileInfoReader _videoFileInfoReader ;
private readonly IVideoFileInfoReader _videoFileInfoReader ;
private readonly IDetectSample _detectSample ;
private readonly IDetectSample _detectSample ;
private readonly IQualityDefinitionService _qualitiesService ;
private readonly Logger _logger ;
private readonly Logger _logger ;
public ImportDecisionMaker ( IEnumerable < IImportDecisionEngineSpecification > specifications ,
public ImportDecisionMaker ( IEnumerable < IImportDecisionEngineSpecification > specifications ,
@ -39,6 +41,7 @@ namespace NzbDrone.Core.MediaFiles.EpisodeImport
IDiskProvider diskProvider ,
IDiskProvider diskProvider ,
IVideoFileInfoReader videoFileInfoReader ,
IVideoFileInfoReader videoFileInfoReader ,
IDetectSample detectSample ,
IDetectSample detectSample ,
IQualityDefinitionService qualitiesService ,
Logger logger )
Logger logger )
{
{
_specifications = specifications ;
_specifications = specifications ;
@ -47,6 +50,7 @@ namespace NzbDrone.Core.MediaFiles.EpisodeImport
_diskProvider = diskProvider ;
_diskProvider = diskProvider ;
_videoFileInfoReader = videoFileInfoReader ;
_videoFileInfoReader = videoFileInfoReader ;
_detectSample = detectSample ;
_detectSample = detectSample ;
_qualitiesService = qualitiesService ;
_logger = logger ;
_logger = logger ;
}
}
@ -57,7 +61,12 @@ namespace NzbDrone.Core.MediaFiles.EpisodeImport
public List < ImportDecision > GetImportDecisions ( List < string > videoFiles , Movie movie )
public List < ImportDecision > GetImportDecisions ( List < string > videoFiles , Movie movie )
{
{
return GetImportDecisions ( videoFiles , movie , null , true ) ;
return GetImportDecisions ( videoFiles , movie , null , true , false ) ;
}
public List < ImportDecision > GetImportDecisions ( List < string > videoFiles , Movie movie , bool shouldCheckQuality = false )
{
return GetImportDecisions ( videoFiles , movie , null , true , shouldCheckQuality ) ;
}
}
public List < ImportDecision > GetImportDecisions ( List < string > videoFiles , Series series , ParsedEpisodeInfo folderInfo , bool sceneSource )
public List < ImportDecision > GetImportDecisions ( List < string > videoFiles , Series series , ParsedEpisodeInfo folderInfo , bool sceneSource )
@ -77,7 +86,7 @@ namespace NzbDrone.Core.MediaFiles.EpisodeImport
return decisions ;
return decisions ;
}
}
public List < ImportDecision > GetImportDecisions ( List < string > videoFiles , Movie movie , ParsedMovieInfo folderInfo , bool sceneSource )
public List < ImportDecision > GetImportDecisions ( List < string > videoFiles , Movie movie , ParsedMovieInfo folderInfo , bool sceneSource , bool shouldCheckQuality = false )
{
{
var newFiles = _mediaFileService . FilterExistingFiles ( videoFiles . ToList ( ) , movie ) ;
var newFiles = _mediaFileService . FilterExistingFiles ( videoFiles . ToList ( ) , movie ) ;
@ -88,13 +97,13 @@ namespace NzbDrone.Core.MediaFiles.EpisodeImport
foreach ( var file in newFiles )
foreach ( var file in newFiles )
{
{
decisions . AddIfNotNull ( GetDecision ( file , movie , folderInfo , sceneSource , shouldUseFolderName )) ;
decisions . AddIfNotNull ( GetDecision ( file , movie , folderInfo , sceneSource , shouldUseFolderName , shouldCheckQuality )) ;
}
}
return decisions ;
return decisions ;
}
}
private ImportDecision GetDecision ( string file , Movie movie , ParsedMovieInfo folderInfo , bool sceneSource , bool shouldUseFolderName )
private ImportDecision GetDecision ( string file , Movie movie , ParsedMovieInfo folderInfo , bool sceneSource , bool shouldUseFolderName , bool shouldCheckQuality = false )
{
{
ImportDecision decision = null ;
ImportDecision decision = null ;
@ -113,6 +122,106 @@ namespace NzbDrone.Core.MediaFiles.EpisodeImport
if ( sceneSource )
if ( sceneSource )
{
{
localMovie . MediaInfo = _videoFileInfoReader . GetMediaInfo ( file ) ;
localMovie . MediaInfo = _videoFileInfoReader . GetMediaInfo ( file ) ;
if ( shouldCheckQuality )
{
var width = localMovie . MediaInfo . Width ;
var current = localMovie . Quality ;
var qualityName = current . Quality . Name . ToLower ( ) ;
QualityModel updated = null ;
if ( width > 1400 )
{
if ( qualityName . Contains ( "bluray" ) )
{
updated = new QualityModel ( Quality . Bluray1080p ) ;
}
else if ( qualityName . Contains ( "webdl" ) )
{
updated = new QualityModel ( Quality . WEBDL1080p ) ;
}
else if ( qualityName . Contains ( "hdtv" ) )
{
updated = new QualityModel ( Quality . HDTV1080p ) ;
}
else
{
var def = _qualitiesService . Get ( Quality . HDTV1080p ) ;
if ( localMovie . Size > def . MinSize & & def . MaxSize > localMovie . Size )
{
updated = new QualityModel ( Quality . HDTV1080p ) ;
}
def = _qualitiesService . Get ( Quality . WEBDL1080p ) ;
if ( localMovie . Size > def . MinSize & & def . MaxSize > localMovie . Size )
{
updated = new QualityModel ( Quality . WEBDL1080p ) ;
}
def = _qualitiesService . Get ( Quality . Bluray1080p ) ;
if ( localMovie . Size > def . MinSize & & def . MaxSize > localMovie . Size )
{
updated = new QualityModel ( Quality . Bluray1080p ) ;
}
if ( updated = = null )
{
updated = new QualityModel ( Quality . Bluray1080p ) ;
}
}
}
else
if ( width > 900 )
{
if ( qualityName . Contains ( "bluray" ) )
{
updated = new QualityModel ( Quality . Bluray720p ) ;
}
else if ( qualityName . Contains ( "webdl" ) )
{
updated = new QualityModel ( Quality . WEBDL720p ) ;
}
else if ( qualityName . Contains ( "hdtv" ) )
{
updated = new QualityModel ( Quality . HDTV720p ) ;
}
else
{
var def = _qualitiesService . Get ( Quality . HDTV720p ) ;
if ( localMovie . Size > def . MinSize & & def . MaxSize > localMovie . Size )
{
updated = new QualityModel ( Quality . HDTV720p ) ;
}
def = _qualitiesService . Get ( Quality . WEBDL720p ) ;
if ( localMovie . Size > def . MinSize & & def . MaxSize > localMovie . Size )
{
updated = new QualityModel ( Quality . WEBDL720p ) ;
}
def = _qualitiesService . Get ( Quality . Bluray720p ) ;
if ( localMovie . Size > def . MinSize & & def . MaxSize > localMovie . Size )
{
updated = new QualityModel ( Quality . Bluray720p ) ;
}
if ( updated = = null )
{
updated = new QualityModel ( Quality . Bluray720p ) ;
}
}
}
if ( updated ! = null & & updated ! = current )
{
updated . QualitySource = QualitySource . MediaInfo ;
localMovie . Quality = updated ;
}
}
decision = GetDecision ( localMovie ) ;
decision = GetDecision ( localMovie ) ;
}
}
else
else