[urort] Add extractor (Fixes #2634)
parent
e9c076c317
commit
e2b06e76c1
2 changed files with 58 additions and 0 deletions
@ -0,0 +1,57 @@ |
||||
# coding: utf-8 |
||||
from __future__ import unicode_literals |
||||
|
||||
import re |
||||
|
||||
from .common import InfoExtractor |
||||
from ..utils import ( |
||||
compat_urllib_parse, |
||||
) |
||||
|
||||
|
||||
class UrortIE(InfoExtractor): |
||||
IE_DESC = 'NRK P3 Urørt' |
||||
_VALID_URL = r'https?://(?:www\.)?urort\.p3\.no/#!/Band/(?P<id>[^/]+)$' |
||||
|
||||
_TEST = { |
||||
'url': 'https://urort.p3.no/#!/Band/Gerilja', |
||||
'md5': '5ed31a924be8a05e47812678a86e127b', |
||||
'info_dict': { |
||||
'id': '33124-4', |
||||
'ext': 'mp3', |
||||
'title': 'The Bomb', |
||||
'thumbnail': 're:^https?://.+\.jpg', |
||||
'like_count': int, |
||||
'uploader': 'Gerilja', |
||||
'uploader_id': 'Gerilja', |
||||
}, |
||||
'params': { |
||||
'matchtitle': '^The Bomb$', # To test, we want just one video |
||||
} |
||||
} |
||||
|
||||
def _real_extract(self, url): |
||||
mobj = re.match(self._VALID_URL, url) |
||||
playlist_id = mobj.group('id') |
||||
|
||||
fstr = compat_urllib_parse.quote("InternalBandUrl eq '%s'" % playlist_id) |
||||
json_url = 'http://urort.p3.no/breeze/urort/TrackDtos?$filter=' + fstr |
||||
songs = self._download_json(json_url, playlist_id) |
||||
|
||||
entries = [{ |
||||
'id': '%d-%s' % (s['BandId'], s['$id']), |
||||
'title': s['Title'], |
||||
'url': s['TrackUrl'], |
||||
'ext': 'mp3', |
||||
'uploader_id': playlist_id, |
||||
'uploader': s.get('BandName', playlist_id), |
||||
'like_count': s.get('LikeCount'), |
||||
'thumbnail': 'http://urort.p3.no/cloud/images/%s' % s['Image'], |
||||
} for s in songs] |
||||
|
||||
return { |
||||
'_type': 'playlist', |
||||
'id': playlist_id, |
||||
'title': playlist_id, |
||||
'entries': entries, |
||||
} |
Loading…
Reference in new issue