~facundo/encuentro/trunk

« back to all changes in this revision

Viewing changes to external/youtube-dl/youtube_dl/extractor/mailru.py

  • Committer: Facundo Batista
  • Date: 2015-12-27 11:27:15 UTC
  • mto: This revision was merged to the branch mainline in revision 274.
  • Revision ID: facundo@taniquetil.com.ar-20151227112715-ztuasdhqm26hycug
Able to download TEDx.

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
# encoding: utf-8
 
2
from __future__ import unicode_literals
 
3
 
 
4
import re
 
5
 
 
6
from .common import InfoExtractor
 
7
 
 
8
 
 
9
class MailRuIE(InfoExtractor):
 
10
    IE_NAME = 'mailru'
 
11
    IE_DESC = 'Видео@Mail.Ru'
 
12
    _VALID_URL = r'http://(?:www\.)?my\.mail\.ru/(?:video/.*#video=/?(?P<idv1>(?:[^/]+/){3}\d+)|(?:(?P<idv2prefix>(?:[^/]+/){2})video/(?P<idv2suffix>[^/]+/\d+))\.html)'
 
13
 
 
14
    _TESTS = [
 
15
        {
 
16
            'url': 'http://my.mail.ru/video/top#video=/mail/sonypicturesrus/75/76',
 
17
            'md5': 'dea205f03120046894db4ebb6159879a',
 
18
            'info_dict': {
 
19
                'id': '46301138_76',
 
20
                'ext': 'mp4',
 
21
                'title': 'Новый Человек-Паук. Высокое напряжение. Восстание Электро',
 
22
                'timestamp': 1393232740,
 
23
                'upload_date': '20140224',
 
24
                'uploader': 'sonypicturesrus',
 
25
                'uploader_id': 'sonypicturesrus@mail.ru',
 
26
                'duration': 184,
 
27
            },
 
28
            'skip': 'Not accessible from Travis CI server',
 
29
        },
 
30
        {
 
31
            'url': 'http://my.mail.ru/corp/hitech/video/news_hi-tech_mail_ru/1263.html',
 
32
            'md5': '00a91a58c3402204dcced523777b475f',
 
33
            'info_dict': {
 
34
                'id': '46843144_1263',
 
35
                'ext': 'mp4',
 
36
                'title': 'Samsung Galaxy S5 Hammer Smash Fail Battery Explosion',
 
37
                'timestamp': 1397217632,
 
38
                'upload_date': '20140411',
 
39
                'uploader': 'hitech',
 
40
                'uploader_id': 'hitech@corp.mail.ru',
 
41
                'duration': 245,
 
42
            },
 
43
            'skip': 'Not accessible from Travis CI server',
 
44
        },
 
45
    ]
 
46
 
 
47
    def _real_extract(self, url):
 
48
        mobj = re.match(self._VALID_URL, url)
 
49
        video_id = mobj.group('idv1')
 
50
 
 
51
        if not video_id:
 
52
            video_id = mobj.group('idv2prefix') + mobj.group('idv2suffix')
 
53
 
 
54
        video_data = self._download_json(
 
55
            'http://api.video.mail.ru/videos/%s.json?new=1' % video_id, video_id, 'Downloading video JSON')
 
56
 
 
57
        author = video_data['author']
 
58
        uploader = author['name']
 
59
        uploader_id = author.get('id') or author.get('email')
 
60
        view_count = video_data.get('views_count')
 
61
 
 
62
        meta_data = video_data['meta']
 
63
        content_id = '%s_%s' % (
 
64
            meta_data.get('accId', ''), meta_data['itemId'])
 
65
        title = meta_data['title']
 
66
        if title.endswith('.mp4'):
 
67
            title = title[:-4]
 
68
        thumbnail = meta_data['poster']
 
69
        duration = meta_data['duration']
 
70
        timestamp = meta_data['timestamp']
 
71
 
 
72
        formats = [
 
73
            {
 
74
                'url': video['url'],
 
75
                'format_id': video['key'],
 
76
                'height': int(video['key'].rstrip('p'))
 
77
            } for video in video_data['videos']
 
78
        ]
 
79
        self._sort_formats(formats)
 
80
 
 
81
        return {
 
82
            'id': content_id,
 
83
            'title': title,
 
84
            'thumbnail': thumbnail,
 
85
            'timestamp': timestamp,
 
86
            'uploader': uploader,
 
87
            'uploader_id': uploader_id,
 
88
            'duration': duration,
 
89
            'view_count': view_count,
 
90
            'formats': formats,
 
91
        }