# coding: utf-8 from __future__ import unicode_literals import itertools import re from .common import ( InfoExtractor, SearchInfoExtractor ) from ..compat import ( compat_HTTPError, compat_kwargs, compat_str, compat_urlparse, ) from ..utils import ( error_to_compat_str, ExtractorError, float_or_none, HEADRequest, int_or_none, KNOWN_EXTENSIONS, mimetype2ext, str_or_none, try_get, unified_timestamp, update_url_query, url_or_none, urlhandle_detect_ext, ) class SoundcloudEmbedIE(InfoExtractor): _VALID_URL = r'https?://(?:w|player|p)\.soundcloud\.com/player/?.*?\burl=(?P<id>.+)' _TEST = { # from https://www.soundi.fi/uutiset/ennakkokuuntelussa-timo-kaukolammen-station-to-station-to-station-julkaisua-juhlitaan-tanaan-g-livelabissa/ 'url': 'https://w.soundcloud.com/player/?visual=true&url=https%3A%2F%2Fapi.soundcloud.com%2Fplaylists%2F922213810&show_artwork=true&maxwidth=640&maxheight=960&dnt=1&secret_token=s-ziYey', 'only_matching': True, } @staticmethod def _extract_urls(webpage): return [m.group('url') for m in re.finditer( r'<iframe[^>]+src=(["\'])(?P<url>(?:https?://)?(?:w\.)?soundcloud\.com/player.+?)\1', webpage)] def _real_extract(self, url): query = compat_urlparse.parse_qs( compat_urlparse.urlparse(url).query) api_url = query['url'][0] secret_token = query.get('secret_token') if secret_token: api_url = update_url_query(api_url, {'secret_token': secret_token[0]}) return self.url_result(api_url) class SoundcloudIE(InfoExtractor): """Information extractor for soundcloud.com To access the media, the uid of the song and a stream token must be extracted from the page source and the script must make a request to media.soundcloud.com/crossdomain.xml. Then the media can be grabbed by requesting from an url composed of the stream token and uid """ _VALID_URL = r'''(?x)^(?:https?://)? (?:(?:(?:www\.|m\.)?soundcloud\.com/ (?!stations/track) (?P<uploader>[\w\d-]+)/ (?!(?:tracks|albums|sets(?:/.+?)?|reposts|likes|spotlight)/?(?:$|[?#])) (?P<title>[\w\d-]+)/? (?P<token>[^?]+?)?(?:[?].*)?$) |(?:api(?:-v2)?\.soundcloud\.com/tracks/(?P<track_id>\d+) (?:/?\?secret_token=(?P<secret_token>[^&]+))?) ) ''' IE_NAME = 'soundcloud' _TESTS = [ { 'url': 'http://soundcloud.com/ethmusic/lostin-powers-she-so-heavy', 'md5': 'ebef0a451b909710ed1d7787dddbf0d7', 'info_dict': { 'id': '62986583', 'ext': 'mp3', 'title': 'Lostin Powers - She so Heavy (SneakPreview) Adrian Ackers Blueprint 1', 'description': 'No Downloads untill we record the finished version this weekend, i was too pumped n i had to post it , earl is prolly gonna b hella p.o\'d', 'uploader': 'E.T. ExTerrestrial Music', 'uploader_id': '1571244', 'timestamp': 1349920598, 'upload_date': '20121011', 'duration': 143.216, 'license': 'all-rights-reserved', 'view_count': int, 'like_count': int, 'comment_count': int, 'repost_count': int, } }, # geo-restricted { 'url': 'https://soundcloud.com/the-concept-band/goldrushed-mastered?in=the-concept-band/sets/the-royal-concept-ep', 'info_dict': { 'id': '47127627', 'ext': 'mp3', 'title': 'Goldrushed', 'description': 'From Stockholm Sweden\r\nPovel / Magnus / Filip / David\r\nwww.theroyalconcept.com', 'uploader': 'The Royal Concept', 'uploader_id': '9615865', 'timestamp': 1337635207, 'upload_date': '20120521', 'duration': 227.155, 'license': 'all-rights-reserved', 'view_count': int, 'like_count': int, 'comment_count': int, 'repost_count': int, }, }, # private link { 'url': 'https://soundcloud.com/jaimemf/youtube-dl-test-video-a-y-baw/s-8Pjrp', 'md5': 'aa0dd32bfea9b0c5ef4f02aacd080604', 'info_dict': { 'id': '123998367', 'ext': 'mp3', 'title': 'Youtube - Dl Test Video \'\' Ä↭', 'description': 'test chars: \"\'/\\ä↭', 'uploader': 'jaimeMF', 'uploader_id': '69767071', 'timestamp': 1386604920, 'upload_date': '20131209', 'duration': 9.927, 'license': 'all-rights-reserved', 'view_count': int, 'like_count': int, 'comment_count': int, 'repost_count': int, }, }, # private link (alt format) { 'url': 'https://api.soundcloud.com/tracks/123998367?secret_token=s-8Pjrp', 'md5': 'aa0dd32bfea9b0c5ef4f02aacd080604', 'info_dict': { 'id': '123998367', 'ext': 'mp3', 'title': 'Youtube - Dl Test Video \'\' Ä↭', 'description': 'test chars: \"\'/\\ä↭', 'uploader': 'jaimeMF', 'uploader_id': '69767071', 'timestamp': 1386604920, 'upload_date': '20131209', 'duration': 9.927, 'license': 'all-rights-reserved', 'view_count': int, 'like_count': int, 'comment_count': int, 'repost_count': int, }, }, # downloadable song { 'url': 'https://soundcloud.com/oddsamples/bus-brakes', 'md5': '7624f2351f8a3b2e7cd51522496e7631', 'info_dict': { 'id': '128590877', 'ext': 'mp3', 'title': 'Bus Brakes', 'description': 'md5:0053ca6396e8d2fd7b7e1595ef12ab66', 'uploader': 'oddsamples', 'uploader_id': '73680509', 'timestamp': 1389232924, 'upload_date': '20140109', 'duration': 17.346, 'license': 'cc-by-sa', 'view_count': int, 'like_count': int, 'comment_count': int, 'repost_count': int, }, }, # private link, downloadable format { 'url': 'https://soundcloud.com/oriuplift/uponly-238-no-talking-wav/s-AyZUd', 'md5': '64a60b16e617d41d0bef032b7f55441e', 'info_dict': { 'id': '340344461', 'ext': 'wav', 'title': 'Uplifting Only 238 [No Talking] (incl. Alex Feed Guestmix) (Aug 31, 2017) [wav]', 'description': 'md5:fa20ee0fca76a3d6df8c7e57f3715366', 'uploader': 'Ori Uplift Music', 'uploader_id': '12563093', 'timestamp': 1504206263, 'upload_date': '20170831', 'duration': 7449.096, 'license': 'all-rights-reserved', 'view_count': int, 'like_count': int, 'comment_count': int, 'repost_count': int, }, }, # no album art, use avatar pic for thumbnail { 'url': 'https://soundcloud.com/garyvee/sideways-prod-mad-real', 'md5': '59c7872bc44e5d99b7211891664760c2', 'info_dict': { 'id': '309699954', 'ext': 'mp3', 'title': 'Sideways (Prod. Mad Real)', 'description': 'md5:d41d8cd98f00b204e9800998ecf8427e', 'uploader': 'garyvee', 'uploader_id': '2366352', 'timestamp': 1488152409, 'upload_date': '20170226', 'duration': 207.012, 'thumbnail': r're:https?://.*\.jpg', 'license': 'all-rights-reserved', 'view_count': int, 'like_count': int, 'comment_count': int, 'repost_count': int, }, 'params': { 'skip_download': True, }, }, { 'url': 'https://soundcloud.com/giovannisarani/mezzo-valzer', 'md5': 'e22aecd2bc88e0e4e432d7dcc0a1abf7', 'info_dict': { 'id': '583011102', 'ext': 'mp3', 'title': 'Mezzo Valzer', 'description': 'md5:4138d582f81866a530317bae316e8b61', 'uploader': 'Micronie', 'uploader_id': '3352531', 'timestamp': 1551394171, 'upload_date': '20190228', 'duration': 180.157, 'thumbnail': r're:https?://.*\.jpg', 'license': 'all-rights-reserved', 'view_count': int, 'like_count': int, 'comment_count': int, 'repost_count': int, }, }, { # with AAC HQ format available via OAuth token 'url': 'https://soundcloud.com/wandw/the-chainsmokers-ft-daya-dont-let-me-down-ww-remix-1', 'only_matching': True, }, ] _API_V2_BASE = 'https://api-v2.soundcloud.com/' _BASE_URL = 'https://soundcloud.com/' _IMAGE_REPL_RE = r'-([0-9a-z]+)\.jpg' _ARTWORK_MAP = { 'mini': 16, 'tiny': 20, 'small': 32, 'badge': 47, 't67x67': 67, 'large': 100, 't300x300': 300, 'crop': 400, 't500x500': 500, 'original': 0, } def _store_client_id(self, client_id): self._downloader.cache.store('soundcloud', 'client_id', client_id) def _update_client_id(self): webpage = self._download_webpage('https://soundcloud.com/', None) for src in reversed(re.findall(r'<script[^>]+src="([^"]+)"', webpage)): script = self._download_webpage(src, None, fatal=False) if script: client_id = self._search_regex( r'client_id\s*:\s*"([0-9a-zA-Z]{32})"', script, 'client id', default=None) if client_id: self._CLIENT_ID = client_id self._store_client_id(client_id) return raise ExtractorError('Unable to extract client id') def _download_json(self, *args, **kwargs): non_fatal = kwargs.get('fatal') is False if non_fatal: del kwargs['fatal'] query = kwargs.get('query', {}).copy() for _ in range(2): query['client_id'] = self._CLIENT_ID kwargs['query'] = query try: return super(SoundcloudIE, self)._download_json(*args, **compat_kwargs(kwargs)) except ExtractorError as e: if isinstance(e.cause, compat_HTTPError) and e.cause.code == 401: self._store_client_id(None) self._update_client_id() continue elif non_fatal: self._downloader.report_warning(error_to_compat_str(e)) return False raise def _real_initialize(self): self._CLIENT_ID = self._downloader.cache.load('soundcloud', 'client_id') or 'YUKXoArFcqrlQn9tfNHvvyfnDISj04zk' @classmethod def _resolv_url(cls, url): return SoundcloudIE._API_V2_BASE + 'resolve?url=' + url def _extract_info_dict(self, info, full_title=None, secret_token=None): track_id = compat_str(info['id']) title = info['title'] format_urls = set() formats = [] query = {'client_id': self._CLIENT_ID} if secret_token: query['secret_token'] = secret_token if info.get('downloadable') and info.get('has_downloads_left'): download_url = update_url_query( self._API_V2_BASE + 'tracks/' + track_id + '/download', query) redirect_url = (self._download_json(download_url, track_id, fatal=False) or {}).get('redirectUri') if redirect_url: urlh = self._request_webpage( HEADRequest(redirect_url), track_id, fatal=False) if urlh: format_url = urlh.geturl() format_urls.add(format_url) formats.append({ 'format_id': 'download', 'ext': urlhandle_detect_ext(urlh) or 'mp3', 'filesize': int_or_none(urlh.headers.get('Content-Length')), 'url': format_url, 'preference': 10, }) def invalid_url(url): return not url or url in format_urls def add_format(f, protocol, is_preview=False): mobj = re.search(r'\.(?P<abr>\d+)\.(?P<ext>[0-9a-z]{3,4})(?=[/?])', stream_url) if mobj: for k, v in mobj.groupdict().items(): if not f.get(k): f[k] = v format_id_list = [] if protocol: format_id_list.append(protocol) ext = f.get('ext') if ext == 'aac': f['abr'] = '256' for k in ('ext', 'abr'): v = f.get(k) if v: format_id_list.append(v) preview = is_preview or re.search(r'/(?:preview|playlist)/0/30/', f['url']) if preview: format_id_list.append('preview') abr = f.get('abr') if abr: f['abr'] = int(abr) if protocol == 'hls': protocol = 'm3u8' if ext == 'aac' else 'm3u8_native' else: protocol = 'http' f.update({ 'format_id': '_'.join(format_id_list), 'protocol': protocol, 'preference': -10 if preview else None, }) formats.append(f) # New API transcodings = try_get( info, lambda x: x['media']['transcodings'], list) or [] for t in transcodings: if not isinstance(t, dict): continue format_url = url_or_none(t.get('url')) if not format_url: continue stream = self._download_json( format_url, track_id, query=query, fatal=False) if not isinstance(stream, dict): continue stream_url = url_or_none(stream.get('url')) if invalid_url(stream_url): continue format_urls.add(stream_url) stream_format = t.get('format') or {} protocol = stream_format.get('protocol') if protocol != 'hls' and '/hls' in format_url: protocol = 'hls' ext = None preset = str_or_none(t.get('preset')) if preset: ext = preset.split('_')[0] if ext not in KNOWN_EXTENSIONS: ext = mimetype2ext(stream_format.get('mime_type')) add_format({ 'url': stream_url, 'ext': ext, }, 'http' if protocol == 'progressive' else protocol, t.get('snipped') or '/preview/' in format_url) for f in formats: f['vcodec'] = 'none' if not formats and info.get('policy') == 'BLOCK': self.raise_geo_restricted() self._sort_formats(formats) user = info.get('user') or {} thumbnails = [] artwork_url = info.get('artwork_url') thumbnail = artwork_url or user.get('avatar_url') if isinstance(thumbnail, compat_str): if re.search(self._IMAGE_REPL_RE, thumbnail): for image_id, size in self._ARTWORK_MAP.items(): i = { 'id': image_id, 'url': re.sub(self._IMAGE_REPL_RE, '-%s.jpg' % image_id, thumbnail), } if image_id == 'tiny' and not artwork_url: size = 18 elif image_id == 'original': i['preference'] = 10 if size: i.update({ 'width': size, 'height': size, }) thumbnails.append(i) else: thumbnails = [{'url': thumbnail}] def extract_count(key): return int_or_none(info.get('%s_count' % key)) return { 'id': track_id, 'uploader': user.get('username'), 'uploader_id': str_or_none(user.get('id')) or user.get('permalink'), 'uploader_url': user.get('permalink_url'), 'timestamp': unified_timestamp(info.get('created_at')), 'title': title, 'description': info.get('description'), 'thumbnails': thumbnails, 'duration': float_or_none(info.get('duration'), 1000), 'webpage_url': info.get('permalink_url'), 'license': info.get('license'), 'view_count': extract_count('playback'), 'like_count': extract_count('favoritings') or extract_count('likes'), 'comment_count': extract_count('comment'), 'repost_count': extract_count('reposts'), 'genre': info.get('genre'), 'formats': formats } def _real_extract(self, url): mobj = re.match(self._VALID_URL, url) track_id = mobj.group('track_id') query = {} if track_id: info_json_url = self._API_V2_BASE + 'tracks/' + track_id full_title = track_id token = mobj.group('secret_token') if token: query['secret_token'] = token else: full_title = resolve_title = '%s/%s' % mobj.group('uploader', 'title') token = mobj.group('token') if token: resolve_title += '/%s' % token info_json_url = self._resolv_url(self._BASE_URL + resolve_title) info = self._download_json( info_json_url, full_title, 'Downloading info JSON', query=query) return self._extract_info_dict(info, full_title, token) class SoundcloudPlaylistBaseIE(SoundcloudIE): def _extract_set(self, playlist, token=None): playlist_id = compat_str(playlist['id']) tracks = playlist.get('tracks') or [] if not all([t.get('permalink_url') for t in tracks]) and token: tracks = self._download_json( self._API_V2_BASE + 'tracks', playlist_id, 'Downloading tracks', query={ 'ids': ','.join([compat_str(t['id']) for t in tracks]), 'playlistId': playlist_id, 'playlistSecretToken': token, }) entries = [] for track in tracks: track_id = str_or_none(track.get('id')) url = track.get('permalink_url') if not url: if not track_id: continue url = self._API_V2_BASE + 'tracks/' + track_id if token: url += '?secret_token=' + token entries.append(self.url_result( url, SoundcloudIE.ie_key(), track_id)) return self.playlist_result( entries, playlist_id, playlist.get('title'), playlist.get('description')) class SoundcloudSetIE(SoundcloudPlaylistBaseIE): _VALID_URL = r'https?://(?:(?:www|m)\.)?soundcloud\.com/(?P<uploader>[\w\d-]+)/sets/(?P<slug_title>[\w\d-]+)(?:/(?P<token>[^?/]+))?' IE_NAME = 'soundcloud:set' _TESTS = [{ 'url': 'https://soundcloud.com/the-concept-band/sets/the-royal-concept-ep', 'info_dict': { 'id': '2284613', 'title': 'The Royal Concept EP', 'description': 'md5:71d07087c7a449e8941a70a29e34671e', }, 'playlist_mincount': 5, }, { 'url': 'https://soundcloud.com/the-concept-band/sets/the-royal-concept-ep/token', 'only_matching': True, }] def _real_extract(self, url): mobj = re.match(self._VALID_URL, url) full_title = '%s/sets/%s' % mobj.group('uploader', 'slug_title') token = mobj.group('token') if token: full_title += '/' + token info = self._download_json(self._resolv_url( self._BASE_URL + full_title), full_title) if 'errors' in info: msgs = (compat_str(err['error_message']) for err in info['errors']) raise ExtractorError('unable to download video webpage: %s' % ','.join(msgs)) return self._extract_set(info, token) class SoundcloudPagedPlaylistBaseIE(SoundcloudIE): def _extract_playlist(self, base_url, playlist_id, playlist_title): # Per the SoundCloud documentation, the maximum limit for a linked partitioning query is 200. # https://developers.soundcloud.com/blog/offset-pagination-deprecated COMMON_QUERY = { 'limit': 200, 'linked_partitioning': '1', } query = COMMON_QUERY.copy() query['offset'] = 0 next_href = base_url entries = [] for i in itertools.count(): response = self._download_json( next_href, playlist_id, 'Downloading track page %s' % (i + 1), query=query) collection = response['collection'] if not isinstance(collection, list): collection = [] # Empty collection may be returned, in this case we proceed # straight to next_href def resolve_entry(candidates): for cand in candidates: if not isinstance(cand, dict): continue permalink_url = url_or_none(cand.get('permalink_url')) if not permalink_url: continue return self.url_result( permalink_url, SoundcloudIE.ie_key() if SoundcloudIE.suitable(permalink_url) else None, str_or_none(cand.get('id')), cand.get('title')) for e in collection: entry = resolve_entry((e, e.get('track'), e.get('playlist'))) if entry: entries.append(entry) next_href = response.get('next_href') if not next_href: break next_href = response['next_href'] parsed_next_href = compat_urlparse.urlparse(next_href) query = compat_urlparse.parse_qs(parsed_next_href.query) query.update(COMMON_QUERY) return { '_type': 'playlist', 'id': playlist_id, 'title': playlist_title, 'entries': entries, } class SoundcloudUserIE(SoundcloudPagedPlaylistBaseIE): _VALID_URL = r'''(?x) https?:// (?:(?:www|m)\.)?soundcloud\.com/ (?P<user>[^/]+) (?:/ (?P<rsrc>tracks|albums|sets|reposts|likes|spotlight) )? /?(?:[?#].*)?$ ''' IE_NAME = 'soundcloud:user' _TESTS = [{ 'url': 'https://soundcloud.com/soft-cell-official', 'info_dict': { 'id': '207965082', 'title': 'Soft Cell (All)', }, 'playlist_mincount': 28, }, { 'url': 'https://soundcloud.com/soft-cell-official/tracks', 'info_dict': { 'id': '207965082', 'title': 'Soft Cell (Tracks)', }, 'playlist_mincount': 27, }, { 'url': 'https://soundcloud.com/soft-cell-official/albums', 'info_dict': { 'id': '207965082', 'title': 'Soft Cell (Albums)', }, 'playlist_mincount': 1, }, { 'url': 'https://soundcloud.com/jcv246/sets', 'info_dict': { 'id': '12982173', 'title': 'Jordi / cv (Sets)', }, 'playlist_mincount': 2, }, { 'url': 'https://soundcloud.com/jcv246/reposts', 'info_dict': { 'id': '12982173', 'title': 'Jordi / cv (Reposts)', }, 'playlist_mincount': 6, }, { 'url': 'https://soundcloud.com/clalberg/likes', 'info_dict': { 'id': '11817582', 'title': 'clalberg (Likes)', }, 'playlist_mincount': 5, }, { 'url': 'https://soundcloud.com/grynpyret/spotlight', 'info_dict': { 'id': '7098329', 'title': 'Grynpyret (Spotlight)', }, 'playlist_mincount': 1, }] _BASE_URL_MAP = { 'all': 'stream/users/%s', 'tracks': 'users/%s/tracks', 'albums': 'users/%s/albums', 'sets': 'users/%s/playlists', 'reposts': 'stream/users/%s/reposts', 'likes': 'users/%s/likes', 'spotlight': 'users/%s/spotlight', } def _real_extract(self, url): mobj = re.match(self._VALID_URL, url) uploader = mobj.group('user') user = self._download_json( self._resolv_url(self._BASE_URL + uploader), uploader, 'Downloading user info') resource = mobj.group('rsrc') or 'all' return self._extract_playlist( self._API_V2_BASE + self._BASE_URL_MAP[resource] % user['id'], str_or_none(user.get('id')), '%s (%s)' % (user['username'], resource.capitalize())) class SoundcloudTrackStationIE(SoundcloudPagedPlaylistBaseIE): _VALID_URL = r'https?://(?:(?:www|m)\.)?soundcloud\.com/stations/track/[^/]+/(?P<id>[^/?#&]+)' IE_NAME = 'soundcloud:trackstation' _TESTS = [{ 'url': 'https://soundcloud.com/stations/track/officialsundial/your-text', 'info_dict': { 'id': '286017854', 'title': 'Track station: your text', }, 'playlist_mincount': 47, }] def _real_extract(self, url): track_name = self._match_id(url) track = self._download_json(self._resolv_url(url), track_name) track_id = self._search_regex( r'soundcloud:track-stations:(\d+)', track['id'], 'track id') return self._extract_playlist( self._API_V2_BASE + 'stations/%s/tracks' % track['id'], track_id, 'Track station: %s' % track['title']) class SoundcloudPlaylistIE(SoundcloudPlaylistBaseIE): _VALID_URL = r'https?://api(?:-v2)?\.soundcloud\.com/playlists/(?P<id>[0-9]+)(?:/?\?secret_token=(?P<token>[^&]+?))?$' IE_NAME = 'soundcloud:playlist' _TESTS = [{ 'url': 'https://api.soundcloud.com/playlists/4110309', 'info_dict': { 'id': '4110309', 'title': 'TILT Brass - Bowery Poetry Club, August \'03 [Non-Site SCR 02]', 'description': 're:.*?TILT Brass - Bowery Poetry Club', }, 'playlist_count': 6, }] def _real_extract(self, url): mobj = re.match(self._VALID_URL, url) playlist_id = mobj.group('id') query = {} token = mobj.group('token') if token: query['secret_token'] = token data = self._download_json( self._API_V2_BASE + 'playlists/' + playlist_id, playlist_id, 'Downloading playlist', query=query) return self._extract_set(data, token) class SoundcloudSearchIE(SearchInfoExtractor, SoundcloudIE): IE_NAME = 'soundcloud:search' IE_DESC = 'Soundcloud search' _MAX_RESULTS = float('inf') _TESTS = [{ 'url': 'scsearch15:post-avant jazzcore', 'info_dict': { 'title': 'post-avant jazzcore', }, 'playlist_count': 15, }] _SEARCH_KEY = 'scsearch' _MAX_RESULTS_PER_PAGE = 200 _DEFAULT_RESULTS_PER_PAGE = 50 def _get_collection(self, endpoint, collection_id, **query): limit = min( query.get('limit', self._DEFAULT_RESULTS_PER_PAGE), self._MAX_RESULTS_PER_PAGE) query.update({ 'limit': limit, 'linked_partitioning': 1, 'offset': 0, }) next_url = update_url_query(self._API_V2_BASE + endpoint, query) collected_results = 0 for i in itertools.count(1): response = self._download_json( next_url, collection_id, 'Downloading page {0}'.format(i), 'Unable to download API page') collection = response.get('collection', []) if not collection: break collection = list(filter(bool, collection)) collected_results += len(collection) for item in collection: yield self.url_result(item['uri'], SoundcloudIE.ie_key()) if not collection or collected_results >= limit: break next_url = response.get('next_href') if not next_url: break def _get_n_results(self, query, n): tracks = self._get_collection('search/tracks', query, limit=n, q=query) return self.playlist_result(tracks, playlist_title=query)
Name | Type | Size | Permission | Actions |
---|---|---|---|---|
__pycache__ | Folder | 2755 |
|
|
__init__.py | File | 1.23 KB | 0644 |
|
abc.py | File | 7.32 KB | 0644 |
|
abcnews.py | File | 5.31 KB | 0644 |
|
abcotvs.py | File | 4.63 KB | 0644 |
|
academicearth.py | File | 1.37 KB | 0644 |
|
acast.py | File | 4.39 KB | 0644 |
|
adn.py | File | 9.9 KB | 0644 |
|
adobeconnect.py | File | 1.32 KB | 0644 |
|
adobepass.py | File | 40.44 KB | 0644 |
|
adobetv.py | File | 10.05 KB | 0644 |
|
adultswim.py | File | 7.67 KB | 0644 |
|
aenetworks.py | File | 11.81 KB | 0644 |
|
afreecatv.py | File | 14.22 KB | 0644 |
|
airmozilla.py | File | 2.63 KB | 0644 |
|
aliexpress.py | File | 1.54 KB | 0644 |
|
aljazeera.py | File | 2.18 KB | 0644 |
|
allocine.py | File | 4.85 KB | 0644 |
|
alphaporno.py | File | 2.66 KB | 0644 |
|
amara.py | File | 3.5 KB | 0644 |
|
amcnetworks.py | File | 4.85 KB | 0644 |
|
americastestkitchen.py | File | 6.2 KB | 0644 |
|
amp.py | File | 3.97 KB | 0644 |
|
animeondemand.py | File | 12.24 KB | 0644 |
|
anvato.py | File | 24.41 KB | 0644 |
|
aol.py | File | 5.52 KB | 0644 |
|
apa.py | File | 3.1 KB | 0644 |
|
aparat.py | File | 3.13 KB | 0644 |
|
appleconnect.py | File | 1.71 KB | 0644 |
|
applepodcasts.py | File | 2.26 KB | 0644 |
|
appletrailers.py | File | 10.09 KB | 0644 |
|
archiveorg.py | File | 2.43 KB | 0644 |
|
arcpublishing.py | File | 7.78 KB | 0644 |
|
ard.py | File | 16.39 KB | 0644 |
|
arkena.py | File | 7.35 KB | 0644 |
|
arte.py | File | 10.36 KB | 0644 |
|
asiancrush.py | File | 7.62 KB | 0644 |
|
atresplayer.py | File | 4.28 KB | 0644 |
|
atttechchannel.py | File | 1.92 KB | 0644 |
|
atvat.py | File | 2.45 KB | 0644 |
|
audimedia.py | File | 3.93 KB | 0644 |
|
audioboom.py | File | 2.6 KB | 0644 |
|
audiomack.py | File | 5.73 KB | 0644 |
|
awaan.py | File | 6.98 KB | 0644 |
|
aws.py | File | 3.02 KB | 0644 |
|
azmedien.py | File | 2.21 KB | 0644 |
|
baidu.py | File | 1.93 KB | 0644 |
|
bandcamp.py | File | 14.03 KB | 0644 |
|
bbc.py | File | 58.62 KB | 0644 |
|
beatport.py | File | 3.34 KB | 0644 |
|
beeg.py | File | 3.5 KB | 0644 |
|
behindkink.py | File | 1.61 KB | 0644 |
|
bellmedia.py | File | 2.9 KB | 0644 |
|
bet.py | File | 2.72 KB | 0644 |
|
bfi.py | File | 1.31 KB | 0644 |
|
bfmtv.py | File | 4.12 KB | 0644 |
|
bibeltv.py | File | 1.08 KB | 0644 |
|
bigflix.py | File | 2.28 KB | 0644 |
|
bild.py | File | 1.33 KB | 0644 |
|
bilibili.py | File | 16.18 KB | 0644 |
|
biobiochiletv.py | File | 3.43 KB | 0644 |
|
biqle.py | File | 3.77 KB | 0644 |
|
bitchute.py | File | 5.2 KB | 0644 |
|
bleacherreport.py | File | 4.11 KB | 0644 |
|
blinkx.py | File | 3.14 KB | 0644 |
|
bloomberg.py | File | 3.25 KB | 0644 |
|
bokecc.py | File | 2.01 KB | 0644 |
|
bongacams.py | File | 1.86 KB | 0644 |
|
bostonglobe.py | File | 3.12 KB | 0644 |
|
box.py | File | 3.71 KB | 0644 |
|
bpb.py | File | 2.15 KB | 0644 |
|
br.py | File | 11.62 KB | 0644 |
|
bravotv.py | File | 3.38 KB | 0644 |
|
breakcom.py | File | 2.88 KB | 0644 |
|
brightcove.py | File | 29.8 KB | 0644 |
|
businessinsider.py | File | 1.95 KB | 0644 |
|
buzzfeed.py | File | 3.57 KB | 0644 |
|
byutv.py | File | 4.07 KB | 0644 |
|
c56.py | File | 2.03 KB | 0644 |
|
camdemy.py | File | 5.64 KB | 0644 |
|
cammodels.py | File | 3.4 KB | 0644 |
|
camtube.py | File | 2.16 KB | 0644 |
|
camwithher.py | File | 3.15 KB | 0644 |
|
canalc2.py | File | 2.26 KB | 0644 |
|
canalplus.py | File | 4.37 KB | 0644 |
|
canvas.py | File | 12.91 KB | 0644 |
|
carambatv.py | File | 3.44 KB | 0644 |
|
cartoonnetwork.py | File | 2.32 KB | 0644 |
|
cbc.py | File | 20.17 KB | 0644 |
|
cbs.py | File | 4.57 KB | 0644 |
|
cbsinteractive.py | File | 3.95 KB | 0644 |
|
cbslocal.py | File | 4.02 KB | 0644 |
|
cbsnews.py | File | 7.44 KB | 0644 |
|
cbssports.py | File | 1.45 KB | 0644 |
|
ccc.py | File | 3.78 KB | 0644 |
|
ccma.py | File | 3.62 KB | 0644 |
|
cctv.py | File | 6.74 KB | 0644 |
|
cda.py | File | 7.99 KB | 0644 |
|
ceskatelevize.py | File | 10.41 KB | 0644 |
|
channel9.py | File | 10.04 KB | 0644 |
|
charlierose.py | File | 1.79 KB | 0644 |
|
chaturbate.py | File | 3.82 KB | 0644 |
|
chilloutzone.py | File | 3.42 KB | 0644 |
|
chirbit.py | File | 2.88 KB | 0644 |
|
cinchcast.py | File | 1.95 KB | 0644 |
|
cinemax.py | File | 949 B | 0644 |
|
ciscolive.py | File | 5.88 KB | 0644 |
|
cjsw.py | File | 2.36 KB | 0644 |
|
cliphunter.py | File | 2.47 KB | 0644 |
|
clippit.py | File | 2.49 KB | 0644 |
|
cliprs.py | File | 1.01 KB | 0644 |
|
clipsyndicate.py | File | 1.77 KB | 0644 |
|
closertotruth.py | File | 3.02 KB | 0644 |
|
cloudflarestream.py | File | 2.61 KB | 0644 |
|
cloudy.py | File | 1.85 KB | 0644 |
|
clubic.py | File | 1.93 KB | 0644 |
|
clyp.py | File | 2.44 KB | 0644 |
|
cmt.py | File | 2.12 KB | 0644 |
|
cnbc.py | File | 2.24 KB | 0644 |
|
cnn.py | File | 6.37 KB | 0644 |
|
comedycentral.py | File | 1.99 KB | 0644 |
|
common.py | File | 140.53 KB | 0644 |
|
commonmistakes.py | File | 1.5 KB | 0644 |
|
commonprotocols.py | File | 1.63 KB | 0644 |
|
condenast.py | File | 9.51 KB | 0644 |
|
contv.py | File | 4.1 KB | 0644 |
|
corus.py | File | 6.25 KB | 0644 |
|
coub.py | File | 4.45 KB | 0644 |
|
cracked.py | File | 3.06 KB | 0644 |
|
crackle.py | File | 7.45 KB | 0644 |
|
crooksandliars.py | File | 2.01 KB | 0644 |
|
crunchyroll.py | File | 28.07 KB | 0644 |
|
cspan.py | File | 10.04 KB | 0644 |
|
ctsnews.py | File | 3.56 KB | 0644 |
|
ctv.py | File | 1.73 KB | 0644 |
|
ctvnews.py | File | 2.22 KB | 0644 |
|
cultureunplugged.py | File | 2.45 KB | 0644 |
|
curiositystream.py | File | 5.84 KB | 0644 |
|
cwtv.py | File | 3.75 KB | 0644 |
|
dailymail.py | File | 3.06 KB | 0644 |
|
dailymotion.py | File | 14.77 KB | 0644 |
|
daum.py | File | 9.49 KB | 0644 |
|
dbtv.py | File | 1.91 KB | 0644 |
|
dctp.py | File | 3.5 KB | 0644 |
|
deezer.py | File | 3.2 KB | 0644 |
|
defense.py | File | 1.21 KB | 0644 |
|
democracynow.py | File | 3.03 KB | 0644 |
|
dfb.py | File | 2.2 KB | 0644 |
|
dhm.py | File | 2.04 KB | 0644 |
|
digg.py | File | 1.84 KB | 0644 |
|
digiteka.py | File | 3.43 KB | 0644 |
|
discovery.py | File | 4.8 KB | 0644 |
|
discoverygo.py | File | 5.94 KB | 0644 |
|
discoverynetworks.py | File | 1.6 KB | 0644 |
|
discoveryvr.py | File | 2.08 KB | 0644 |
|
disney.py | File | 6.88 KB | 0644 |
|
dispeak.py | File | 4.55 KB | 0644 |
|
dlive.py | File | 3.05 KB | 0644 |
|
dotsub.py | File | 3.01 KB | 0644 |
|
douyutv.py | File | 6.72 KB | 0644 |
|
dplay.py | File | 10.6 KB | 0644 |
|
drbonanza.py | File | 1.93 KB | 0644 |
|
dreisat.py | File | 7.5 KB | 0644 |
|
dropbox.py | File | 1.27 KB | 0644 |
|
drtuber.py | File | 3.88 KB | 0644 |
|
drtv.py | File | 13.59 KB | 0644 |
|
dtube.py | File | 2.73 KB | 0644 |
|
dumpert.py | File | 2.64 KB | 0644 |
|
dvtv.py | File | 7.48 KB | 0644 |
|
dw.py | File | 4 KB | 0644 |
|
eagleplatform.py | File | 7.55 KB | 0644 |
|
ebaumsworld.py | File | 1.06 KB | 0644 |
|
echomsk.py | File | 1.29 KB | 0644 |
|
egghead.py | File | 4.54 KB | 0644 |
|
ehow.py | File | 1.48 KB | 0644 |
|
eighttracks.py | File | 5.73 KB | 0644 |
|
einthusan.py | File | 3.63 KB | 0644 |
|
eitb.py | File | 3.2 KB | 0644 |
|
ellentube.py | File | 4.79 KB | 0644 |
|
elpais.py | File | 4.26 KB | 0644 |
|
embedly.py | File | 842 B | 0644 |
|
engadget.py | File | 807 B | 0644 |
|
eporner.py | File | 4.56 KB | 0644 |
|
eroprofile.py | File | 3.14 KB | 0644 |
|
escapist.py | File | 3.54 KB | 0644 |
|
espn.py | File | 8.55 KB | 0644 |
|
esri.py | File | 2.57 KB | 0644 |
|
europa.py | File | 3.33 KB | 0644 |
|
expotv.py | File | 2.84 KB | 0644 |
|
expressen.py | File | 3.77 KB | 0644 |
|
extractors.py | File | 34.55 KB | 0644 |
|
extremetube.py | File | 1.71 KB | 0644 |
|
eyedotv.py | File | 2.62 KB | 0644 |
|
facebook.py | File | 29.36 KB | 0644 |
|
faz.py | File | 3.5 KB | 0644 |
|
fc2.py | File | 5.46 KB | 0644 |
|
fczenit.py | File | 1.72 KB | 0644 |
|
filmon.py | File | 5.91 KB | 0644 |
|
filmweb.py | File | 1.44 KB | 0644 |
|
firsttv.py | File | 6.31 KB | 0644 |
|
fivemin.py | File | 1.87 KB | 0644 |
|
fivetv.py | File | 3.13 KB | 0644 |
|
flickr.py | File | 4.66 KB | 0644 |
|
folketinget.py | File | 2.58 KB | 0644 |
|
footyroom.py | File | 1.83 KB | 0644 |
|
formula1.py | File | 1.18 KB | 0644 |
|
fourtube.py | File | 11.31 KB | 0644 |
|
fox.py | File | 5.56 KB | 0644 |
|
fox9.py | File | 1.43 KB | 0644 |
|
foxgay.py | File | 2.15 KB | 0644 |
|
foxnews.py | File | 5.04 KB | 0644 |
|
foxsports.py | File | 1.07 KB | 0644 |
|
franceculture.py | File | 2.8 KB | 0644 |
|
franceinter.py | File | 2.16 KB | 0644 |
|
francetv.py | File | 19.69 KB | 0644 |
|
freesound.py | File | 2.44 KB | 0644 |
|
freespeech.py | File | 1.03 KB | 0644 |
|
freshlive.py | File | 2.64 KB | 0644 |
|
frontendmasters.py | File | 8.6 KB | 0644 |
|
fujitv.py | File | 1.02 KB | 0644 |
|
funimation.py | File | 5.54 KB | 0644 |
|
funk.py | File | 1.67 KB | 0644 |
|
fusion.py | File | 3.09 KB | 0644 |
|
gaia.py | File | 4.59 KB | 0644 |
|
gameinformer.py | File | 2.07 KB | 0644 |
|
gamespot.py | File | 3.08 KB | 0644 |
|
gamestar.py | File | 2.56 KB | 0644 |
|
gaskrank.py | File | 3.76 KB | 0644 |
|
gazeta.py | File | 1.91 KB | 0644 |
|
gdcvault.py | File | 7.13 KB | 0644 |
|
generic.py | File | 142.73 KB | 0644 |
|
gfycat.py | File | 4.12 KB | 0644 |
|
giantbomb.py | File | 2.98 KB | 0644 |
|
giga.py | File | 3.73 KB | 0644 |
|
gigya.py | File | 677 B | 0644 |
|
glide.py | File | 1.51 KB | 0644 |
|
globo.py | File | 9.56 KB | 0644 |
|
go.py | File | 11.37 KB | 0644 |
|
godtube.py | File | 1.74 KB | 0644 |
|
golem.py | File | 2.16 KB | 0644 |
|
googledrive.py | File | 10.29 KB | 0644 |
|
googlepodcasts.py | File | 3.33 KB | 0644 |
|
googlesearch.py | File | 1.65 KB | 0644 |
|
goshgay.py | File | 1.51 KB | 0644 |
|
gputechconf.py | File | 1.17 KB | 0644 |
|
groupon.py | File | 2.54 KB | 0644 |
|
hbo.py | File | 5.98 KB | 0644 |
|
hearthisat.py | File | 5.12 KB | 0644 |
|
heise.py | File | 6.39 KB | 0644 |
|
hellporno.py | File | 2.65 KB | 0644 |
|
helsinki.py | File | 1.32 KB | 0644 |
|
hentaistigma.py | File | 1.17 KB | 0644 |
|
hgtv.py | File | 1.4 KB | 0644 |
|
hidive.py | File | 4.02 KB | 0644 |
|
historicfilms.py | File | 1.54 KB | 0644 |
|
hitbox.py | File | 7.24 KB | 0644 |
|
hitrecord.py | File | 2.22 KB | 0644 |
|
hketv.py | File | 6.8 KB | 0644 |
|
hornbunny.py | File | 1.49 KB | 0644 |
|
hotnewhiphop.py | File | 2.23 KB | 0644 |
|
hotstar.py | File | 9.23 KB | 0644 |
|
howcast.py | File | 1.34 KB | 0644 |
|
howstuffworks.py | File | 3.38 KB | 0644 |
|
hrti.py | File | 7.03 KB | 0644 |
|
huajiao.py | File | 1.81 KB | 0644 |
|
huffpost.py | File | 3.31 KB | 0644 |
|
hungama.py | File | 3.71 KB | 0644 |
|
hypem.py | File | 1.51 KB | 0644 |
|
ign.py | File | 8.89 KB | 0644 |
|
iheart.py | File | 3.38 KB | 0644 |
|
imdb.py | File | 5.13 KB | 0644 |
|
imggaming.py | File | 4.99 KB | 0644 |
|
imgur.py | File | 4.96 KB | 0644 |
|
ina.py | File | 2.88 KB | 0644 |
|
inc.py | File | 2.25 KB | 0644 |
|
indavideo.py | File | 4.31 KB | 0644 |
|
infoq.py | File | 4.95 KB | 0644 |
|
instagram.py | File | 16.21 KB | 0644 |
|
internazionale.py | File | 3.25 KB | 0644 |
|
internetvideoarchive.py | File | 2.36 KB | 0644 |
|
iprima.py | File | 5.12 KB | 0644 |
|
iqiyi.py | File | 13.31 KB | 0644 |
|
ir90tv.py | File | 1.7 KB | 0644 |
|
itv.py | File | 6.5 KB | 0644 |
|
ivi.py | File | 10.2 KB | 0644 |
|
ivideon.py | File | 3.18 KB | 0644 |
|
iwara.py | File | 3.3 KB | 0644 |
|
izlesene.py | File | 4.05 KB | 0644 |
|
jamendo.py | File | 6.37 KB | 0644 |
|
jeuxvideo.py | File | 1.99 KB | 0644 |
|
joj.py | File | 3.66 KB | 0644 |
|
jove.py | File | 3 KB | 0644 |
|
jwplatform.py | File | 1.68 KB | 0644 |
|
kakao.py | File | 5.38 KB | 0644 |
|
kaltura.py | File | 15.03 KB | 0644 |
|
kankan.py | File | 1.7 KB | 0644 |
|
karaoketv.py | File | 2.29 KB | 0644 |
|
karrierevideos.py | File | 3.3 KB | 0644 |
|
keezmovies.py | File | 4.61 KB | 0644 |
|
ketnet.py | File | 2.47 KB | 0644 |
|
khanacademy.py | File | 3.83 KB | 0644 |
|
kickstarter.py | File | 2.64 KB | 0644 |
|
kinja.py | File | 8.37 KB | 0644 |
|
kinopoisk.py | File | 2.17 KB | 0644 |
|
konserthusetplay.py | File | 4.4 KB | 0644 |
|
krasview.py | File | 1.91 KB | 0644 |
|
ku6.py | File | 992 B | 0644 |
|
kusi.py | File | 3.04 KB | 0644 |
|
kuwo.py | File | 12.24 KB | 0644 |
|
la7.py | File | 2.21 KB | 0644 |
|
laola1tv.py | File | 9.23 KB | 0644 |
|
lbry.py | File | 8.42 KB | 0644 |
|
lci.py | File | 953 B | 0644 |
|
lcp.py | File | 2.88 KB | 0644 |
|
lecture2go.py | File | 2.35 KB | 0644 |
|
lecturio.py | File | 8.24 KB | 0644 |
|
leeco.py | File | 12.8 KB | 0644 |
|
lego.py | File | 5.97 KB | 0644 |
|
lemonde.py | File | 2.27 KB | 0644 |
|
lenta.py | File | 1.64 KB | 0644 |
|
libraryofcongress.py | File | 4.91 KB | 0644 |
|
libsyn.py | File | 3.55 KB | 0644 |
|
lifenews.py | File | 9.4 KB | 0644 |
|
limelight.py | File | 14.54 KB | 0644 |
|
line.py | File | 3.11 KB | 0644 |
|
linkedin.py | File | 6.59 KB | 0644 |
|
linuxacademy.py | File | 9.29 KB | 0644 |
|
litv.py | File | 6.11 KB | 0644 |
|
livejournal.py | File | 1.49 KB | 0644 |
|
liveleak.py | File | 7.83 KB | 0644 |
|
livestream.py | File | 13.38 KB | 0644 |
|
lnkgo.py | File | 3.13 KB | 0644 |
|
localnews8.py | File | 1.69 KB | 0644 |
|
lovehomeporn.py | File | 1.16 KB | 0644 |
|
lrt.py | File | 2.52 KB | 0644 |
|
lynda.py | File | 12.41 KB | 0644 |
|
m6.py | File | 896 B | 0644 |
|
mailru.py | File | 11.26 KB | 0644 |
|
malltv.py | File | 3.22 KB | 0644 |
|
mangomolo.py | File | 1.98 KB | 0644 |
|
manyvids.py | File | 3.05 KB | 0644 |
|
markiza.py | File | 4.42 KB | 0644 |
|
massengeschmacktv.py | File | 2.63 KB | 0644 |
|
matchtv.py | File | 1.77 KB | 0644 |
|
mdr.py | File | 6.9 KB | 0644 |
|
medaltv.py | File | 4.55 KB | 0644 |
|
medialaan.py | File | 9.76 KB | 0644 |
|
mediaset.py | File | 7.65 KB | 0644 |
|
mediasite.py | File | 14.33 KB | 0644 |
|
medici.py | File | 2.24 KB | 0644 |
|
megaphone.py | File | 1.73 KB | 0644 |
|
meipai.py | File | 3.62 KB | 0644 |
|
melonvod.py | File | 2.2 KB | 0644 |
|
meta.py | File | 2.56 KB | 0644 |
|
metacafe.py | File | 11.44 KB | 0644 |
|
metacritic.py | File | 2.61 KB | 0644 |
|
mgoon.py | File | 2.63 KB | 0644 |
|
mgtv.py | File | 3.46 KB | 0644 |
|
miaopai.py | File | 1.46 KB | 0644 |
|
microsoftvirtualacademy.py | File | 7.3 KB | 0644 |
|
minds.py | File | 6.75 KB | 0644 |
|
ministrygrid.py | File | 2.12 KB | 0644 |
|
minoto.py | File | 1.88 KB | 0644 |
|
miomio.py | File | 4.95 KB | 0644 |
|
mit.py | File | 5.09 KB | 0644 |
|
mitele.py | File | 3.14 KB | 0644 |
|
mixcloud.py | File | 11.39 KB | 0644 |
|
mlb.py | File | 4.9 KB | 0644 |
|
mnet.py | File | 2.86 KB | 0644 |
|
moevideo.py | File | 2.77 KB | 0644 |
|
mofosex.py | File | 2.69 KB | 0644 |
|
mojvideo.py | File | 2.04 KB | 0644 |
|
morningstar.py | File | 1.82 KB | 0644 |
|
motherless.py | File | 8.68 KB | 0644 |
|
motorsport.py | File | 1.76 KB | 0644 |
|
movieclips.py | File | 1.85 KB | 0644 |
|
moviezine.py | File | 1.37 KB | 0644 |
|
movingimage.py | File | 1.73 KB | 0644 |
|
msn.py | File | 7.41 KB | 0644 |
|
mtv.py | File | 18.15 KB | 0644 |
|
muenchentv.py | File | 2.08 KB | 0644 |
|
mwave.py | File | 3.2 KB | 0644 |
|
mychannels.py | File | 1.55 KB | 0644 |
|
myspace.py | File | 8.21 KB | 0644 |
|
myspass.py | File | 2.18 KB | 0644 |
|
myvi.py | File | 3.92 KB | 0644 |
|
myvidster.py | File | 918 B | 0644 |
|
nationalgeographic.py | File | 2.86 KB | 0644 |
|
naver.py | File | 6.44 KB | 0644 |
|
nba.py | File | 16.28 KB | 0644 |
|
nbc.py | File | 19.93 KB | 0644 |
|
ndr.py | File | 15.88 KB | 0644 |
|
ndtv.py | File | 4.5 KB | 0644 |
|
nerdcubed.py | File | 1.1 KB | 0644 |
|
neteasemusic.py | File | 16.93 KB | 0644 |
|
netzkino.py | File | 2.98 KB | 0644 |
|
newgrounds.py | File | 5.45 KB | 0644 |
|
newstube.py | File | 3.05 KB | 0644 |
|
nextmedia.py | File | 8.76 KB | 0644 |
|
nexx.py | File | 16.71 KB | 0644 |
|
nfl.py | File | 6.57 KB | 0644 |
|
nhk.py | File | 6.54 KB | 0644 |
|
nhl.py | File | 4.89 KB | 0644 |
|
nick.py | File | 10.8 KB | 0644 |
|
niconico.py | File | 19.88 KB | 0644 |
|
ninecninemedia.py | File | 3.76 KB | 0644 |
|
ninegag.py | File | 4 KB | 0644 |
|
ninenow.py | File | 3.46 KB | 0644 |
|
nintendo.py | File | 1.84 KB | 0644 |
|
njpwworld.py | File | 3.36 KB | 0644 |
|
nobelprize.py | File | 2.07 KB | 0644 |
|
nonktube.py | File | 1.12 KB | 0644 |
|
noovo.py | File | 3.57 KB | 0644 |
|
normalboots.py | File | 2.13 KB | 0644 |
|
nosvideo.py | File | 2.42 KB | 0644 |
|
nova.py | File | 11.55 KB | 0644 |
|
nowness.py | File | 5.88 KB | 0644 |
|
noz.py | File | 3.58 KB | 0644 |
|
npo.py | File | 27.53 KB | 0644 |
|
npr.py | File | 4.94 KB | 0644 |
|
nrk.py | File | 31.14 KB | 0644 |
|
nrl.py | File | 1 KB | 0644 |
|
ntvcojp.py | File | 1.89 KB | 0644 |
|
ntvde.py | File | 3.12 KB | 0644 |
|
ntvru.py | File | 4.94 KB | 0644 |
|
nuevo.py | File | 1.18 KB | 0644 |
|
nuvid.py | File | 2.53 KB | 0644 |
|
nytimes.py | File | 10.03 KB | 0644 |
|
nzz.py | File | 1.38 KB | 0644 |
|
odatv.py | File | 1.46 KB | 0644 |
|
odnoklassniki.py | File | 9.27 KB | 0644 |
|
oktoberfesttv.py | File | 1.47 KB | 0644 |
|
once.py | File | 2.12 KB | 0644 |
|
ondemandkorea.py | File | 1.99 KB | 0644 |
|
onet.py | File | 9.94 KB | 0644 |
|
onionstudios.py | File | 1.89 KB | 0644 |
|
ooyala.py | File | 8.57 KB | 0644 |
|
openload.py | File | 7.99 KB | 0644 |
|
ora.py | File | 3.15 KB | 0644 |
|
orf.py | File | 19.26 KB | 0644 |
|
outsidetv.py | File | 995 B | 0644 |
|
packtpub.py | File | 6.18 KB | 0644 |
|
pandoratv.py | File | 4.69 KB | 0644 |
|
parliamentliveuk.py | File | 1.6 KB | 0644 |
|
patreon.py | File | 5.51 KB | 0644 |
|
pbs.py | File | 35.77 KB | 0644 |
|
pearvideo.py | File | 2.05 KB | 0644 |
|
peertube.py | File | 27.71 KB | 0644 |
|
people.py | File | 1.11 KB | 0644 |
|
performgroup.py | File | 3.28 KB | 0644 |
|
periscope.py | File | 6.81 KB | 0644 |
|
philharmoniedeparis.py | File | 3.67 KB | 0644 |
|
phoenix.py | File | 1.47 KB | 0644 |
|
photobucket.py | File | 1.75 KB | 0644 |
|
picarto.py | File | 5.08 KB | 0644 |
|
piksel.py | File | 6.88 KB | 0644 |
|
pinkbike.py | File | 3.37 KB | 0644 |
|
pinterest.py | File | 7.34 KB | 0644 |
|
pladform.py | File | 4.14 KB | 0644 |
|
platzi.py | File | 7.45 KB | 0644 |
|
playfm.py | File | 2.54 KB | 0644 |
|
playplustv.py | File | 3.64 KB | 0644 |
|
plays.py | File | 1.8 KB | 0644 |
|
playtvak.py | File | 7.1 KB | 0644 |
|
playvid.py | File | 3.22 KB | 0644 |
|
playwire.py | File | 2.35 KB | 0644 |
|
pluralsight.py | File | 18.22 KB | 0644 |
|
podomatic.py | File | 2.58 KB | 0644 |
|
pokemon.py | File | 2.81 KB | 0644 |
|
polskieradio.py | File | 6.51 KB | 0644 |
|
popcorntimes.py | File | 3.28 KB | 0644 |
|
popcorntv.py | File | 2.62 KB | 0644 |
|
porn91.py | File | 2.07 KB | 0644 |
|
porncom.py | File | 3.78 KB | 0644 |
|
pornhd.py | File | 4.53 KB | 0644 |
|
pornhub.py | File | 23.06 KB | 0644 |
|
pornotube.py | File | 3.08 KB | 0644 |
|
pornovoisines.py | File | 3.91 KB | 0644 |
|
pornoxo.py | File | 1.89 KB | 0644 |
|
presstv.py | File | 2.33 KB | 0644 |
|
prosiebensat1.py | File | 21.07 KB | 0644 |
|
puhutv.py | File | 8.26 KB | 0644 |
|
puls4.py | File | 2.24 KB | 0644 |
|
pyvideo.py | File | 2.7 KB | 0644 |
|
qqmusic.py | File | 13.33 KB | 0644 |
|
r7.py | File | 4.49 KB | 0644 |
|
radiobremen.py | File | 2.37 KB | 0644 |
|
radiocanada.py | File | 6.2 KB | 0644 |
|
radiode.py | File | 1.78 KB | 0644 |
|
radiofrance.py | File | 2.04 KB | 0644 |
|
radiojavan.py | File | 2.7 KB | 0644 |
|
rai.py | File | 17.82 KB | 0644 |
|
raywenderlich.py | File | 6.02 KB | 0644 |
|
rbmaradio.py | File | 2.35 KB | 0644 |
|
rds.py | File | 2.73 KB | 0644 |
|
redbulltv.py | File | 9.05 KB | 0644 |
|
reddit.py | File | 5.21 KB | 0644 |
|
redtube.py | File | 5.11 KB | 0644 |
|
regiotv.py | File | 2.21 KB | 0644 |
|
rentv.py | File | 4.06 KB | 0644 |
|
restudy.py | File | 1.32 KB | 0644 |
|
reuters.py | File | 2.38 KB | 0644 |
|
reverbnation.py | File | 1.59 KB | 0644 |
|
rice.py | File | 4.47 KB | 0644 |
|
rmcdecouverte.py | File | 1.97 KB | 0644 |
|
ro220.py | File | 1.42 KB | 0644 |
|
rockstargames.py | File | 2.2 KB | 0644 |
|
roosterteeth.py | File | 5.64 KB | 0644 |
|
rottentomatoes.py | File | 1.25 KB | 0644 |
|
roxwel.py | File | 1.92 KB | 0644 |
|
rozhlas.py | File | 1.86 KB | 0644 |
|
rtbf.py | File | 5.43 KB | 0644 |
|
rte.py | File | 6.14 KB | 0644 |
|
rtl2.py | File | 7.23 KB | 0644 |
|
rtlnl.py | File | 5.76 KB | 0644 |
|
rtp.py | File | 2.2 KB | 0644 |
|
rts.py | File | 8.94 KB | 0644 |
|
rtve.py | File | 9.83 KB | 0644 |
|
rtvnh.py | File | 2.21 KB | 0644 |
|
rtvs.py | File | 1.44 KB | 0644 |
|
ruhd.py | File | 1.55 KB | 0644 |
|
rumble.py | File | 2.13 KB | 0644 |
|
rutube.py | File | 11.2 KB | 0644 |
|
rutv.py | File | 7.88 KB | 0644 |
|
ruutu.py | File | 9.13 KB | 0644 |
|
ruv.py | File | 3.28 KB | 0644 |
|
safari.py | File | 9.52 KB | 0644 |
|
sapo.py | File | 4.39 KB | 0644 |
|
savefrom.py | File | 1.06 KB | 0644 |
|
sbs.py | File | 3.04 KB | 0644 |
|
screencast.py | File | 4.57 KB | 0644 |
|
screencastomatic.py | File | 1.32 KB | 0644 |
|
scrippsnetworks.py | File | 5.5 KB | 0644 |
|
scte.py | File | 4.88 KB | 0644 |
|
seeker.py | File | 2.25 KB | 0644 |
|
senateisvp.py | File | 6.13 KB | 0644 |
|
sendtonews.py | File | 3.74 KB | 0644 |
|
servus.py | File | 5.53 KB | 0644 |
|
sevenplus.py | File | 3.23 KB | 0644 |
|
sexu.py | File | 1.95 KB | 0644 |
|
seznamzpravy.py | File | 7.73 KB | 0644 |
|
shahid.py | File | 7.77 KB | 0644 |
|
shared.py | File | 4.19 KB | 0644 |
|
showroomlive.py | File | 3.05 KB | 0644 |
|
sina.py | File | 4.22 KB | 0644 |
|
sixplay.py | File | 5.13 KB | 0644 |
|
sky.py | File | 5.29 KB | 0644 |
|
skyit.py | File | 8.73 KB | 0644 |
|
skylinewebcams.py | File | 1.42 KB | 0644 |
|
skynewsarabia.py | File | 5.26 KB | 0644 |
|
slideshare.py | File | 2.08 KB | 0644 |
|
slideslive.py | File | 4.13 KB | 0644 |
|
slutload.py | File | 2.29 KB | 0644 |
|
snotr.py | File | 2.44 KB | 0644 |
|
sohu.py | File | 6.75 KB | 0644 |
|
sonyliv.py | File | 4.36 KB | 0644 |
|
soundcloud.py | File | 29.37 KB | 0644 |
|
soundgasm.py | File | 2.36 KB | 0644 |
|
southpark.py | File | 4.58 KB | 0644 |
|
spankbang.py | File | 7.06 KB | 0644 |
|
spankwire.py | File | 6.32 KB | 0644 |
|
spiegel.py | File | 2.33 KB | 0644 |
|
spike.py | File | 1.66 KB | 0644 |
|
sport5.py | File | 3.18 KB | 0644 |
|
sportbox.py | File | 3.34 KB | 0644 |
|
sportdeutschland.py | File | 2.89 KB | 0644 |
|
spotify.py | File | 5.6 KB | 0644 |
|
spreaker.py | File | 5.89 KB | 0644 |
|
springboardplatform.py | File | 4.14 KB | 0644 |
|
sprout.py | File | 2.27 KB | 0644 |
|
srgssr.py | File | 8.07 KB | 0644 |
|
srmediathek.py | File | 2.27 KB | 0644 |
|
stanfordoc.py | File | 3.45 KB | 0644 |
|
steam.py | File | 5.51 KB | 0644 |
|
stitcher.py | File | 5.25 KB | 0644 |
|
streamable.py | File | 3.8 KB | 0644 |
|
streamcloud.py | File | 2.5 KB | 0644 |
|
streamcz.py | File | 3.42 KB | 0644 |
|
streetvoice.py | File | 3.54 KB | 0644 |
|
stretchinternet.py | File | 1.02 KB | 0644 |
|
stv.py | File | 3.37 KB | 0644 |
|
sunporno.py | File | 2.59 KB | 0644 |
|
sverigesradio.py | File | 3.82 KB | 0644 |
|
svt.py | File | 14.34 KB | 0644 |
|
swrmediathek.py | File | 4.27 KB | 0644 |
|
syfy.py | File | 2 KB | 0644 |
|
sztvhu.py | File | 1.63 KB | 0644 |
|
tagesschau.py | File | 11.92 KB | 0644 |
|
tass.py | File | 1.97 KB | 0644 |
|
tbs.py | File | 3.31 KB | 0644 |
|
tdslifeway.py | File | 2.42 KB | 0644 |
|
teachable.py | File | 10.25 KB | 0644 |
|
teachertube.py | File | 4.31 KB | 0644 |
|
teachingchannel.py | File | 1.04 KB | 0644 |
|
teamcoco.py | File | 7.14 KB | 0644 |
|
teamtreehouse.py | File | 5.38 KB | 0644 |
|
techtalks.py | File | 2.47 KB | 0644 |
|
ted.py | File | 13.38 KB | 0644 |
|
tele13.py | File | 3.27 KB | 0644 |
|
tele5.py | File | 3.63 KB | 0644 |
|
telebruxelles.py | File | 2.88 KB | 0644 |
|
telecinco.py | File | 6.08 KB | 0644 |
|
telegraaf.py | File | 2.92 KB | 0644 |
|
telemb.py | File | 2.9 KB | 0644 |
|
telequebec.py | File | 9.09 KB | 0644 |
|
teletask.py | File | 1.7 KB | 0644 |
|
telewebion.py | File | 1.8 KB | 0644 |
|
tennistv.py | File | 3.85 KB | 0644 |
|
tenplay.py | File | 2.91 KB | 0644 |
|
testurl.py | File | 2.06 KB | 0644 |
|
tf1.py | File | 3.53 KB | 0644 |
|
tfo.py | File | 1.99 KB | 0644 |
|
theintercept.py | File | 1.76 KB | 0644 |
|
theplatform.py | File | 17.13 KB | 0644 |
|
thescene.py | File | 1.34 KB | 0644 |
|
thestar.py | File | 1.37 KB | 0644 |
|
thesun.py | File | 1.37 KB | 0644 |
|
theweatherchannel.py | File | 3.92 KB | 0644 |
|
thisamericanlife.py | File | 1.51 KB | 0644 |
|
thisav.py | File | 2.47 KB | 0644 |
|
thisoldhouse.py | File | 1.96 KB | 0644 |
|
threeqsdn.py | File | 6.11 KB | 0644 |
|
tiktok.py | File | 4.69 KB | 0644 |
|
tinypic.py | File | 1.85 KB | 0644 |
|
tmz.py | File | 2.09 KB | 0644 |
|
tnaflix.py | File | 11.93 KB | 0644 |
|
toggle.py | File | 8.76 KB | 0644 |
|
tonline.py | File | 2.04 KB | 0644 |
|
toongoggles.py | File | 2.97 KB | 0644 |
|
toutv.py | File | 3.47 KB | 0644 |
|
toypics.py | File | 2.68 KB | 0644 |
|
traileraddict.py | File | 2.63 KB | 0644 |
|
trilulilu.py | File | 3.54 KB | 0644 |
|
trovo.py | File | 6.09 KB | 0644 |
|
trunews.py | File | 1.45 KB | 0644 |
|
trutv.py | File | 2.47 KB | 0644 |
|
tube8.py | File | 3.01 KB | 0644 |
|
tubitv.py | File | 3.67 KB | 0644 |
|
tudou.py | File | 1.66 KB | 0644 |
|
tumblr.py | File | 7.54 KB | 0644 |
|
tunein.py | File | 5.79 KB | 0644 |
|
tunepk.py | File | 3.13 KB | 0644 |
|
turbo.py | File | 2.37 KB | 0644 |
|
turner.py | File | 10.85 KB | 0644 |
|
tv2.py | File | 7.32 KB | 0644 |
|
tv2dk.py | File | 5.11 KB | 0644 |
|
tv2hu.py | File | 2.35 KB | 0644 |
|
tv4.py | File | 4.29 KB | 0644 |
|
tv5mondeplus.py | File | 4.39 KB | 0644 |
|
tv5unis.py | File | 3.99 KB | 0644 |
|
tva.py | File | 3.08 KB | 0644 |
|
tvanouvelles.py | File | 2.34 KB | 0644 |
|
tvc.py | File | 3.82 KB | 0644 |
|
tver.py | File | 2.19 KB | 0644 |
|
tvigle.py | File | 4.93 KB | 0644 |
|
tvland.py | File | 1.43 KB | 0644 |
|
tvn24.py | File | 3.81 KB | 0644 |
|
tvnet.py | File | 4.83 KB | 0644 |
|
tvnoe.py | File | 1.57 KB | 0644 |
|
tvnow.py | File | 18.04 KB | 0644 |
|
tvp.py | File | 9.2 KB | 0644 |
|
tvplay.py | File | 17.75 KB | 0644 |
|
tvplayer.py | File | 2.76 KB | 0644 |
|
tweakers.py | File | 2.11 KB | 0644 |
|
twentyfourvideo.py | File | 4.64 KB | 0644 |
|
twentymin.py | File | 2.79 KB | 0644 |
|
twentythreevideo.py | File | 3.22 KB | 0644 |
|
twitcasting.py | File | 4.05 KB | 0644 |
|
twitch.py | File | 32.69 KB | 0644 |
|
twitter.py | File | 27.28 KB | 0644 |
|
udemy.py | File | 18.96 KB | 0644 |
|
udn.py | File | 3.49 KB | 0644 |
|
ufctv.py | File | 511 B | 0644 |
|
uktvplay.py | File | 1.33 KB | 0644 |
|
umg.py | File | 3.33 KB | 0644 |
|
unistra.py | File | 2.11 KB | 0644 |
|
unity.py | File | 1.2 KB | 0644 |
|
uol.py | File | 5.41 KB | 0644 |
|
uplynk.py | File | 2.56 KB | 0644 |
|
urort.py | File | 2.2 KB | 0644 |
|
urplay.py | File | 3.76 KB | 0644 |
|
usanetwork.py | File | 795 B | 0644 |
|
usatoday.py | File | 2.64 KB | 0644 |
|
ustream.py | File | 10.51 KB | 0644 |
|
ustudio.py | File | 4.29 KB | 0644 |
|
varzesh3.py | File | 3.16 KB | 0644 |
|
vbox7.py | File | 3.33 KB | 0644 |
|
veehd.py | File | 4.04 KB | 0644 |
|
veoh.py | File | 3.9 KB | 0644 |
|
vesti.py | File | 4.28 KB | 0644 |
|
vevo.py | File | 13.8 KB | 0644 |
|
vgtv.py | File | 10.36 KB | 0644 |
|
vh1.py | File | 1.5 KB | 0644 |
|
vice.py | File | 12.12 KB | 0644 |
|
vidbit.py | File | 2.85 KB | 0644 |
|
viddler.py | File | 4.78 KB | 0644 |
|
videa.py | File | 5.67 KB | 0644 |
|
videodetective.py | File | 906 B | 0644 |
|
videofyme.py | File | 1.71 KB | 0644 |
|
videomore.py | File | 11.46 KB | 0644 |
|
videopress.py | File | 2.94 KB | 0644 |
|
vidio.py | File | 2.79 KB | 0644 |
|
vidlii.py | File | 4.42 KB | 0644 |
|
vidme.py | File | 9.66 KB | 0644 |
|
vidzi.py | File | 2.11 KB | 0644 |
|
vier.py | File | 9.77 KB | 0644 |
|
viewlift.py | File | 9.76 KB | 0644 |
|
viidea.py | File | 7.27 KB | 0644 |
|
viki.py | File | 14.43 KB | 0644 |
|
vimeo.py | File | 45.68 KB | 0644 |
|
vimple.py | File | 1.92 KB | 0644 |
|
vine.py | File | 5.2 KB | 0644 |
|
viqeo.py | File | 3.22 KB | 0644 |
|
viu.py | File | 9.05 KB | 0644 |
|
vk.py | File | 25.26 KB | 0644 |
|
vlive.py | File | 11.6 KB | 0644 |
|
vodlocker.py | File | 2.73 KB | 0644 |
|
vodpl.py | File | 1.01 KB | 0644 |
|
vodplatform.py | File | 1.53 KB | 0644 |
|
voicerepublic.py | File | 2.25 KB | 0644 |
|
voot.py | File | 3.48 KB | 0644 |
|
voxmedia.py | File | 9.07 KB | 0644 |
|
vrak.py | File | 2.87 KB | 0644 |
|
vrt.py | File | 3.44 KB | 0644 |
|
vrv.py | File | 10.85 KB | 0644 |
|
vshare.py | File | 2.23 KB | 0644 |
|
vube.py | File | 6.77 KB | 0644 |
|
vuclip.py | File | 2.2 KB | 0644 |
|
vvvvid.py | File | 8.62 KB | 0644 |
|
vyborymos.py | File | 1.98 KB | 0644 |
|
vzaar.py | File | 3.53 KB | 0644 |
|
wakanim.py | File | 2.32 KB | 0644 |
|
walla.py | File | 2.75 KB | 0644 |
|
washingtonpost.py | File | 5.13 KB | 0644 |
|
wat.py | File | 4.53 KB | 0644 |
|
watchbox.py | File | 5.8 KB | 0644 |
|
watchindianporn.py | File | 2.24 KB | 0644 |
|
wdr.py | File | 12.92 KB | 0644 |
|
webcaster.py | File | 3.74 KB | 0644 |
|
webofstories.py | File | 5.42 KB | 0644 |
|
weibo.py | File | 4.39 KB | 0644 |
|
weiqitv.py | File | 1.64 KB | 0644 |
|
wistia.py | File | 7.06 KB | 0644 |
|
worldstarhiphop.py | File | 1.31 KB | 0644 |
|
wsj.py | File | 4.58 KB | 0644 |
|
wwe.py | File | 4.43 KB | 0644 |
|
xbef.py | File | 1.41 KB | 0644 |
|
xboxclips.py | File | 1.9 KB | 0644 |
|
xfileshare.py | File | 7.08 KB | 0644 |
|
xhamster.py | File | 14.95 KB | 0644 |
|
xiami.py | File | 6.66 KB | 0644 |
|
ximalaya.py | File | 9.68 KB | 0644 |
|
xminus.py | File | 2.87 KB | 0644 |
|
xnxx.py | File | 2.82 KB | 0644 |
|
xstream.py | File | 3.89 KB | 0644 |
|
xtube.py | File | 6.98 KB | 0644 |
|
xuite.py | File | 5.67 KB | 0644 |
|
xvideos.py | File | 5.16 KB | 0644 |
|
xxxymovies.py | File | 2.61 KB | 0644 |
|
yahoo.py | File | 22.33 KB | 0644 |
|
yandexdisk.py | File | 5.04 KB | 0644 |
|
yandexmusic.py | File | 16.71 KB | 0644 |
|
yandexvideo.py | File | 5.13 KB | 0644 |
|
yapfiles.py | File | 3.14 KB | 0644 |
|
yesjapan.py | File | 2.14 KB | 0644 |
|
yinyuetai.py | File | 1.86 KB | 0644 |
|
ynet.py | File | 1.76 KB | 0644 |
|
youjizz.py | File | 3.05 KB | 0644 |
|
youku.py | File | 11.14 KB | 0644 |
|
younow.py | File | 6.92 KB | 0644 |
|
youporn.py | File | 8.2 KB | 0644 |
|
yourporn.py | File | 2.01 KB | 0644 |
|
yourupload.py | File | 1.38 KB | 0644 |
|
youtube.py | File | 158.61 KB | 0644 |
|
zapiks.py | File | 3.74 KB | 0644 |
|
zattoo.py | File | 13.99 KB | 0644 |
|
zdf.py | File | 11.66 KB | 0644 |
|
zingmp3.py | File | 4.71 KB | 0644 |
|
zype.py | File | 5.43 KB | 0644 |
|