From 27fe903c511691c078942bef5ee9a05a43b15c8f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jes=C3=BAs?= Date: Wed, 9 Jun 2021 17:54:27 -0500 Subject: initial --- hypervideo_dl/extractor/hypem.py | 49 ++++++++++++++++++++++++++++++++++++++++ 1 file changed, 49 insertions(+) create mode 100644 hypervideo_dl/extractor/hypem.py (limited to 'hypervideo_dl/extractor/hypem.py') diff --git a/hypervideo_dl/extractor/hypem.py b/hypervideo_dl/extractor/hypem.py new file mode 100644 index 0000000..9ca28d6 --- /dev/null +++ b/hypervideo_dl/extractor/hypem.py @@ -0,0 +1,49 @@ +from __future__ import unicode_literals + +from .common import InfoExtractor +from ..utils import int_or_none + + +class HypemIE(InfoExtractor): + _VALID_URL = r'https?://(?:www\.)?hypem\.com/track/(?P[0-9a-z]{5})' + _TEST = { + 'url': 'http://hypem.com/track/1v6ga/BODYWORK+-+TAME', + 'md5': 'b9cc91b5af8995e9f0c1cee04c575828', + 'info_dict': { + 'id': '1v6ga', + 'ext': 'mp3', + 'title': 'Tame', + 'uploader': 'BODYWORK', + 'timestamp': 1371810457, + 'upload_date': '20130621', + } + } + + def _real_extract(self, url): + track_id = self._match_id(url) + + response = self._download_webpage(url, track_id) + + track = self._parse_json(self._html_search_regex( + r'(?s)(.+?)', + response, 'tracks'), track_id)['tracks'][0] + + track_id = track['id'] + title = track['song'] + + final_url = self._download_json( + 'http://hypem.com/serve/source/%s/%s' % (track_id, track['key']), + track_id, 'Downloading metadata', headers={ + 'Content-Type': 'application/json' + })['url'] + + return { + 'id': track_id, + 'url': final_url, + 'ext': 'mp3', + 'title': title, + 'uploader': track.get('artist'), + 'duration': int_or_none(track.get('time')), + 'timestamp': int_or_none(track.get('ts')), + 'track': title, + } -- cgit v1.2.3