1
0
mirror of https://github.com/spaam/svtplay-dl.git synced 2024-11-24 12:15:40 +01:00
svtplay-dl/lib/svtplay_dl/service/riksdagen.py
Johan Andersson 3aef9a796e black fixes
2019-09-06 22:31:52 +02:00

51 lines
1.6 KiB
Python

from __future__ import absolute_import
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,
)