mirror of https://github.com/l3uddz/traktarr
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.
77 lines
3.1 KiB
77 lines
3.1 KiB
7 years ago
|
from misc.log import logger
|
||
|
import json
|
||
|
import requests
|
||
|
|
||
|
log = logger.get_logger(__name__)
|
||
6 years ago
|
|
||
|
|
||
5 years ago
|
def get_movie_rt_score(omdb_api_key, movie_title, movie_year, movie_imdb_id):
|
||
5 years ago
|
"""
|
||
|
Lookup movie ratings via OMDb
|
||
|
|
||
5 years ago
|
:param omdb_api_key: OMDb API Key
|
||
|
:param movie_title: Movie Title
|
||
|
:param movie_year: Movie Year
|
||
|
:param movie_imdb_id: Movie IMDb ID
|
||
|
:return: Rating score (int) or False if no rating found
|
||
5 years ago
|
"""
|
||
6 years ago
|
|
||
6 years ago
|
ratings_exist = False
|
||
5 years ago
|
|
||
5 years ago
|
if movie_imdb_id:
|
||
5 years ago
|
log.debug("Requesting info from OMDb for: \'%s (%s)\' [IMDb ID: %s]",
|
||
5 years ago
|
movie_title,
|
||
5 years ago
|
movie_year,
|
||
5 years ago
|
movie_imdb_id)
|
||
|
r = requests.get('http://www.omdbapi.com/?i=' + movie_imdb_id + '&apikey=' + omdb_api_key)
|
||
6 years ago
|
if r.status_code == 200 and json.loads(r.text)["Response"] == 'True':
|
||
5 years ago
|
log.debug("Successfully requested ratings from OMDB for \'%s (%s)\' [IMDb ID: %s]",
|
||
5 years ago
|
movie_title,
|
||
5 years ago
|
movie_year,
|
||
5 years ago
|
movie_imdb_id)
|
||
7 years ago
|
for source in json.loads(r.text)["Ratings"]:
|
||
6 years ago
|
if source['Source'] == 'Rotten Tomatoes':
|
||
6 years ago
|
# noinspection PyUnusedLocal
|
||
|
ratings_exist = True
|
||
5 years ago
|
log.debug("Rotten Tomatoes score for \'%s (%s)\' [IMDb ID: %s]: %s",
|
||
|
movie_title,
|
||
5 years ago
|
movie_year,
|
||
5 years ago
|
movie_imdb_id,
|
||
|
source['Value'])
|
||
7 years ago
|
return int(source['Value'].split('%')[0])
|
||
6 years ago
|
if not ratings_exist:
|
||
5 years ago
|
log.debug("No Rotten Tomatoes score found for: \'%s (%s)\' [IMDb ID: %s]",
|
||
5 years ago
|
movie_title,
|
||
5 years ago
|
movie_year,
|
||
5 years ago
|
movie_imdb_id)
|
||
7 years ago
|
else:
|
||
5 years ago
|
log.debug("Error encountered when requesting ratings from OMDb for: \'%s (%s)\' [IMDb ID: %s]",
|
||
5 years ago
|
movie_title,
|
||
5 years ago
|
movie_year,
|
||
5 years ago
|
movie_imdb_id)
|
||
7 years ago
|
else:
|
||
6 years ago
|
log.debug("Skipping OMDb ratings lookup because no IMDb ID was found for: \'%s (%s)\'",
|
||
5 years ago
|
movie_title,
|
||
5 years ago
|
movie_year)
|
||
|
|
||
|
return False
|
||
|
|
||
|
|
||
5 years ago
|
def does_movie_have_min_req_rt_score(omdb_api_key, movie_title, movie_year, movie_imdb_id, min_req_rt_score):
|
||
5 years ago
|
|
||
|
# pull RT score
|
||
5 years ago
|
movie_rt_score = get_movie_rt_score(omdb_api_key, movie_title, movie_year, movie_imdb_id)
|
||
7 years ago
|
|
||
5 years ago
|
if not movie_rt_score:
|
||
5 years ago
|
log.info("SKIPPING: \'%s (%s)\' because a Rotten Tomatoes score could not be found.", movie_title,
|
||
5 years ago
|
movie_year)
|
||
|
return False
|
||
5 years ago
|
elif movie_rt_score < min_req_rt_score:
|
||
5 years ago
|
log.info("SKIPPING: \'%s (%s)\' because its Rotten Tomatoes score of %d%% is below the required score of %d%%.",
|
||
5 years ago
|
movie_title, movie_year, movie_rt_score, min_req_rt_score)
|
||
5 years ago
|
return False
|
||
5 years ago
|
elif movie_rt_score >= min_req_rt_score:
|
||
5 years ago
|
log.info("ADDING: \'%s (%s)\' because its Rotten Tomatoes score of %d%% is above the required score of %d%%.",
|
||
5 years ago
|
movie_title, movie_year, movie_rt_score, min_req_rt_score)
|
||
5 years ago
|
return True
|