Compare commits

...

2 Commits

Author SHA1 Message Date
joshwd36
539d280291
Merge 8a0905798e into e1b3fa242c 2024-07-28 01:35:00 +09:00
joshwd36
8a0905798e Add MacProVideo extractor 2022-06-02 17:33:02 +01:00
3 changed files with 91 additions and 0 deletions

View File

@ -482,6 +482,7 @@
- **lynda**: lynda.com videos
- **lynda:course**: lynda.com online courses
- **m6**
- **MacProVideo.com**
- **mailru**: Видео@Mail.Ru
- **mailru:music**: Музыка@Mail.Ru
- **mailru:music:search**: Музыка@Mail.Ru

View File

@ -652,6 +652,10 @@ from .lynda import (
LyndaCourseIE
)
from .m6 import M6IE
from .macprovideo import (
MacProVideoIE,
MacProVideoCourseIE
)
from .mailru import (
MailRuIE,
MailRuMusicIE,

View File

@ -0,0 +1,86 @@
# coding: utf-8
from __future__ import unicode_literals
import re
from youtube_dl.utils import try_get, str_or_none
from .common import InfoExtractor
class MacProVideoBaseIE(InfoExtractor):
def _get_video_info(self, data):
meta = data.get('ned_programmanifest')
video_id = str_or_none(meta.get('fk_videoMediaID'))
formats = self._extract_m3u8_formats(
data['video_medium']['mediaURL'], video_id, 'mp4', m3u8_id='hls', fatal=False)
self._sort_formats(formats)
description = try_get(data, lambda x: x['ned_programmanifest_description']['description'])
thumbnail = try_get(data, lambda x: x['thumbnail_medium']['mediaURL'])
return {
'id': video_id,
'title': meta.get('vid_title'),
'description': description,
'thumbnail': thumbnail,
'duration': meta.get('vid_duration'),
'formats': formats
}
class MacProVideoIE(MacProVideoBaseIE):
_VALID_URL = r'https?://(?:www\.)?macprovideo\.com/video/(?P<course>[0-9a-zA-Z-]+)/(?P<num>[0-9]+)-[0-9a-zA-Z-]+'
_TEST = {
'url': 'https://www.macprovideo.com/video/apple-logic-pro-102-recording-and-editing-audio/1-1-transducers-and-converters',
'md5': 'md5:608d7c8cf9f31202cbd269273df62aaf',
'info_dict': {
'id': '319676',
'ext': 'mp4',
'title': '1. Transducers and Converters',
'thumbnail': r're:^https?://.*\.jpg$',
'description': 'md5:c16dc8a42252e2be44225f129c591c3d',
},
'params': {
# m3u8 download
'skip_download': True,
'format': 'bestvideo'
},
}
def _real_extract(self, url):
course, num = re.match(self._VALID_URL, url).groups()
num = int(num) - 1
data = self._download_json('https://www.macprovideo.com/ajax/videos/' + course,
None)['data']['videos'][num]
return self._get_video_info(data)
class MacProVideoCourseIE(MacProVideoBaseIE):
_VALID_URL = r'https?://(?:www\.)?macprovideo\.com/course/(?P<id>[0-9a-zA-Z-]+)'
_TEST = {
'url': 'https://www.macprovideo.com/course/apple-logic-pro-102-recording-and-editing-audio',
'md5': 'md5:608d7c8cf9f31202cbd269273df62aaf',
'info_dict': {
'id': '319676',
'ext': 'mp4',
'title': '1. Transducers and Converters',
'thumbnail': r're:^https?://.*\.jpg$',
'description': 'md5:c16dc8a42252e2be44225f129c591c3d',
},
'params': {
# m3u8 download
'skip_download': True,
'format': 'bestvideo'
},
}
def _real_extract(self, url):
course_id = self._match_id(url)
videos = self._download_json('https://www.macprovideo.com/ajax/videos/' + course_id, None)['data']['videos']
title = try_get(videos, lambda x: x[0]['tutorial']['tu_title'])
return self.playlist_result(
[self._get_video_info(data) for data in videos],
playlist_id=course_id, playlist_title=title)