]>
jfr.im git - yt-dlp.git/blob - yt_dlp/extractor/hotnewhiphop.py
1 from .common
import InfoExtractor
2 from ..compat
import compat_b64decode
11 class HotNewHipHopIE(InfoExtractor
):
12 _VALID_URL
= r
'https?://(?:www\.)?hotnewhiphop\.com/.*\.(?P<id>.*)\.html'
14 'url': 'http://www.hotnewhiphop.com/freddie-gibbs-lay-it-down-song.1435540.html',
15 'md5': '2c2cd2f76ef11a9b3b581e8b232f3d96',
19 'title': 'Freddie Gibbs - Lay It Down'
23 def _real_extract(self
, url
):
24 video_id
= self
._match
_id
(url
)
25 webpage
= self
._download
_webpage
(url
, video_id
)
27 video_url_base64
= self
._search
_regex
(
28 r
'data-path="(.*?)"', webpage
, 'video URL', default
=None)
30 if video_url_base64
is None:
31 video_url
= self
._search
_regex
(
32 r
'"contentUrl" content="(.*?)"', webpage
, 'content URL')
33 return self
.url_result(video_url
, ie
='Youtube')
35 reqdata
= urlencode_postdata([
37 ('mediaId', video_id
),
39 r
= sanitized_Request(
40 'http://www.hotnewhiphop.com/ajax/media/getActions/', data
=reqdata
)
41 r
.add_header('Content-Type', 'application/x-www-form-urlencoded')
42 mkd
= self
._download
_json
(
43 r
, video_id
, note
='Requesting media key',
44 errnote
='Could not download media key')
45 if 'mediaKey' not in mkd
:
46 raise ExtractorError('Did not get a media key')
48 redirect_url
= compat_b64decode(video_url_base64
).decode('utf-8')
49 redirect_req
= HEADRequest(redirect_url
)
50 req
= self
._request
_webpage
(
51 redirect_req
, video_id
,
52 note
='Resolving final URL', errnote
='Could not resolve final URL')
53 video_url
= req
.geturl()
54 if video_url
.endswith('.html'):
55 raise ExtractorError('Redirect failed')
57 video_title
= self
._og
_search
_title
(webpage
).strip()
63 'thumbnail': self
._og
_search
_thumbnail
(webpage
),