You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

57 lines
2.2 KiB

from couchpotato.core.downloaders.base import Downloader
14 years ago
from couchpotato.core.helpers.encoding import toSafeString
from couchpotato.core.logger import CPLog
import os
import traceback
14 years ago
log = CPLog(__name__)
class Blackhole(Downloader):
type = ['nzb', 'torrent']
def download(self, data = {}, movie = {}):
14 years ago
if self.isDisabled() or not self.isCorrectType(data.get('type') or not self.conf('use_for') in ['both', data.get('type')]):
14 years ago
return
directory = self.conf('directory')
if not directory or not os.path.isdir(directory):
log.error('No directory set for blackhole %s download.' % data.get('type'))
else:
fullPath = os.path.join(directory, '%s%s.%s' % (toSafeString(data.get('name')), self.cpTag(movie) , data.get('type')))
try:
if not os.path.isfile(fullPath):
log.info('Downloading %s to %s.' % (data.get('type'), fullPath))
14 years ago
try:
file = data.get('download')(url = data.get('url'), nzb_id = data.get('id'))
# error handling for nzbs that aren't available
if "no nzb" in file:
log.error('No nzb available!')
return False
# some providers provide nzbs that are rarred, save these with the proper extension
if "DOCTYPE nzb" not in file:
if data.get('type') == 'nzb':
fullPath = os.path.join(directory, '%s%s.%s' % (toSafeString(data.get('name')), self.cpTag(movie) , 'rar'))
with open(fullPath, 'wb') as f:
f.write(file)
except:
14 years ago
log.debug('Failed download file: %s' % data.get('name'))
return False
return True
else:
log.info('File %s already exists.' % fullPath)
return True
except:
log.error('Failed to download to blackhole %s' % traceback.format_exc())
pass
14 years ago
return False