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

40 lines
1.3 KiB
Python
Raw Normal View History

2016-09-02 01:20:54 +02:00
from __future__ import absolute_import
import re
import copy
2016-09-02 01:20:54 +02:00
from svtplay_dl.fetcher.hls import hlsparse
from svtplay_dl.fetcher.http import HTTP
2016-09-02 01:20:54 +02:00
from svtplay_dl.service import Service, OpenGraphThumbMixin
from svtplay_dl.error import ServiceError
class Riksdagen(Service, OpenGraphThumbMixin):
supported_domains_re = ["riksdagen.se", "www.riksdagen.se"]
2016-09-02 01:20:54 +02:00
def get(self):
match = re.search("_([a-zA-Z0-9]+)$", self.url)
2016-09-02 01:20:54 +02:00
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)
2018-05-08 22:48:55 +02:00
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)