mirror of
https://github.com/yt-dlp/yt-dlp.git
synced 2024-11-10 15:14:57 +00:00
[extractor/zattoo] Fix Zattoo resellers (#4675)
Closes #4630 Authored by: goggle
This commit is contained in:
parent
25836db6be
commit
f60ef66371
2 changed files with 481 additions and 57 deletions
|
@ -2200,17 +2200,41 @@ from .youtube import (
|
||||||
from .zapiks import ZapiksIE
|
from .zapiks import ZapiksIE
|
||||||
from .zattoo import (
|
from .zattoo import (
|
||||||
BBVTVIE,
|
BBVTVIE,
|
||||||
|
BBVTVLiveIE,
|
||||||
|
BBVTVRecordingsIE,
|
||||||
EinsUndEinsTVIE,
|
EinsUndEinsTVIE,
|
||||||
|
EinsUndEinsTVLiveIE,
|
||||||
|
EinsUndEinsTVRecordingsIE,
|
||||||
EWETVIE,
|
EWETVIE,
|
||||||
|
EWETVLiveIE,
|
||||||
|
EWETVRecordingsIE,
|
||||||
GlattvisionTVIE,
|
GlattvisionTVIE,
|
||||||
|
GlattvisionTVLiveIE,
|
||||||
|
GlattvisionTVRecordingsIE,
|
||||||
MNetTVIE,
|
MNetTVIE,
|
||||||
NetPlusIE,
|
MNetTVLiveIE,
|
||||||
|
MNetTVRecordingsIE,
|
||||||
|
NetPlusTVIE,
|
||||||
|
NetPlusTVLiveIE,
|
||||||
|
NetPlusTVRecordingsIE,
|
||||||
OsnatelTVIE,
|
OsnatelTVIE,
|
||||||
|
OsnatelTVLiveIE,
|
||||||
|
OsnatelTVRecordingsIE,
|
||||||
QuantumTVIE,
|
QuantumTVIE,
|
||||||
|
QuantumTVLiveIE,
|
||||||
|
QuantumTVRecordingsIE,
|
||||||
SaltTVIE,
|
SaltTVIE,
|
||||||
|
SaltTVLiveIE,
|
||||||
|
SaltTVRecordingsIE,
|
||||||
SAKTVIE,
|
SAKTVIE,
|
||||||
|
SAKTVLiveIE,
|
||||||
|
SAKTVRecordingsIE,
|
||||||
VTXTVIE,
|
VTXTVIE,
|
||||||
|
VTXTVLiveIE,
|
||||||
|
VTXTVRecordingsIE,
|
||||||
WalyTVIE,
|
WalyTVIE,
|
||||||
|
WalyTVLiveIE,
|
||||||
|
WalyTVRecordingsIE,
|
||||||
ZattooIE,
|
ZattooIE,
|
||||||
ZattooLiveIE,
|
ZattooLiveIE,
|
||||||
ZattooMoviesIE,
|
ZattooMoviesIE,
|
||||||
|
|
|
@ -236,32 +236,24 @@ class ZattooPlatformBaseIE(InfoExtractor):
|
||||||
|
|
||||||
def _real_extract(self, url):
|
def _real_extract(self, url):
|
||||||
video_id, record_id = self._match_valid_url(url).groups()
|
video_id, record_id = self._match_valid_url(url).groups()
|
||||||
return self._extract_video(video_id, record_id)
|
return getattr(self, f'_extract_{self._TYPE}')(video_id or record_id)
|
||||||
|
|
||||||
|
|
||||||
def _make_valid_url(host):
|
def _create_valid_url(host, match, qs, base_re=None):
|
||||||
return rf'https?://(?:www\.)?{re.escape(host)}/watch/[^/]+?/(?P<id>[0-9]+)[^/]+(?:/(?P<recid>[0-9]+))?'
|
match_base = fr'|{base_re}/(?P<vid1>{match})' if base_re else '(?P<vid1>)'
|
||||||
|
return rf'''(?x)https?://(?:www\.)?{re.escape(host)}/(?:
|
||||||
|
[^?#]+\?(?:[^#]+&)?{qs}=(?P<vid2>{match})
|
||||||
|
{match_base}
|
||||||
|
)'''
|
||||||
|
|
||||||
|
|
||||||
class ZattooBaseIE(ZattooPlatformBaseIE):
|
class ZattooBaseIE(ZattooPlatformBaseIE):
|
||||||
_NETRC_MACHINE = 'zattoo'
|
_NETRC_MACHINE = 'zattoo'
|
||||||
_HOST = 'zattoo.com'
|
_HOST = 'zattoo.com'
|
||||||
|
|
||||||
@staticmethod
|
|
||||||
def _create_valid_url(match, qs, base_re=None):
|
|
||||||
match_base = fr'|{base_re}/(?P<vid1>{match})' if base_re else '(?P<vid1>)'
|
|
||||||
return rf'''(?x)https?://(?:www\.)?zattoo\.com/(?:
|
|
||||||
[^?#]+\?(?:[^#]+&)?{qs}=(?P<vid2>{match})
|
|
||||||
{match_base}
|
|
||||||
)'''
|
|
||||||
|
|
||||||
def _real_extract(self, url):
|
|
||||||
vid1, vid2 = self._match_valid_url(url).group('vid1', 'vid2')
|
|
||||||
return getattr(self, f'_extract_{self._TYPE}')(vid1 or vid2)
|
|
||||||
|
|
||||||
|
|
||||||
class ZattooIE(ZattooBaseIE):
|
class ZattooIE(ZattooBaseIE):
|
||||||
_VALID_URL = ZattooBaseIE._create_valid_url(r'\d+', 'program', '(?:program|watch)/[^/]+')
|
_VALID_URL = _create_valid_url(ZattooBaseIE._HOST, r'\d+', 'program', '(?:program|watch)/[^/]+')
|
||||||
_TYPE = 'video'
|
_TYPE = 'video'
|
||||||
_TESTS = [{
|
_TESTS = [{
|
||||||
'url': 'https://zattoo.com/program/zdf/250170418',
|
'url': 'https://zattoo.com/program/zdf/250170418',
|
||||||
|
@ -288,7 +280,7 @@ class ZattooIE(ZattooBaseIE):
|
||||||
|
|
||||||
|
|
||||||
class ZattooLiveIE(ZattooBaseIE):
|
class ZattooLiveIE(ZattooBaseIE):
|
||||||
_VALID_URL = ZattooBaseIE._create_valid_url(r'[^/?&#]+', 'channel', 'live')
|
_VALID_URL = _create_valid_url(ZattooBaseIE._HOST, r'[^/?&#]+', 'channel', 'live')
|
||||||
_TYPE = 'live'
|
_TYPE = 'live'
|
||||||
_TESTS = [{
|
_TESTS = [{
|
||||||
'url': 'https://zattoo.com/channels/german?channel=srf_zwei',
|
'url': 'https://zattoo.com/channels/german?channel=srf_zwei',
|
||||||
|
@ -304,7 +296,7 @@ class ZattooLiveIE(ZattooBaseIE):
|
||||||
|
|
||||||
|
|
||||||
class ZattooMoviesIE(ZattooBaseIE):
|
class ZattooMoviesIE(ZattooBaseIE):
|
||||||
_VALID_URL = ZattooBaseIE._create_valid_url(r'\w+', 'movie_id', 'vod/movies')
|
_VALID_URL = _create_valid_url(ZattooBaseIE._HOST, r'\w+', 'movie_id', 'vod/movies')
|
||||||
_TYPE = 'ondemand'
|
_TYPE = 'ondemand'
|
||||||
_TESTS = [{
|
_TESTS = [{
|
||||||
'url': 'https://zattoo.com/vod/movies/7521',
|
'url': 'https://zattoo.com/vod/movies/7521',
|
||||||
|
@ -316,7 +308,7 @@ class ZattooMoviesIE(ZattooBaseIE):
|
||||||
|
|
||||||
|
|
||||||
class ZattooRecordingsIE(ZattooBaseIE):
|
class ZattooRecordingsIE(ZattooBaseIE):
|
||||||
_VALID_URL = ZattooBaseIE._create_valid_url(r'\d+', 'recording')
|
_VALID_URL = _create_valid_url('zattoo.com', r'\d+', 'recording')
|
||||||
_TYPE = 'record'
|
_TYPE = 'record'
|
||||||
_TESTS = [{
|
_TESTS = [{
|
||||||
'url': 'https://zattoo.com/recordings?recording=193615508',
|
'url': 'https://zattoo.com/recordings?recording=193615508',
|
||||||
|
@ -327,139 +319,547 @@ class ZattooRecordingsIE(ZattooBaseIE):
|
||||||
}]
|
}]
|
||||||
|
|
||||||
|
|
||||||
class NetPlusIE(ZattooPlatformBaseIE):
|
class NetPlusTVBaseIE(ZattooPlatformBaseIE):
|
||||||
_NETRC_MACHINE = 'netplus'
|
_NETRC = 'netplus'
|
||||||
_HOST = 'netplus.tv'
|
_HOST = 'netplus.tv'
|
||||||
_API_HOST = 'www.%s' % _HOST
|
_API_HOST = 'www.%s' % _HOST
|
||||||
_VALID_URL = _make_valid_url(_HOST)
|
|
||||||
|
|
||||||
|
|
||||||
|
class NetPlusTVIE(NetPlusTVBaseIE):
|
||||||
|
_VALID_URL = _create_valid_url(NetPlusTVBaseIE._HOST, r'\d+', 'program', '(?:program|watch)/[^/]+')
|
||||||
|
_TYPE = 'video'
|
||||||
_TESTS = [{
|
_TESTS = [{
|
||||||
'url': 'https://www.netplus.tv/watch/abc/123-abc',
|
'url': 'https://netplus.tv/program/daserste/210177916',
|
||||||
|
'only_matching': True,
|
||||||
|
}, {
|
||||||
|
'url': 'https://netplus.tv/guide/german?channel=srf1&program=169860555',
|
||||||
'only_matching': True,
|
'only_matching': True,
|
||||||
}]
|
}]
|
||||||
|
|
||||||
|
|
||||||
class MNetTVIE(ZattooPlatformBaseIE):
|
class NetPlusTVLiveIE(NetPlusTVBaseIE):
|
||||||
|
_VALID_URL = _create_valid_url(NetPlusTVBaseIE._HOST, r'[^/?&#]+', 'channel', 'live')
|
||||||
|
_TYPE = 'live'
|
||||||
|
_TESTS = [{
|
||||||
|
'url': 'https://netplus.tv/channels/german?channel=srf_zwei',
|
||||||
|
'only_matching': True,
|
||||||
|
}, {
|
||||||
|
'url': 'https://netplus.tv/live/srf1',
|
||||||
|
'only_matching': True,
|
||||||
|
}]
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def suitable(cls, url):
|
||||||
|
return False if NetPlusTVIE.suitable(url) else super().suitable(url)
|
||||||
|
|
||||||
|
|
||||||
|
class NetPlusTVRecordingsIE(NetPlusTVBaseIE):
|
||||||
|
_VALID_URL = _create_valid_url(NetPlusTVBaseIE._HOST, r'\d+', 'recording')
|
||||||
|
_TYPE = 'record'
|
||||||
|
_TESTS = [{
|
||||||
|
'url': 'https://netplus.tv/recordings?recording=193615508',
|
||||||
|
'only_matching': True,
|
||||||
|
}, {
|
||||||
|
'url': 'https://netplus.tv/tc/ptc_recordings_all_recordings?recording=193615420',
|
||||||
|
'only_matching': True,
|
||||||
|
}]
|
||||||
|
|
||||||
|
|
||||||
|
class MNetTVBaseIE(ZattooPlatformBaseIE):
|
||||||
_NETRC_MACHINE = 'mnettv'
|
_NETRC_MACHINE = 'mnettv'
|
||||||
_HOST = 'tvplus.m-net.de'
|
_HOST = 'tvplus.m-net.de'
|
||||||
_VALID_URL = _make_valid_url(_HOST)
|
|
||||||
|
|
||||||
|
|
||||||
|
class MNetTVIE(MNetTVBaseIE):
|
||||||
|
_VALID_URL = _create_valid_url(MNetTVBaseIE._HOST, r'\d+', 'program', '(?:program|watch)/[^/]+')
|
||||||
|
_TYPE = 'video'
|
||||||
_TESTS = [{
|
_TESTS = [{
|
||||||
'url': 'https://tvplus.m-net.de/watch/abc/123-abc',
|
'url': 'https://tvplus.m-net.de/program/daserste/210177916',
|
||||||
|
'only_matching': True,
|
||||||
|
}, {
|
||||||
|
'url': 'https://tvplus.m-net.de/guide/german?channel=srf1&program=169860555',
|
||||||
'only_matching': True,
|
'only_matching': True,
|
||||||
}]
|
}]
|
||||||
|
|
||||||
|
|
||||||
class WalyTVIE(ZattooPlatformBaseIE):
|
class MNetTVLiveIE(MNetTVBaseIE):
|
||||||
|
_VALID_URL = _create_valid_url(MNetTVBaseIE._HOST, r'[^/?&#]+', 'channel', 'live')
|
||||||
|
_TYPE = 'live'
|
||||||
|
_TESTS = [{
|
||||||
|
'url': 'https://tvplus.m-net.de/channels/german?channel=srf_zwei',
|
||||||
|
'only_matching': True,
|
||||||
|
}, {
|
||||||
|
'url': 'https://tvplus.m-net.de/live/srf1',
|
||||||
|
'only_matching': True,
|
||||||
|
}]
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def suitable(cls, url):
|
||||||
|
return False if MNetTVIE.suitable(url) else super().suitable(url)
|
||||||
|
|
||||||
|
|
||||||
|
class MNetTVRecordingsIE(MNetTVBaseIE):
|
||||||
|
_VALID_URL = _create_valid_url(MNetTVBaseIE._HOST, r'\d+', 'recording')
|
||||||
|
_TYPE = 'record'
|
||||||
|
_TESTS = [{
|
||||||
|
'url': 'https://tvplus.m-net.de/recordings?recording=193615508',
|
||||||
|
'only_matching': True,
|
||||||
|
}, {
|
||||||
|
'url': 'https://tvplus.m-net.de/tc/ptc_recordings_all_recordings?recording=193615420',
|
||||||
|
'only_matching': True,
|
||||||
|
}]
|
||||||
|
|
||||||
|
|
||||||
|
class WalyTVBaseIE(ZattooPlatformBaseIE):
|
||||||
_NETRC_MACHINE = 'walytv'
|
_NETRC_MACHINE = 'walytv'
|
||||||
_HOST = 'player.waly.tv'
|
_HOST = 'player.waly.tv'
|
||||||
_VALID_URL = _make_valid_url(_HOST)
|
|
||||||
|
|
||||||
|
|
||||||
|
class WalyTVIE(WalyTVBaseIE):
|
||||||
|
_VALID_URL = _create_valid_url(WalyTVBaseIE._HOST, r'\d+', 'program', '(?:program|watch)/[^/]+')
|
||||||
|
_TYPE = 'video'
|
||||||
_TESTS = [{
|
_TESTS = [{
|
||||||
'url': 'https://player.waly.tv/watch/abc/123-abc',
|
'url': 'https://player.waly.tv/program/daserste/210177916',
|
||||||
|
'only_matching': True,
|
||||||
|
}, {
|
||||||
|
'url': 'https://player.waly.tv/guide/german?channel=srf1&program=169860555',
|
||||||
'only_matching': True,
|
'only_matching': True,
|
||||||
}]
|
}]
|
||||||
|
|
||||||
|
|
||||||
class BBVTVIE(ZattooPlatformBaseIE):
|
class WalyTVLiveIE(WalyTVBaseIE):
|
||||||
|
_VALID_URL = _create_valid_url(WalyTVBaseIE._HOST, r'[^/?&#]+', 'channel', 'live')
|
||||||
|
_TYPE = 'live'
|
||||||
|
_TESTS = [{
|
||||||
|
'url': 'https://player.waly.tv/channels/german?channel=srf_zwei',
|
||||||
|
'only_matching': True,
|
||||||
|
}, {
|
||||||
|
'url': 'https://player.waly.tv/live/srf1',
|
||||||
|
'only_matching': True,
|
||||||
|
}]
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def suitable(cls, url):
|
||||||
|
return False if WalyTVIE.suitable(url) else super().suitable(url)
|
||||||
|
|
||||||
|
|
||||||
|
class WalyTVRecordingsIE(WalyTVBaseIE):
|
||||||
|
_VALID_URL = _create_valid_url(WalyTVBaseIE._HOST, r'\d+', 'recording')
|
||||||
|
_TYPE = 'record'
|
||||||
|
_TESTS = [{
|
||||||
|
'url': 'https://player.waly.tv/recordings?recording=193615508',
|
||||||
|
'only_matching': True,
|
||||||
|
}, {
|
||||||
|
'url': 'https://player.waly.tv/tc/ptc_recordings_all_recordings?recording=193615420',
|
||||||
|
'only_matching': True,
|
||||||
|
}]
|
||||||
|
|
||||||
|
|
||||||
|
class BBVTVBaseIE(ZattooPlatformBaseIE):
|
||||||
_NETRC_MACHINE = 'bbvtv'
|
_NETRC_MACHINE = 'bbvtv'
|
||||||
_HOST = 'bbv-tv.net'
|
_HOST = 'bbv-tv.net'
|
||||||
_API_HOST = 'www.%s' % _HOST
|
_API_HOST = 'www.%s' % _HOST
|
||||||
_VALID_URL = _make_valid_url(_HOST)
|
|
||||||
|
|
||||||
|
|
||||||
|
class BBVTVIE(BBVTVBaseIE):
|
||||||
|
_VALID_URL = _create_valid_url(BBVTVBaseIE._HOST, r'\d+', 'program', '(?:program|watch)/[^/]+')
|
||||||
|
_TYPE = 'video'
|
||||||
_TESTS = [{
|
_TESTS = [{
|
||||||
'url': 'https://www.bbv-tv.net/watch/abc/123-abc',
|
'url': 'https://bbv-tv.net/program/daserste/210177916',
|
||||||
|
'only_matching': True,
|
||||||
|
}, {
|
||||||
|
'url': 'https://bbv-tv.net/guide/german?channel=srf1&program=169860555',
|
||||||
'only_matching': True,
|
'only_matching': True,
|
||||||
}]
|
}]
|
||||||
|
|
||||||
|
|
||||||
class VTXTVIE(ZattooPlatformBaseIE):
|
class BBVTVLiveIE(BBVTVBaseIE):
|
||||||
|
_VALID_URL = _create_valid_url(BBVTVBaseIE._HOST, r'[^/?&#]+', 'channel', 'live')
|
||||||
|
_TYPE = 'live'
|
||||||
|
_TESTS = [{
|
||||||
|
'url': 'https://bbv-tv.net/channels/german?channel=srf_zwei',
|
||||||
|
'only_matching': True,
|
||||||
|
}, {
|
||||||
|
'url': 'https://bbv-tv.net/live/srf1',
|
||||||
|
'only_matching': True,
|
||||||
|
}]
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def suitable(cls, url):
|
||||||
|
return False if BBVTVIE.suitable(url) else super().suitable(url)
|
||||||
|
|
||||||
|
|
||||||
|
class BBVTVRecordingsIE(BBVTVBaseIE):
|
||||||
|
_VALID_URL = _create_valid_url(BBVTVBaseIE._HOST, r'\d+', 'recording')
|
||||||
|
_TYPE = 'record'
|
||||||
|
_TESTS = [{
|
||||||
|
'url': 'https://bbv-tv.net/recordings?recording=193615508',
|
||||||
|
'only_matching': True,
|
||||||
|
}, {
|
||||||
|
'url': 'https://bbv-tv.net/tc/ptc_recordings_all_recordings?recording=193615420',
|
||||||
|
'only_matching': True,
|
||||||
|
}]
|
||||||
|
|
||||||
|
|
||||||
|
class VTXTVBaseIE(ZattooPlatformBaseIE):
|
||||||
_NETRC_MACHINE = 'vtxtv'
|
_NETRC_MACHINE = 'vtxtv'
|
||||||
_HOST = 'vtxtv.ch'
|
_HOST = 'vtxtv.ch'
|
||||||
_API_HOST = 'www.%s' % _HOST
|
_API_HOST = 'www.%s' % _HOST
|
||||||
_VALID_URL = _make_valid_url(_HOST)
|
|
||||||
|
|
||||||
|
|
||||||
|
class VTXTVIE(VTXTVBaseIE):
|
||||||
|
_VALID_URL = _create_valid_url(VTXTVBaseIE._HOST, r'\d+', 'program', '(?:program|watch)/[^/]+')
|
||||||
|
_TYPE = 'video'
|
||||||
_TESTS = [{
|
_TESTS = [{
|
||||||
'url': 'https://www.vtxtv.ch/watch/abc/123-abc',
|
'url': 'https://vtxtv.ch/program/daserste/210177916',
|
||||||
|
'only_matching': True,
|
||||||
|
}, {
|
||||||
|
'url': 'https://vtxtv.ch/guide/german?channel=srf1&program=169860555',
|
||||||
'only_matching': True,
|
'only_matching': True,
|
||||||
}]
|
}]
|
||||||
|
|
||||||
|
|
||||||
class GlattvisionTVIE(ZattooPlatformBaseIE):
|
class VTXTVLiveIE(VTXTVBaseIE):
|
||||||
|
_VALID_URL = _create_valid_url(VTXTVBaseIE._HOST, r'[^/?&#]+', 'channel', 'live')
|
||||||
|
_TYPE = 'live'
|
||||||
|
_TESTS = [{
|
||||||
|
'url': 'https://vtxtv.ch/channels/german?channel=srf_zwei',
|
||||||
|
'only_matching': True,
|
||||||
|
}, {
|
||||||
|
'url': 'https://vtxtv.ch/live/srf1',
|
||||||
|
'only_matching': True,
|
||||||
|
}]
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def suitable(cls, url):
|
||||||
|
return False if VTXTVIE.suitable(url) else super().suitable(url)
|
||||||
|
|
||||||
|
|
||||||
|
class VTXTVRecordingsIE(VTXTVBaseIE):
|
||||||
|
_VALID_URL = _create_valid_url(VTXTVBaseIE._HOST, r'\d+', 'recording')
|
||||||
|
_TYPE = 'record'
|
||||||
|
_TESTS = [{
|
||||||
|
'url': 'https://vtxtv.ch/recordings?recording=193615508',
|
||||||
|
'only_matching': True,
|
||||||
|
}, {
|
||||||
|
'url': 'https://vtxtv.ch/tc/ptc_recordings_all_recordings?recording=193615420',
|
||||||
|
'only_matching': True,
|
||||||
|
}]
|
||||||
|
|
||||||
|
|
||||||
|
class GlattvisionTVBaseIE(ZattooPlatformBaseIE):
|
||||||
_NETRC_MACHINE = 'glattvisiontv'
|
_NETRC_MACHINE = 'glattvisiontv'
|
||||||
_HOST = 'iptv.glattvision.ch'
|
_HOST = 'iptv.glattvision.ch'
|
||||||
_VALID_URL = _make_valid_url(_HOST)
|
|
||||||
|
|
||||||
|
|
||||||
|
class GlattvisionTVIE(GlattvisionTVBaseIE):
|
||||||
|
_VALID_URL = _create_valid_url(GlattvisionTVBaseIE._HOST, r'\d+', 'program', '(?:program|watch)/[^/]+')
|
||||||
|
_TYPE = 'video'
|
||||||
_TESTS = [{
|
_TESTS = [{
|
||||||
'url': 'https://iptv.glattvision.ch/watch/abc/123-abc',
|
'url': 'https://iptv.glattvision.ch/program/daserste/210177916',
|
||||||
|
'only_matching': True,
|
||||||
|
}, {
|
||||||
|
'url': 'https://iptv.glattvision.ch/guide/german?channel=srf1&program=169860555',
|
||||||
'only_matching': True,
|
'only_matching': True,
|
||||||
}]
|
}]
|
||||||
|
|
||||||
|
|
||||||
class SAKTVIE(ZattooPlatformBaseIE):
|
class GlattvisionTVLiveIE(GlattvisionTVBaseIE):
|
||||||
|
_VALID_URL = _create_valid_url(GlattvisionTVBaseIE._HOST, r'[^/?&#]+', 'channel', 'live')
|
||||||
|
_TYPE = 'live'
|
||||||
|
_TESTS = [{
|
||||||
|
'url': 'https://iptv.glattvision.ch/channels/german?channel=srf_zwei',
|
||||||
|
'only_matching': True,
|
||||||
|
}, {
|
||||||
|
'url': 'https://iptv.glattvision.ch/live/srf1',
|
||||||
|
'only_matching': True,
|
||||||
|
}]
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def suitable(cls, url):
|
||||||
|
return False if GlattvisionTVIE.suitable(url) else super().suitable(url)
|
||||||
|
|
||||||
|
|
||||||
|
class GlattvisionTVRecordingsIE(GlattvisionTVBaseIE):
|
||||||
|
_VALID_URL = _create_valid_url(GlattvisionTVBaseIE._HOST, r'\d+', 'recording')
|
||||||
|
_TYPE = 'record'
|
||||||
|
_TESTS = [{
|
||||||
|
'url': 'https://iptv.glattvision.ch/recordings?recording=193615508',
|
||||||
|
'only_matching': True,
|
||||||
|
}, {
|
||||||
|
'url': 'https://iptv.glattvision.ch/tc/ptc_recordings_all_recordings?recording=193615420',
|
||||||
|
'only_matching': True,
|
||||||
|
}]
|
||||||
|
|
||||||
|
|
||||||
|
class SAKTVBaseIE(ZattooPlatformBaseIE):
|
||||||
_NETRC_MACHINE = 'saktv'
|
_NETRC_MACHINE = 'saktv'
|
||||||
_HOST = 'saktv.ch'
|
_HOST = 'saktv.ch'
|
||||||
_API_HOST = 'www.%s' % _HOST
|
_API_HOST = 'www.%s' % _HOST
|
||||||
_VALID_URL = _make_valid_url(_HOST)
|
|
||||||
|
|
||||||
|
|
||||||
|
class SAKTVIE(SAKTVBaseIE):
|
||||||
|
_VALID_URL = _create_valid_url(SAKTVBaseIE._HOST, r'\d+', 'program', '(?:program|watch)/[^/]+')
|
||||||
|
_TYPE = 'video'
|
||||||
_TESTS = [{
|
_TESTS = [{
|
||||||
'url': 'https://www.saktv.ch/watch/abc/123-abc',
|
'url': 'https://saktv.ch/program/daserste/210177916',
|
||||||
|
'only_matching': True,
|
||||||
|
}, {
|
||||||
|
'url': 'https://saktv.ch/guide/german?channel=srf1&program=169860555',
|
||||||
'only_matching': True,
|
'only_matching': True,
|
||||||
}]
|
}]
|
||||||
|
|
||||||
|
|
||||||
class EWETVIE(ZattooPlatformBaseIE):
|
class SAKTVLiveIE(SAKTVBaseIE):
|
||||||
|
_VALID_URL = _create_valid_url(SAKTVBaseIE._HOST, r'[^/?&#]+', 'channel', 'live')
|
||||||
|
_TYPE = 'live'
|
||||||
|
_TESTS = [{
|
||||||
|
'url': 'https://saktv.ch/channels/german?channel=srf_zwei',
|
||||||
|
'only_matching': True,
|
||||||
|
}, {
|
||||||
|
'url': 'https://saktv.ch/live/srf1',
|
||||||
|
'only_matching': True,
|
||||||
|
}]
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def suitable(cls, url):
|
||||||
|
return False if SAKTVIE.suitable(url) else super().suitable(url)
|
||||||
|
|
||||||
|
|
||||||
|
class SAKTVRecordingsIE(SAKTVBaseIE):
|
||||||
|
_VALID_URL = _create_valid_url(SAKTVBaseIE._HOST, r'\d+', 'recording')
|
||||||
|
_TYPE = 'record'
|
||||||
|
_TESTS = [{
|
||||||
|
'url': 'https://saktv.ch/recordings?recording=193615508',
|
||||||
|
'only_matching': True,
|
||||||
|
}, {
|
||||||
|
'url': 'https://saktv.ch/tc/ptc_recordings_all_recordings?recording=193615420',
|
||||||
|
'only_matching': True,
|
||||||
|
}]
|
||||||
|
|
||||||
|
|
||||||
|
class EWETVBaseIE(ZattooPlatformBaseIE):
|
||||||
_NETRC_MACHINE = 'ewetv'
|
_NETRC_MACHINE = 'ewetv'
|
||||||
_HOST = 'tvonline.ewe.de'
|
_HOST = 'tvonline.ewe.de'
|
||||||
_VALID_URL = _make_valid_url(_HOST)
|
|
||||||
|
|
||||||
|
|
||||||
|
class EWETVIE(EWETVBaseIE):
|
||||||
|
_VALID_URL = _create_valid_url(EWETVBaseIE._HOST, r'\d+', 'program', '(?:program|watch)/[^/]+')
|
||||||
|
_TYPE = 'video'
|
||||||
_TESTS = [{
|
_TESTS = [{
|
||||||
'url': 'https://tvonline.ewe.de/watch/abc/123-abc',
|
'url': 'https://tvonline.ewe.de/program/daserste/210177916',
|
||||||
|
'only_matching': True,
|
||||||
|
}, {
|
||||||
|
'url': 'https://tvonline.ewe.de/guide/german?channel=srf1&program=169860555',
|
||||||
'only_matching': True,
|
'only_matching': True,
|
||||||
}]
|
}]
|
||||||
|
|
||||||
|
|
||||||
class QuantumTVIE(ZattooPlatformBaseIE):
|
class EWETVLiveIE(EWETVBaseIE):
|
||||||
|
_VALID_URL = _create_valid_url(EWETVBaseIE._HOST, r'[^/?&#]+', 'channel', 'live')
|
||||||
|
_TYPE = 'live'
|
||||||
|
_TESTS = [{
|
||||||
|
'url': 'https://tvonline.ewe.de/channels/german?channel=srf_zwei',
|
||||||
|
'only_matching': True,
|
||||||
|
}, {
|
||||||
|
'url': 'https://tvonline.ewe.de/live/srf1',
|
||||||
|
'only_matching': True,
|
||||||
|
}]
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def suitable(cls, url):
|
||||||
|
return False if EWETVIE.suitable(url) else super().suitable(url)
|
||||||
|
|
||||||
|
|
||||||
|
class EWETVRecordingsIE(EWETVBaseIE):
|
||||||
|
_VALID_URL = _create_valid_url(EWETVBaseIE._HOST, r'\d+', 'recording')
|
||||||
|
_TYPE = 'record'
|
||||||
|
_TESTS = [{
|
||||||
|
'url': 'https://tvonline.ewe.de/recordings?recording=193615508',
|
||||||
|
'only_matching': True,
|
||||||
|
}, {
|
||||||
|
'url': 'https://tvonline.ewe.de/tc/ptc_recordings_all_recordings?recording=193615420',
|
||||||
|
'only_matching': True,
|
||||||
|
}]
|
||||||
|
|
||||||
|
|
||||||
|
class QuantumTVBaseIE(ZattooPlatformBaseIE):
|
||||||
_NETRC_MACHINE = 'quantumtv'
|
_NETRC_MACHINE = 'quantumtv'
|
||||||
_HOST = 'quantum-tv.com'
|
_HOST = 'quantum-tv.com'
|
||||||
_API_HOST = 'www.%s' % _HOST
|
_API_HOST = 'www.%s' % _HOST
|
||||||
_VALID_URL = _make_valid_url(_HOST)
|
|
||||||
|
|
||||||
|
|
||||||
|
class QuantumTVIE(QuantumTVBaseIE):
|
||||||
|
_VALID_URL = _create_valid_url(QuantumTVBaseIE._HOST, r'\d+', 'program', '(?:program|watch)/[^/]+')
|
||||||
|
_TYPE = 'video'
|
||||||
_TESTS = [{
|
_TESTS = [{
|
||||||
'url': 'https://www.quantum-tv.com/watch/abc/123-abc',
|
'url': 'https://quantum-tv.com/program/daserste/210177916',
|
||||||
|
'only_matching': True,
|
||||||
|
}, {
|
||||||
|
'url': 'https://quantum-tv.com/guide/german?channel=srf1&program=169860555',
|
||||||
'only_matching': True,
|
'only_matching': True,
|
||||||
}]
|
}]
|
||||||
|
|
||||||
|
|
||||||
class OsnatelTVIE(ZattooPlatformBaseIE):
|
class QuantumTVLiveIE(QuantumTVBaseIE):
|
||||||
|
_VALID_URL = _create_valid_url(QuantumTVBaseIE._HOST, r'[^/?&#]+', 'channel', 'live')
|
||||||
|
_TYPE = 'live'
|
||||||
|
_TESTS = [{
|
||||||
|
'url': 'https://quantum-tv.com/channels/german?channel=srf_zwei',
|
||||||
|
'only_matching': True,
|
||||||
|
}, {
|
||||||
|
'url': 'https://quantum-tv.com/live/srf1',
|
||||||
|
'only_matching': True,
|
||||||
|
}]
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def suitable(cls, url):
|
||||||
|
return False if QuantumTVIE.suitable(url) else super().suitable(url)
|
||||||
|
|
||||||
|
|
||||||
|
class QuantumTVRecordingsIE(QuantumTVBaseIE):
|
||||||
|
_VALID_URL = _create_valid_url(QuantumTVBaseIE._HOST, r'\d+', 'recording')
|
||||||
|
_TYPE = 'record'
|
||||||
|
_TESTS = [{
|
||||||
|
'url': 'https://quantum-tv.com/recordings?recording=193615508',
|
||||||
|
'only_matching': True,
|
||||||
|
}, {
|
||||||
|
'url': 'https://quantum-tv.com/tc/ptc_recordings_all_recordings?recording=193615420',
|
||||||
|
'only_matching': True,
|
||||||
|
}]
|
||||||
|
|
||||||
|
|
||||||
|
class OsnatelTVBaseIE(ZattooPlatformBaseIE):
|
||||||
_NETRC_MACHINE = 'osnateltv'
|
_NETRC_MACHINE = 'osnateltv'
|
||||||
_HOST = 'tvonline.osnatel.de'
|
_HOST = 'tvonline.osnatel.de'
|
||||||
_VALID_URL = _make_valid_url(_HOST)
|
|
||||||
|
|
||||||
|
|
||||||
|
class OsnatelTVIE(OsnatelTVBaseIE):
|
||||||
|
_VALID_URL = _create_valid_url(OsnatelTVBaseIE._HOST, r'\d+', 'program', '(?:program|watch)/[^/]+')
|
||||||
|
_TYPE = 'video'
|
||||||
_TESTS = [{
|
_TESTS = [{
|
||||||
'url': 'https://tvonline.osnatel.de/watch/abc/123-abc',
|
'url': 'https://tvonline.osnatel.de/program/daserste/210177916',
|
||||||
|
'only_matching': True,
|
||||||
|
}, {
|
||||||
|
'url': 'https://tvonline.osnatel.de/guide/german?channel=srf1&program=169860555',
|
||||||
'only_matching': True,
|
'only_matching': True,
|
||||||
}]
|
}]
|
||||||
|
|
||||||
|
|
||||||
class EinsUndEinsTVIE(ZattooPlatformBaseIE):
|
class OsnatelTVLiveIE(OsnatelTVBaseIE):
|
||||||
|
_VALID_URL = _create_valid_url(OsnatelTVBaseIE._HOST, r'[^/?&#]+', 'channel', 'live')
|
||||||
|
_TYPE = 'live'
|
||||||
|
_TESTS = [{
|
||||||
|
'url': 'https://tvonline.osnatel.de/channels/german?channel=srf_zwei',
|
||||||
|
'only_matching': True,
|
||||||
|
}, {
|
||||||
|
'url': 'https://tvonline.osnatel.de/live/srf1',
|
||||||
|
'only_matching': True,
|
||||||
|
}]
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def suitable(cls, url):
|
||||||
|
return False if OsnatelTVIE.suitable(url) else super().suitable(url)
|
||||||
|
|
||||||
|
|
||||||
|
class OsnatelTVRecordingsIE(OsnatelTVBaseIE):
|
||||||
|
_VALID_URL = _create_valid_url(OsnatelTVBaseIE._HOST, r'\d+', 'recording')
|
||||||
|
_TYPE = 'record'
|
||||||
|
_TESTS = [{
|
||||||
|
'url': 'https://tvonline.osnatel.de/recordings?recording=193615508',
|
||||||
|
'only_matching': True,
|
||||||
|
}, {
|
||||||
|
'url': 'https://tvonline.osnatel.de/tc/ptc_recordings_all_recordings?recording=193615420',
|
||||||
|
'only_matching': True,
|
||||||
|
}]
|
||||||
|
|
||||||
|
|
||||||
|
class EinsUndEinsTVBaseIE(ZattooPlatformBaseIE):
|
||||||
_NETRC_MACHINE = '1und1tv'
|
_NETRC_MACHINE = '1und1tv'
|
||||||
_HOST = '1und1.tv'
|
_HOST = '1und1.tv'
|
||||||
_API_HOST = 'www.%s' % _HOST
|
_API_HOST = 'www.%s' % _HOST
|
||||||
_VALID_URL = _make_valid_url(_HOST)
|
|
||||||
|
|
||||||
|
|
||||||
|
class EinsUndEinsTVIE(EinsUndEinsTVBaseIE):
|
||||||
|
_VALID_URL = _create_valid_url(EinsUndEinsTVBaseIE._HOST, r'\d+', 'program', '(?:program|watch)/[^/]+')
|
||||||
|
_TYPE = 'video'
|
||||||
_TESTS = [{
|
_TESTS = [{
|
||||||
'url': 'https://www.1und1.tv/watch/abc/123-abc',
|
'url': 'https://1und1.tv/program/daserste/210177916',
|
||||||
|
'only_matching': True,
|
||||||
|
}, {
|
||||||
|
'url': 'https://1und1.tv/guide/german?channel=srf1&program=169860555',
|
||||||
'only_matching': True,
|
'only_matching': True,
|
||||||
}]
|
}]
|
||||||
|
|
||||||
|
|
||||||
class SaltTVIE(ZattooPlatformBaseIE):
|
class EinsUndEinsTVLiveIE(EinsUndEinsTVBaseIE):
|
||||||
|
_VALID_URL = _create_valid_url(EinsUndEinsTVBaseIE._HOST, r'[^/?&#]+', 'channel', 'live')
|
||||||
|
_TYPE = 'live'
|
||||||
|
_TESTS = [{
|
||||||
|
'url': 'https://1und1.tv/channels/german?channel=srf_zwei',
|
||||||
|
'only_matching': True,
|
||||||
|
}, {
|
||||||
|
'url': 'https://1und1.tv/live/srf1',
|
||||||
|
'only_matching': True,
|
||||||
|
}]
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def suitable(cls, url):
|
||||||
|
return False if EinsUndEinsTVIE.suitable(url) else super().suitable(url)
|
||||||
|
|
||||||
|
|
||||||
|
class EinsUndEinsTVRecordingsIE(EinsUndEinsTVBaseIE):
|
||||||
|
_VALID_URL = _create_valid_url(EinsUndEinsTVBaseIE._HOST, r'\d+', 'recording')
|
||||||
|
_TYPE = 'record'
|
||||||
|
_TESTS = [{
|
||||||
|
'url': 'https://1und1.tv/recordings?recording=193615508',
|
||||||
|
'only_matching': True,
|
||||||
|
}, {
|
||||||
|
'url': 'https://1und1.tv/tc/ptc_recordings_all_recordings?recording=193615420',
|
||||||
|
'only_matching': True,
|
||||||
|
}]
|
||||||
|
|
||||||
|
|
||||||
|
class SaltTVBaseIE(ZattooPlatformBaseIE):
|
||||||
_NETRC_MACHINE = 'salttv'
|
_NETRC_MACHINE = 'salttv'
|
||||||
_HOST = 'tv.salt.ch'
|
_HOST = 'tv.salt.ch'
|
||||||
_VALID_URL = _make_valid_url(_HOST)
|
|
||||||
|
|
||||||
|
|
||||||
|
class SaltTVIE(SaltTVBaseIE):
|
||||||
|
_VALID_URL = _create_valid_url(SaltTVBaseIE._HOST, r'\d+', 'program', '(?:program|watch)/[^/]+')
|
||||||
|
_TYPE = 'video'
|
||||||
_TESTS = [{
|
_TESTS = [{
|
||||||
'url': 'https://tv.salt.ch/watch/abc/123-abc',
|
'url': 'https://tv.salt.ch/program/daserste/210177916',
|
||||||
|
'only_matching': True,
|
||||||
|
}, {
|
||||||
|
'url': 'https://tv.salt.ch/guide/german?channel=srf1&program=169860555',
|
||||||
|
'only_matching': True,
|
||||||
|
}]
|
||||||
|
|
||||||
|
|
||||||
|
class SaltTVLiveIE(SaltTVBaseIE):
|
||||||
|
_VALID_URL = _create_valid_url(SaltTVBaseIE._HOST, r'[^/?&#]+', 'channel', 'live')
|
||||||
|
_TYPE = 'live'
|
||||||
|
_TESTS = [{
|
||||||
|
'url': 'https://tv.salt.ch/channels/german?channel=srf_zwei',
|
||||||
|
'only_matching': True,
|
||||||
|
}, {
|
||||||
|
'url': 'https://tv.salt.ch/live/srf1',
|
||||||
|
'only_matching': True,
|
||||||
|
}]
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def suitable(cls, url):
|
||||||
|
return False if SaltTVIE.suitable(url) else super().suitable(url)
|
||||||
|
|
||||||
|
|
||||||
|
class SaltTVRecordingsIE(SaltTVBaseIE):
|
||||||
|
_VALID_URL = _create_valid_url(SaltTVBaseIE._HOST, r'\d+', 'recording')
|
||||||
|
_TYPE = 'record'
|
||||||
|
_TESTS = [{
|
||||||
|
'url': 'https://tv.salt.ch/recordings?recording=193615508',
|
||||||
|
'only_matching': True,
|
||||||
|
}, {
|
||||||
|
'url': 'https://tv.salt.ch/tc/ptc_recordings_all_recordings?recording=193615420',
|
||||||
'only_matching': True,
|
'only_matching': True,
|
||||||
}]
|
}]
|
||||||
|
|
Loading…
Reference in a new issue