1
0
mirror of https://github.com/spaam/svtplay-dl.git synced 2024-11-27 21:54:17 +01:00
svtplay-dl/lib/svtplay_dl/service/riksdagen.py
2020-05-03 11:35:03 +02:00

39 lines
1.3 KiB
Python

import copy
import re
from svtplay_dl.error import ServiceError
from svtplay_dl.fetcher.hls import hlsparse
from svtplay_dl.fetcher.http import HTTP
from svtplay_dl.service import OpenGraphThumbMixin
from svtplay_dl.service import Service
class Riksdagen(Service, OpenGraphThumbMixin):
supported_domains_re = ["riksdagen.se", "www.riksdagen.se"]
def get(self):
match = re.search("_([a-zA-Z0-9]+)$", self.url)
if not match:
yield ServiceError("Cant find video id.")
return
vid = match.group(1)
res = self.http.get("http://www.riksdagen.se/api/videostream/get/%s" % vid)
data = res.json()
try:
janson = data["videodata"][0]["streams"]["files"]
except TypeError:
yield ServiceError("Cant find video.")
return
for i in janson:
if i["mimetype"] == "application/x-mpegurl":
data2 = self.http.get(i["url"]).json()
streams = hlsparse(self.config, self.http.request("get", data2["url"]), data2["url"], output=self.output)
for n in list(streams.keys()):
yield streams[n]
if i["mimetype"] == "video/mp4":
for n in i["bandwidth"]:
yield HTTP(copy.copy(self.config), n["url"], n["quality"], output=self.output)