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.

52 lines
1.8 KiB

14 years ago
from __future__ import with_statement
from couchpotato.core.downloaders.base import Downloader
14 years ago
from couchpotato.core.helpers.encoding import toSafeString
from couchpotato.core.logger import CPLog
from inspect import isfunction
14 years ago
import os
import traceback
14 years ago
import urllib
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')):
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))
if isfunction(data.get('download')):
file = data.get('download')()
if not file:
log.debug('Failed download file: %s' % data.get('name'))
return False
else:
log.info('Downloading: %s' % data.get('url'))
file = urllib.urlopen(data.get('url')).read()
with open(fullPath, 'wb') as f:
f.write(file)
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