1
0
mirror of https://github.com/spaam/svtplay-dl.git synced 2024-11-27 13:44:14 +01:00

svtplay: support for lists

This commit is contained in:
Johan Andersson 2023-05-11 20:05:37 +02:00
parent a7eb33b6c0
commit c2ee949415

View File

@ -117,6 +117,25 @@ class Svtplay(Service, MetadataThumbMixin):
elif i["url"].find(".mpd") > 0: elif i["url"].find(".mpd") > 0:
yield from dashparse(self.config, self.http.request("get", i["url"]), i["url"], output=self.output) yield from dashparse(self.config, self.http.request("get", i["url"]), i["url"], output=self.output)
def _lists(self):
videos = []
match = re.search(self.info_search_expr, self.get_urldata())
if not match:
logging.error("Can't find video info.")
return videos
janson = json.loads(match.group(1))
data = None
for data_entry in janson["props"]["urqlState"].values():
if "data" in data_entry:
entry = json.loads(data_entry["data"])
if "selectionById" in entry:
data = entry
if data:
for i in data["selectionById"]["items"]:
videos.append(urljoin("http://www.svtplay.se", i["item"]["urls"]["svtplay"]))
return videos
def _last_chance(self): def _last_chance(self):
videos = [] videos = []
match = re.search(self.info_search_expr, self.get_urldata()) match = re.search(self.info_search_expr, self.get_urldata())
@ -229,6 +248,8 @@ class Svtplay(Service, MetadataThumbMixin):
episodes = self._last_chance() episodes = self._last_chance()
elif re.search("^/genre", parse.path): elif re.search("^/genre", parse.path):
episodes = self._genre() episodes = self._genre()
elif re.search("^/lista", parse.path):
episodes = self._lists()
else: else:
episodes = self._all_episodes(self.url) episodes = self._all_episodes(self.url)