@ -25,47 +25,30 @@ namespace NzbDrone.Core.Download.Clients
_diskProvider = diskProvider ;
_diskProvider = diskProvider ;
}
}
public v irtual bool DownloadNzb ( RemoteEpisode remoteEpisode )
public v oid DownloadNzb ( RemoteEpisode remoteEpisode )
{
{
var url = remoteEpisode . Report . NzbUrl ;
var url = remoteEpisode . Report . NzbUrl ;
var title = remoteEpisode . Report . Title ;
var title = remoteEpisode . Report . Title ;
try
if ( remoteEpisode . ParsedEpisodeInfo . FullSeason )
{
{
//Todo: Allow full season releases
throw new NotImplementedException ( "Full season Pneumatic releases are not supported." ) ;
if ( remoteEpisode . ParsedEpisodeInfo . FullSeason )
}
{
logger . Info ( "Skipping Full Season Release: {0}" , title ) ;
return false ;
}
title = FileNameBuilder . CleanFilename ( title ) ;
//Save to the Pneumatic directory (The user will need to ensure its accessible by XBMC)
title = FileNameBuilder . CleanFilename ( title ) ;
var filename = Path . Combine ( _configService . PneumaticFolder , title + ".nzb" ) ;
if ( _diskProvider . FileExists ( filename ) )
//Save to the Pneumatic directory (The user will need to ensure its accessible by XBMC)
{
var filename = Path . Combine ( _configService . PneumaticFolder , title + ".nzb" ) ;
//Return true so a lesser quality is not returned.
logger . Info ( "NZB already exists on disk: {0}" , filename ) ;
return true ;
}
logger . Trace ( "Downloading NZB from: {0} to: {1}" , url , filename ) ;
_httpProvider . DownloadFile ( url , filename ) ;
logger . Trace ( "NZB Download succeeded, saved to: {0}" , filename ) ;
logger . Trace ( "Downloading NZB from: {0} to: {1}" , url , filename ) ;
_httpProvider . DownloadFile ( url , filename ) ;
var contents = String . Format ( "plugin://plugin.program.pneumatic/?mode=strm&type=add_file&nzb={0}&nzbname={1}" , filename , title ) ;
logger . Trace ( "NZB Download succeeded, saved to: {0}" , filename ) ;
_diskProvider . WriteAllText ( Path . Combine ( _configService . DownloadedEpisodesFolder , title + ".strm" ) , contents ) ;
return true ;
var contents = String . Format ( "plugin://plugin.program.pneumatic/?mode=strm&type=add_file&nzb={0}&nzbname={1}" , filename , title ) ;
}
_diskProvider . WriteAllText ( Path . Combine ( _configService . DownloadedEpisodesFolder , title + ".strm" ) , contents ) ;
catch ( Exception ex )
{
logger . WarnException ( "Failed to download NZB: " + url , ex ) ;
return false ;
}
}
}
public bool IsConfigured
public bool IsConfigured