Skip to content

Commit

Permalink
Merge pull request #646 from linaspurinis/master
Browse files Browse the repository at this point in the history
Support for mdblist.com "limit" variable to limit returned items for a list
  • Loading branch information
meisnate12 authored Jan 24, 2022
2 parents 38818e8 + 440cb7f commit 90814e4
Show file tree
Hide file tree
Showing 2 changed files with 39 additions and 3 deletions.
3 changes: 2 additions & 1 deletion modules/builder.py
Original file line number Diff line number Diff line change
Expand Up @@ -1080,7 +1080,8 @@ def _stevenlu(self, method_name, method_data):
self.builders.append((method_name, self._parse(method_name, method_data, "bool")))

def _mdblist(self, method_name, method_data):
self.builders.append((method_name, self._parse(method_name, method_data, datatype="true")))
for mdb_dict in self.config.Mdblist.validate_mdb_lists(method_data, self.language):
self.builders.append((method_name, mdb_dict))

def _tautulli(self, method_name, method_data):
for dict_data, dict_methods in self._parse(method_name, method_data, datatype="dictlist"):
Expand Down
39 changes: 37 additions & 2 deletions modules/mdblist.py
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
import logging
from modules import util
from modules.util import Failed

logger = logging.getLogger("Plex Meta Manager")
Expand All @@ -12,9 +13,43 @@ class Mdblist:
def __init__(self, config):
self.config = config

def validate_mdb_lists(self, mdb_lists, language):
valid_lists = []
for mdb_dict in util.get_list(mdb_lists, split=False):
if not isinstance(mdb_dict, dict):
mdb_dict = {"url": mdb_dict}
dict_methods = {dm.lower(): dm for dm in mdb_dict}
if "url" not in dict_methods:
raise Failed(f"Collection Error: mdb_list url attribute not found")
elif mdb_dict[dict_methods["url"]] is None:
raise Failed(f"Collection Error: mdb_list url attribute is blank")
else:
mdb_url = mdb_dict[dict_methods["url"]].strip()
if not mdb_url.startswith(base_url):
raise Failed(f"Mdblist Error: {mdb_url} must begin with: {base_url}")
list_count = None
if "limit" in dict_methods:
if mdb_dict[dict_methods["limit"]] is None:
logger.warning(f"Collection Warning: mdb_list limit attribute is blank using 0 as default")
else:
try:
value = int(str(mdb_dict[dict_methods["limit"]]))
if 0 <= value:
list_count = value
except ValueError:
pass
if list_count is None:
logger.warning(f"Collection Warning: mdb_list limit attribute must be an integer 0 or greater using 0 as default")
if list_count is None:
list_count = 0
valid_lists.append({"url": mdb_url, "limit": list_count})
return valid_lists

def get_mdblist_ids(self, method, data):
if method == "mdblist_list":
logger.info(f"Processing Mdblist.com List: {data}")
return [(i["imdb_id"], "imdb") for i in self.config.get_json(data,headers=headers)]
limit_status = f" Limit at: {data['limit']} items" if data['limit'] > 0 else ''
logger.info(f"Processing Mdblist.com List: {data['url']}{limit_status}")
url = f"{data['url']}?limit={data['limit']}"
return [(i["imdb_id"], "imdb") for i in self.config.get_json(url,headers=headers)]
else:
raise Failed(f"Mdblist Error: Method {method} not supported")

0 comments on commit 90814e4

Please sign in to comment.