Merge pull request #797 from JackDandy/feature/ChangeInfoSrcRateLimit

Change add rate limit handler for info source.
This commit is contained in:
JackDandy 2016-10-06 21:13:50 +01:00 committed by GitHub
commit 86dc477c71
2 changed files with 22 additions and 3 deletions

View file

@ -198,6 +198,7 @@
* Fix issue with post processing propers/repacks * Fix issue with post processing propers/repacks
* Change use legacy tzlocal() if new gettz fails to create * Change use legacy tzlocal() if new gettz fails to create
* Change load cached images on demand * Change load cached images on demand
* Change add rate limit handler for info source
### 0.11.16 (2016-10-16 17:30:00 UTC) ### 0.11.16 (2016-10-16 17:30:00 UTC)

View file

@ -32,7 +32,9 @@ from sickbeard.indexers.indexer_config import (INDEXER_TVDB, INDEXER_TVRAGE, IND
INDEXER_IMDB, INDEXER_TRAKT, INDEXER_TMDB) INDEXER_IMDB, INDEXER_TRAKT, INDEXER_TMDB)
from lib.tmdb_api import TMDB from lib.tmdb_api import TMDB
from lib.imdb import IMDb from lib.imdb import IMDb
from time import sleep
tv_maze_retry_wait = 10
defunct_indexer = [] defunct_indexer = []
indexer_list = [] indexer_list = []
tmdb_ids = {INDEXER_TVDB: 'tvdb_id', INDEXER_IMDB: 'imdb_id', INDEXER_TVRAGE: 'tvrage_id'} 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]) (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): def get_tvmaze_ids(url_tvmaze):
ids = {} ids = {}
for url_key in url_tvmaze.iterkeys(): for url_key in url_tvmaze.iterkeys():
try: 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: if res and 'externals' in res:
ids[INDEXER_TVRAGE] = res['externals'].get('tvrage', 0) ids[INDEXER_TVRAGE] = res['externals'].get('tvrage', 0)
ids[INDEXER_TVDB] = res['externals'].get('thetvdb', 0) ids[INDEXER_TVDB] = res['externals'].get('thetvdb', 0)
ids[INDEXER_IMDB] = tryInt(str(res['externals'].get('imdb')).replace('tt', '')) ids[INDEXER_IMDB] = tryInt(str(res['externals'].get('imdb')).replace('tt', ''))
ids[INDEXER_TVMAZE] = res.get('id', 0) ids[INDEXER_TVMAZE] = res.get('id', 0)
break break
except (requests.HTTPError, Exception): except (StandardError, Exception):
pass pass
return {k: v for k, v in ids.iteritems() if v not in (None, '', 0)} 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: try:
url = '%ssearch/shows?%s' % (sickbeard.indexerApi(INDEXER_TVMAZE).config['base_url'], url = '%ssearch/shows?%s' % (sickbeard.indexerApi(INDEXER_TVMAZE).config['base_url'],
urlencode({'q': clean_show_name(showname)})) 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: if res:
for r in res: for r in res:
if 'show' in r and 'premiered' in r['show'] and 'externals' in r['show']: if 'show' in r and 'premiered' in r['show'] and 'externals' in r['show']: