|
|
@ -2,6 +2,7 @@ from urllib2 import HTTPError |
|
|
|
from urlparse import urlparse |
|
|
|
import time |
|
|
|
import traceback |
|
|
|
import re |
|
|
|
import urllib2 |
|
|
|
|
|
|
|
from couchpotato.core.helpers.encoding import tryUrlencode, toUnicode |
|
|
@ -20,10 +21,11 @@ log = CPLog(__name__) |
|
|
|
class Base(NZBProvider, RSS): |
|
|
|
|
|
|
|
urls = { |
|
|
|
'detail': 'details&id=%s', |
|
|
|
'detail': 'details/%s', |
|
|
|
'download': 't=get&id=%s' |
|
|
|
} |
|
|
|
|
|
|
|
passwords_regex = 'password|wachtwoord' |
|
|
|
limits_reached = {} |
|
|
|
|
|
|
|
http_time_between_calls = 1 # Seconds |
|
|
@ -44,9 +46,7 @@ class Base(NZBProvider, RSS): |
|
|
|
def _searchOnHost(self, host, media, quality, results): |
|
|
|
|
|
|
|
query = self.buildUrl(media, host['api_key']) |
|
|
|
|
|
|
|
url = '%s&%s' % (self.getUrl(host['host']), query) |
|
|
|
|
|
|
|
nzbs = self.getRSSData(url, cache_timeout = 1800, headers = {'User-Agent': Env.getIdentifier()}) |
|
|
|
|
|
|
|
for nzb in nzbs: |
|
|
@ -79,6 +79,23 @@ class Base(NZBProvider, RSS): |
|
|
|
if spotter: |
|
|
|
name_extra = spotter |
|
|
|
|
|
|
|
description = '' |
|
|
|
if "@spot.net" in nzb_id: |
|
|
|
try: |
|
|
|
# Get details for extended description to retrieve passwords |
|
|
|
query = self.buildDetailsUrl(nzb_id, host['api_key']) |
|
|
|
url = '%s&%s' % (self.getUrl(host['host']), query) |
|
|
|
nzb_details = self.getRSSData(url, cache_timeout = 1800, headers = {'User-Agent': Env.getIdentifier()})[0] |
|
|
|
|
|
|
|
description = self.getTextElement(nzb_details, 'description') |
|
|
|
|
|
|
|
# Extract a password from the description |
|
|
|
password = re.search('(?:' + self.passwords_regex + ')(?: *)(?:\:|\=)(?: *)(.*?)\<br\>|\n|$', description, flags = re.I).group(1) |
|
|
|
if password: |
|
|
|
name = name + ' {{%s}}' % password.strip() |
|
|
|
except: |
|
|
|
log.debug('Error getting details of "%s": %s', (name, traceback.format_exc())) |
|
|
|
|
|
|
|
results.append({ |
|
|
|
'id': nzb_id, |
|
|
|
'provider_extra': urlparse(host['host']).hostname or host['host'], |
|
|
@ -87,8 +104,9 @@ class Base(NZBProvider, RSS): |
|
|
|
'age': self.calculateAge(int(time.mktime(parse(date).timetuple()))), |
|
|
|
'size': int(self.getElement(nzb, 'enclosure').attrib['length']) / 1024 / 1024, |
|
|
|
'url': ((self.getUrl(host['host']) + self.urls['download']) % tryUrlencode(nzb_id)) + self.getApiExt(host), |
|
|
|
'detail_url': '%sdetails/%s' % (cleanHost(host['host']), tryUrlencode(nzb_id)), |
|
|
|
'detail_url': (cleanHost(host['host']) + self.urls['detail']) % tryUrlencode(nzb_id), |
|
|
|
'content': self.getTextElement(nzb, 'description'), |
|
|
|
'description': description, |
|
|
|
'score': host['extra_score'], |
|
|
|
}) |
|
|
|
|
|
|
@ -191,6 +209,15 @@ class Base(NZBProvider, RSS): |
|
|
|
|
|
|
|
return 'try_next' |
|
|
|
|
|
|
|
def buildDetailsUrl(self, nzb_id, api_key): |
|
|
|
query = tryUrlencode({ |
|
|
|
't': 'details', |
|
|
|
'id': nzb_id, |
|
|
|
'apikey': api_key, |
|
|
|
}) |
|
|
|
return query |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
config = [{ |
|
|
|
'name': 'newznab', |
|
|
|