mirror of
https://github.com/SickGear/SickGear.git
synced 2025-01-07 10:33:38 +00:00
Merge pull request #797 from JackDandy/feature/ChangeInfoSrcRateLimit
Change add rate limit handler for info source.
This commit is contained in:
commit
86dc477c71
2 changed files with 22 additions and 3 deletions
|
@ -198,6 +198,7 @@
|
|||
* Fix issue with post processing propers/repacks
|
||||
* Change use legacy tzlocal() if new gettz fails to create
|
||||
* Change load cached images on demand
|
||||
* Change add rate limit handler for info source
|
||||
|
||||
|
||||
### 0.11.16 (2016-10-16 17:30:00 UTC)
|
||||
|
|
|
@ -32,7 +32,9 @@ from sickbeard.indexers.indexer_config import (INDEXER_TVDB, INDEXER_TVRAGE, IND
|
|||
INDEXER_IMDB, INDEXER_TRAKT, INDEXER_TMDB)
|
||||
from lib.tmdb_api import TMDB
|
||||
from lib.imdb import IMDb
|
||||
from time import sleep
|
||||
|
||||
tv_maze_retry_wait = 10
|
||||
defunct_indexer = []
|
||||
indexer_list = []
|
||||
tmdb_ids = {INDEXER_TVDB: 'tvdb_id', INDEXER_IMDB: 'imdb_id', INDEXER_TVRAGE: 'tvrage_id'}
|
||||
|
@ -94,18 +96,34 @@ class TraktDict(OrderedDict):
|
|||
(self[key], '%07d' % self[key])[key == INDEXER_IMDB])
|
||||
|
||||
|
||||
def get_tvmaze_data(count=0, *args, **kwargs):
|
||||
res = None
|
||||
count += 1
|
||||
if 3 >= count:
|
||||
try:
|
||||
res = getURL(*args, **kwargs)
|
||||
except requests.HTTPError as e:
|
||||
# rate limit
|
||||
if 429 == e.response.status_code:
|
||||
sleep(tv_maze_retry_wait)
|
||||
return get_tvmaze_data(*args, count=count, **kwargs)
|
||||
except (StandardError, Exception):
|
||||
pass
|
||||
return res
|
||||
|
||||
|
||||
def get_tvmaze_ids(url_tvmaze):
|
||||
ids = {}
|
||||
for url_key in url_tvmaze.iterkeys():
|
||||
try:
|
||||
res = getURL(url=url_tvmaze.get_url(url_key), json=True, raise_status_code=True, timeout=120)
|
||||
res = get_tvmaze_data(url=url_tvmaze.get_url(url_key), json=True, raise_status_code=True, timeout=120)
|
||||
if res and 'externals' in res:
|
||||
ids[INDEXER_TVRAGE] = res['externals'].get('tvrage', 0)
|
||||
ids[INDEXER_TVDB] = res['externals'].get('thetvdb', 0)
|
||||
ids[INDEXER_IMDB] = tryInt(str(res['externals'].get('imdb')).replace('tt', ''))
|
||||
ids[INDEXER_TVMAZE] = res.get('id', 0)
|
||||
break
|
||||
except (requests.HTTPError, Exception):
|
||||
except (StandardError, Exception):
|
||||
pass
|
||||
return {k: v for k, v in ids.iteritems() if v not in (None, '', 0)}
|
||||
|
||||
|
@ -129,7 +147,7 @@ def get_tvmaze_by_name(showname, premiere_date):
|
|||
try:
|
||||
url = '%ssearch/shows?%s' % (sickbeard.indexerApi(INDEXER_TVMAZE).config['base_url'],
|
||||
urlencode({'q': clean_show_name(showname)}))
|
||||
res = getURL(url=url, json=True, raise_status_code=True, timeout=120)
|
||||
res = get_tvmaze_data(url=url, json=True, raise_status_code=True, timeout=120)
|
||||
if res:
|
||||
for r in res:
|
||||
if 'show' in r and 'premiered' in r['show'] and 'externals' in r['show']:
|
||||
|
|
Loading…
Reference in a new issue