mirror of
https://github.com/spaam/svtplay-dl.git
synced 2024-12-01 07:34:16 +01:00
9f9bcad0c7
The default handle method will look for a supported_domains attribute (a list), containing the supported domains. The subclassed service class can of course override this if other means of determining support is needded.
40 lines
1.2 KiB
Python
40 lines
1.2 KiB
Python
# ex:ts=4:sw=4:sts=4:et
|
|
# -*- tab-width: 4; c-basic-offset: 4; indent-tabs-mode: nil -*-
|
|
|
|
# pylint has issues with urlparse: "some types could not be inferred"
|
|
# pylint: disable=E1103
|
|
|
|
from __future__ import absolute_import
|
|
import sys
|
|
import re
|
|
import xml.etree.ElementTree as ET
|
|
|
|
from svtplay_dl.utils.urllib import urlparse, parse_qs, unquote_plus
|
|
from svtplay_dl.service import Service
|
|
from svtplay_dl.utils import get_http_data
|
|
from svtplay_dl.log import log
|
|
from svtplay_dl.fetcher.http import download_http
|
|
|
|
class Sr(Service):
|
|
supported_domains = ['sverigesradio.se']
|
|
|
|
def get(self, options, url):
|
|
data = get_http_data(url)
|
|
parse = urlparse(url)
|
|
|
|
if "metafile" in parse_qs(parse.query):
|
|
options.other = "%s?%s" % (parse.path, parse.query)
|
|
else:
|
|
match = re.search(r"linkUrl=(.*)\;isButton=", data)
|
|
if not match:
|
|
log.error("Can't find video file")
|
|
sys.exit(2)
|
|
options.other = unquote_plus(match.group(1))
|
|
|
|
url = "http://sverigesradio.se%s" % options.other
|
|
data = get_http_data(url)
|
|
xml = ET.XML(data)
|
|
url = xml.find("entry").find("ref").attrib["href"]
|
|
download_http(options, url)
|
|
|