2013-03-02 21:26:28 +01:00
|
|
|
# ex:ts=4:sw=4:sts=4:et
|
|
|
|
# -*- tab-width: 4; c-basic-offset: 4; indent-tabs-mode: nil -*-
|
2013-03-01 23:39:42 +01:00
|
|
|
from __future__ import absolute_import
|
2013-02-12 19:43:37 +01:00
|
|
|
import re
|
|
|
|
import json
|
|
|
|
|
2013-04-21 12:44:31 +02:00
|
|
|
from svtplay_dl.service import Service
|
2013-03-17 19:55:19 +01:00
|
|
|
from svtplay_dl.utils import get_http_data, select_quality
|
|
|
|
from svtplay_dl.fetcher.rtmp import download_rtmp
|
2013-02-12 19:43:37 +01:00
|
|
|
|
2013-04-21 12:44:31 +02:00
|
|
|
class Dr(Service):
|
2013-01-17 00:21:47 +01:00
|
|
|
def handle(self, url):
|
|
|
|
return "dr.dk" in url
|
|
|
|
|
|
|
|
def get(self, options, url):
|
|
|
|
data = get_http_data(url)
|
|
|
|
match = re.search(r'resource:[ ]*"([^"]*)",', data)
|
|
|
|
resource_url = match.group(1)
|
|
|
|
resource_data = get_http_data(resource_url)
|
|
|
|
resource = json.loads(resource_data)
|
|
|
|
streams = {}
|
|
|
|
for stream in resource['links']:
|
|
|
|
streams[stream['bitrateKbps']] = stream['uri']
|
|
|
|
if len(streams) == 1:
|
|
|
|
uri = streams[list(streams.keys())[0]]
|
|
|
|
else:
|
|
|
|
uri = select_quality(options, streams)
|
|
|
|
# need -v ?
|
|
|
|
options.other = "-v -y '" + uri.replace("rtmp://vod.dr.dk/cms/", "") + "'"
|
|
|
|
download_rtmp(options, uri)
|
|
|
|
|