]>
jfr.im git - yt-dlp.git/blob - yt_dlp/extractor/hungama.py
2 from __future__
import unicode_literals
6 from .common
import InfoExtractor
14 class HungamaIE(InfoExtractor
):
17 (?:www\.)?hungama\.com/
19 (?:video|movie)/[^/]+/|
20 tv-show/(?:[^/]+/){2}\d+/episode/[^/]+/
25 'url': 'http://www.hungama.com/video/krishna-chants/39349649/',
26 'md5': 'a845a6d1ebd08d80c1035126d49bd6a0',
30 'title': 'Lucky Ali - Kitni Haseen Zindagi',
31 'track': 'Kitni Haseen Zindagi',
32 'artist': 'Lucky Ali',
37 'url': 'https://www.hungama.com/movie/kahaani-2/44129919/',
38 'only_matching': True,
40 'url': 'https://www.hungama.com/tv-show/padded-ki-pushup/season-1/44139461/episode/ep-02-training-sasu-pathlaag-karing/44139503/',
41 'only_matching': True,
44 def _real_extract(self
, url
):
45 video_id
= self
._match
_id
(url
)
47 webpage
= self
._download
_webpage
(url
, video_id
)
49 info
= self
._search
_json
_ld
(webpage
, video_id
)
51 m3u8_url
= self
._download
_json
(
52 'https://www.hungama.com/index.php', video_id
,
53 data
=urlencode_postdata({'content_id': video_id}
), headers
={
54 'Content-Type': 'application/x-www-form-urlencoded; charset=UTF-8',
55 'X-Requested-With': 'XMLHttpRequest',
58 'm': 'get_video_mdn_url',
61 formats
= self
._extract
_m
3u8_formats
(
62 m3u8_url
, video_id
, ext
='mp4', entry_protocol
='m3u8_native',
64 self
._sort
_formats
(formats
)
73 class HungamaSongIE(InfoExtractor
):
74 _VALID_URL
= r
'https?://(?:www\.)?hungama\.com/song/[^/]+/(?P<id>\d+)'
76 'url': 'https://www.hungama.com/song/kitni-haseen-zindagi/2931166/',
77 'md5': 'd4a6a05a394ad0453a9bea3ca00e6024',
81 'title': 'Lucky Ali - Kitni Haseen Zindagi',
82 'track': 'Kitni Haseen Zindagi',
83 'artist': 'Lucky Ali',
89 def _real_extract(self
, url
):
90 audio_id
= self
._match
_id
(url
)
92 data
= self
._download
_json
(
93 'https://www.hungama.com/audio-player-data/track/%s' % audio_id
,
94 audio_id
, query
={'_country': 'IN'}
)[0]
95 track
= data
['song_name']
96 artist
= data
.get('singer_name')
98 media_json
= self
._download
_json
(data
.get('file') or data
['preview_link'], audio_id
)
99 media_url
= try_get(media_json
, lambda x
: x
['response']['media_url'], str)
100 media_type
= try_get(media_json
, lambda x
: x
['response']['type'], str)
107 'acodec': media_type
,
110 title
= '%s - %s' % (artist
, track
) if artist
else track
111 thumbnail
= data
.get('img_src') or data
.get('album_image')
116 'thumbnail': thumbnail
,
119 'album': data
.get('album_name') or None,
120 'release_year': int_or_none(data
.get('date')),
125 class HungamaAlbumPlaylistIE(InfoExtractor
):
126 _VALID_URL
= r
'https?://(?:www\.)?hungama\.com/(?:playlists|album)/[^/]+/(?P<id>\d+)'
128 'url': 'https://www.hungama.com/album/bhuj-the-pride-of-india/69481490/',
129 'playlist_mincount': 7,
134 'url': 'https://www.hungama.com/playlists/hindi-jan-to-june-2021/123063/',
135 'playlist_mincount': 50,
141 def _real_extract(self
, url
):
142 video_id
= self
._match
_id
(url
)
143 webpage
= self
._download
_webpage
(url
, video_id
)
144 ptrn
= r
'<meta[^>]+?property=[\"\']?music
:song
:url
[\"\']?
[^
>]+?content
=[\"\']?
([^
\"\']+)'
145 items = re.findall(ptrn, webpage)
146 entries = [self.url_result(item, ie=HungamaSongIE.ie_key()) for item in items]
147 return self.playlist_result(entries, video_id)